Получить вероятности от Keras CNN Forett () на функциональной модели API - PullRequest
1 голос
/ 03 апреля 2019

Как я могу получить вероятности от Кераса?

Я тренировал свою модель CNN для 3 классов. Когда я использую метод предсказания () обученной модели (используя Functional API) на новом тестовом изображении, я всегда получаю один горячий закодированный вывод, например, i [0, 1, 0], тогда как я хотел бы получить вывод, такой как [0.1, 0.95, 0.1].

Я использую softmax в качестве последней активации, поэтому все вероятности составляют до 1, что ожидается. Однако я сделал фиктивную модель, в которой обучил ее только в одну эпоху, и у меня все еще есть один горячий закодированный вывод, а не вероятности.

Я что-то не так делаю, например, вызываю неправильный метод? Иначе как я могу получить выходные данные последнего слоя, чтобы я мог нормализовать выходные данные?

Фрагмент сценария прогнозирования:

model = load_model('./model.h5')
model.compile(loss='categorical_crossentropy',
              optimizer='adadelta',
              metrics=['acc'])

img = image.load_img(path.name,
                     target_size=(128, 128),
                     color_mode='grayscale')
img = image.img_to_array(img)
img = np.expand_dims(img, axis=0)
probability = model.predict(img)
print(probability)

Сценарий поезда:

# Creates input shape for theano or tensorflow.
if K.image_data_format() == 'channels_first':
    input_shape = (1, 128, 128)
else:
    input_shape = (128, 128, 1)
visible = Input(shape=input_shape)

conv1_1 = Conv2D(filters=8,kernel_size=(5, 5),padding='same', strides = 1)(visible)
prelu1_1 = PReLU(alpha_initializer='zeros')(conv1_1)
pool1_1 = MaxPooling2D(pool_size=(2, 2),strides=2)(prelu1_1)

flat1 = Flatten()(pool1_1)

conv2_1 = Conv2D(filters=8,kernel_size=(5, 5),padding='same', strides = 1)(visible)
prelu2_1 = PReLU(alpha_initializer='zeros')(conv2_1)
pool2_1 = MaxPooling2D(pool_size=(2, 2),strides=2)(prelu2_1)

flat2 = Flatten()(pool2_1)

# Merge layers
merge = concatenate([flat1, flat2])

dense = Dense(64)(merge)
prelu3 = PReLU(alpha_initializer='zeros')(dense)
dropout3 = Dropout(rate=0.4)(prelu3)

dense4 = Dense(3)(dropout3)
output = Activation('softmax')(dense4)

model = Model(inputs=visible, outputs=output)

model.compile(loss='categorical_crossentropy',
              optimizer='Adadelta',
              metrics=['accuracy'])

train_datagen = ImageDataGenerator(
    rescale=1. / 255,
    shear_range=0.2,
    width_shift_range=0.1,
    height_shift_range=0.1,
    rotation_range=5,
    horizontal_flip=True)

test_datagen = ImageDataGenerator(
    rescale=1. / 255, )


train_data_dir = r'D:\path\to\train'
validation_data_dir = r'D:\path\to\validation'

train_generator = train_datagen.flow_from_directory(
    train_data_dir,
    target_size=(128, 128),
    batch_size=32,
    color_mode='grayscale',
    class_mode='categorical')

validation_generator = test_datagen.flow_from_directory(
    validation_data_dir,
    target_size=(128, 128),
    batch_size=32,
    color_mode='grayscale',
    class_mode='categorical')

model_final = model.fit_generator(
    train_generator,
    steps_per_epoch=11000 // 32,
    epochs=1,
    validation_data=validation_generator,
    validation_steps=3000 // 32)

# Save model
model.save('./model.h5')

Версия Keras: 2.1.6

Примечание: model построен на функциональном API, то есть (keras.models.Model())

1 Ответ

1 голос
/ 03 апреля 2019

Если вы не используете функциональный API, вы можете сделать model.predict_proba() для получения вероятностей.

probability = model.predict_proba(img)

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...