gpt4 book ai didi

deep-learning - Keras 多分类中的多个预测?

转载 作者:行者123 更新时间:2023-12-04 06:03:46 25 4
gpt4 key购买 nike

我正在学习使用 Keras 设计卷积神经网络。我开发了一个使用 VGG16 作为基础的简单模型。我在数据集中有大约 6 类图像。这是我的模型的代码和描述。

model = models.Sequential()
conv_base = VGG16(weights='imagenet' ,include_top=False, input_shape=(IMAGE_SIZE, IMAGE_SIZE, 3))
conv_base.trainable = False
model.add(conv_base)
model.add(layers.Flatten())
model.add(layers.Dense(256, activation='relu', kernel_regularizer=regularizers.l2(0.001)))
model.add(layers.Dropout(0.5))
model.add(layers.Dense(6, activation='sigmoid'))

1

这是编译和拟合模型的代码:
model.compile(loss='categorical_crossentropy',
optimizer=optimizers.RMSprop(lr=1e-4),
metrics=['acc'])
model.summary()

callbacks = [
EarlyStopping(monitor='acc', patience=1, mode='auto'),
ModelCheckpoint(monitor='val_loss', save_best_only=True, filepath=model_file_path)
]

history = model.fit_generator(
train_generator,
steps_per_epoch=10,
epochs=EPOCHS,
validation_data=validation_generator,
callbacks = callbacks,
validation_steps=10)

这是预测新图像的代码
img = image.load_img(img_path, target_size=(IMAGE_SIZE, IMAGE_SIZE))
plt.figure(index)
imgplot = plt.imshow(img)

x = image.img_to_array(img)
x = x.reshape((1,) + x.shape)
prediction = model.predict(x)[0]
# print(prediction)

通常 model.predict() 方法预测不止一个类。
[0 1 1 0 0 0]

我有一些问题
  • 多类分类模型预测多个输出是否正常?
  • 如果预测了一个以上的类别,如何在训练期间测量准确度?
  • 如何修改神经网络以便只预测一类?

  • 任何帮助表示赞赏。非常感谢!

    最佳答案

    你不是在做多类分类,而是多标签。这是由在输出层使用 sigmoid 激活引起的。要正确进行多类分类,请在输出处使用 softmax 激活,这将产生类的概率分布。
    正如预期的那样,采用具有最大概率 (argmax) 的类将产生单个类预测。

    关于deep-learning - Keras 多分类中的多个预测?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45509296/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com