首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >对CNN的预测有困难

对CNN的预测有困难
EN

Stack Overflow用户
提问于 2018-11-13 12:24:54
回答 1查看 92关注 0票数 0

我第一次使用卷积神经网络进行车辆识别。目前,我只使用2个类(自行车和汽车)。训练集: 420个汽车图像和825个自行车图像。测试集: 44个汽车图像和110个自行车图像汽车和自行车图像是不同的格式(bmp,jpg)。在单项预测中,我总是得到“自行车”。我已经尝试在输出层中使用Sigmoid函数。那么我只能得到'car‘。我的代码如下:

代码语言:javascript
复制
from keras.models import Sequential
from keras.layers import Conv2D
from keras.layers import MaxPooling2D
from keras.layers import Flatten
from keras.layers import Dense,Dropout



classifier = Sequential()


classifier.add(Conv2D(32, (3, 3), input_shape = (128, 128, 3), activation = 'relu'))


classifier.add(MaxPooling2D(pool_size = (3, 3)))

# Adding a second convolutional layer
classifier.add(Conv2D(32, (3, 3), activation = 'relu'))
classifier.add(MaxPooling2D(pool_size = (3, 3)))

# Step 3 - Flattening
classifier.add(Flatten())

# Step 4 - Full connection
classifier.add(Dropout(0.3))
classifier.add(Dense(units = 128, activation = 'relu'))
classifier.add(Dense(units = 1, activation = 'sigmoid'))

# Compiling the CNN
classifier.compile(optimizer = 'adam', loss = 'binary_crossentropy', metrics = ['accuracy'])

# Part 2 - Fitting the CNN to the images

from keras.preprocessing.image import ImageDataGenerator

train_datagen = ImageDataGenerator(rescale = 1./255,
                                   shear_range = 0.2,
                                   zoom_range = 0.2,
                                   rotation_range= 3,
                                   fill_mode = 'nearest',
                                   horizontal_flip = True)

test_datagen = ImageDataGenerator(rescale = 1./255,
                                   shear_range = 0.2,
                                   zoom_range = 0.2,
                                   rotation_range= 3,
                                   fill_mode = 'nearest',
                                   horizontal_flip = True)

training_set = train_datagen.flow_from_directory('dataset/training_set',
                                                 target_size = (128, 128),
                                                 batch_size = 10,
                                                 class_mode = 'binary')

test_set = test_datagen.flow_from_directory('dataset/test_set',
                                            target_size = (128, 128),
                                            batch_size = 10,
                                            class_mode = 'binary')

classifier.fit_generator(training_set,
                         steps_per_epoch = 1092//10,
                         epochs = 3,
                         validation_data = test_set,
                         validation_steps = 20)

classifier.save("car_bike.h5")

我想测试一个图像,如下所示:

代码语言:javascript
复制
test_image = image.load_img('dataset/single_prediction/download (3).jpg', target_size = (128, 128))
test_image = image.img_to_array(test_image)
test_image *= (1/255.0)
test_image = np.expand_dims(test_image, axis = 0)
result = classifier.predict(test_image)
if result[0][0] == 1:
    prediction = 'bike'
else:
    prediction = 'car'

print(" {}".format(prediction))
EN

回答 1

Stack Overflow用户

发布于 2018-11-13 13:33:29

如果您打印您的result矩阵,您将看到它不仅仅有1和0,而是在这些数字之间浮动。您可以选择一个阈值,并将超过该阈值的值设置为1,将其他值设置为0。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53273786

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档