'predict_generator'返回值大于1小于0

时间:2019-02-01 13:56:56

标签: machine-learning keras deep-learning auto-keras

我用Autokeras训练我的模型,然后在fit_final之后将其另存为纯keras h5文件。

我的模特:

from autokeras import ImageClassifier
from autokeras.image.image_supervised import load_image_dataset

if __name__ == '__main__':
    x_test, y_test = load_image_dataset(csv_file_path="test/label.csv", images_path="test")
    print(x_test.shape)
    print(y_test.shape)

    x_train, y_train = load_image_dataset(csv_file_path="train/label.csv", images_path="train")
    print(x_train.shape)
    print(y_train.shape)

    clf = ImageClassifier(path="~/automodels/", verbose=True)
    clf.fit(x_train, y_train, time_limit= 1 * 10 * 60)
    clf.final_fit(x_train, y_train, x_test, y_test, retrain=True)
    y = clf.evaluate(x_test, y_test)
    print(y)

    clf.export_autokeras_model('my_autokeras_model.h5ak')
    clf.export_keras_model('my_model.h5')

我也有一个predict.py代码,但它给了我错误的值

from keras.models import load_model
from keras.preprocessing import image
import numpy as np
import glob
from keras.preprocessing.image import ImageDataGenerator
from sklearn.metrics import confusion_matrix

# dimensions of our images
img_width, img_height = 128, 128

# load the model we saved
model = load_model('model.h5')
#model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy'])

datagen = ImageDataGenerator(rescale=1./255)

generator = datagen.flow_from_directory(
        'data/test',
        target_size=(img_width, img_height),
        batch_size=1,
        class_mode=None,  # only data, no labels
        shuffle=False)  # keep data in same order as labels

#filenames = datagen.filenames
#nb_samples = len(filenames)

probabilities = model.predict_generator(generator, 4)

实际结果:

[[-2.0996048  1.862035 ]
 [-1.4634153  1.2710633]
 [-1.4367918  1.4041075]
 [-1.3242773  1.2946494]]

预期结果应如下所示:

[[0  0.51234 ]
 [1  0.67847]
 [1  0.92324]
 [1  0.32333]]

例如。

我在做什么错了?

1 个答案:

答案 0 :(得分:0)

在Mickey向我建议激活功能后,我在github here上找到了这个线程

该线程帮助我找出了这些代码行:

'' Creation of file B
fileName = InputBox("Entrer le nom du fichier :", "Création d'un nouveau fichier...", "KIBANA_01022019")

If fileName <> "" Then
    Set NewWkbk = Workbooks.Add
    NewWkbk.SaveAs directory & "\" & fileName
else 
    exit sub ' (or whatever you want to do)
End If

ThisWorkbook.Worksheets("Kibana").Range("A1" & ":V" & nbLigneImportCanope).Copy _
    NewWkbk.WorkSheets(1).Range("A1")