如何在Keras中使用训练有素的模型执行预测

时间:2019-10-31 18:46:22

标签: python keras deep-learning classification prediction

我是Keras的新手。通过在线教程进行迁移学习,我尝试为自定义数据集训练模型,下面是我的代码。现在我应该如何根据图像进行分类?

这是培训代码:

def build_finetune_model(base_model, dropout, fc_layers, num_classes):
    for layer in base_model.layers:
        layer.trainable = False

    x = base_model.output
    x = Flatten()(x)
    for fc in fc_layers:
        # New FC layer, random init
        x = Dense(fc, activation='relu')(x) 
        x = Dropout(dropout)(x)

    # New softmax layer
    predictions = Dense(num_classes, activation='softmax')(x) 
    finetune_model = Model(inputs=base_model.input, outputs=predictions)
    return finetune_model

train_datagen =  ImageDataGenerator(preprocessing_function=preprocess_input)
train_generator = train_datagen.flow_from_directory(TRAIN_DIR, 
                                                    target_size=(HEIGHT, WIDTH), 
                                                    batch_size=BATCH_SIZE)
base_model = MobileNetV2(weights='imagenet', include_top=False, input_shape=(HEIGHT, WIDTH, 3))

root=TRAIN_DIR
class_list = [ item for item in os.listdir(root) if os.path.isdir(os.path.join(root, item)) ]
print (class_list)

FC_LAYERS = [1024, 1024]
dropout = 0.5

finetune_model = build_finetune_model(base_model, dropout=dropout, fc_layers=FC_LAYERS, num_classes=len(class_list))
adam = Adam(lr=0.00001)
finetune_model.compile(adam, loss='categorical_crossentropy', metrics=['accuracy'])
filepath="./checkpoints/" + "MobileNetV2_{epoch:02d}_{acc:.2f}" +"_model_weights.h5"
checkpoint = ModelCheckpoint(filepath, monitor=["acc"], verbose=1, mode='max', save_weights_only=True)
callbacks_list = [checkpoint]

history = finetune_model.fit_generator(train_generator, epochs=NUM_EPOCHS, workers=8, 
                                       steps_per_epoch=steps_per_epoch, 
                                       shuffle=True, callbacks=callbacks_list)

这是我的分类代码,仅返回浮点数数组!

if __name__ == '__main__':
    model = load_model('ResNet50_model_weights.h5')

    img_path = 'test.jpg'
    img = image.load_img(img_path, target_size=(300, 300))
    x = image.img_to_array(img)
    x = np.expand_dims(x, axis=0)
    print('Input image shape:', x.shape)

    results = model.predict(x)
    print('Predicted:', results)

1 个答案:

答案 0 :(得分:2)

您模型的最后一层是softmax,这意味着它输出每个类别在0和1之间的概率。为了确定输入图像是哪个类别,请使用argmax结果。 argmax返回数组中最大元素的索引。

predicted_class_label = np.argmax(results)
print("network predicted input image is class {}".format(predicted_class_label))