假设您有一个函数 get_model() 可以构建您已训练的完全相同的模型,并且路径 weights_path 指向包含模型权重的 HDF5 文件:
model = get_model()
model.load_weights(weights_path)
这应该会正确加载您的模型。然后,您只需定义测试数据的ImageDataGenerator 并拟合模型以获得预测:
# Path to your folder testing data
testing_folder = ""
# Image size (set up the image size used for training)
img_size = 256
# Batch size (you should tune it based on your memory)
batch_size = 16
val_datagen = ImageDataGenerator(
rescale=1. / 255)
validation_generator = val_datagen.flow_from_directory(
testing_folder,
target_size=(img_size, img_size),
batch_size=batch_size,
shuffle=False,
class_mode='categorical')
然后,您可以使用model.predict_generator() 方法使模型在整个数据集上生成所有预测:
# Number of steps corresponding to an epoch
steps = 100
predictions = model.predict_generator(validation_generator, steps=steps)
最后使用sklearn 包中的metrics.confusion_matrix() 方法创建一个混淆矩阵:
val_preds = np.argmax(predictions, axis=-1)
val_trues = validation_generator.classes
cm = metrics.confusion_matrix(val_trues, val_preds)
或者使用sklearn 中的metrics.precision_recall_fscore_support() 方法获取所有类的所有精度、召回率和f1 分数(参数average=None 输出所有类的指标):
# label names
labels = validation_generator.class_indices.keys()
precisions, recall, f1_score, _ = metrics.precision_recall_fscore_support(val_trues, val_preds, labels=labels)
我没有测试过,但我想这会对你有所帮助。