用卷积神经网络写一段猫狗图像识别的代码
时间: 2024-01-18 08:03:28 浏览: 75
好的,以下是一个简单的猫狗图像识别的卷积神经网络代码,使用Keras框架:
```python
from keras.models import Sequential
from keras.layers import Conv2D, MaxPooling2D, Flatten, Dense
# 创建卷积神经网络模型
model = Sequential()
# 添加卷积层和池化层
model.add(Conv2D(32, (3, 3), input_shape=(64, 64, 3), activation='relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))
model.add(Conv2D(32, (3, 3), activation='relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))
# 添加平坦层和全连接层
model.add(Flatten())
model.add(Dense(units=128, activation='relu'))
model.add(Dense(units=1, activation='sigmoid'))
# 编译模型
model.compile(optimizer='adam', loss='binary_crossentropy', metrics=['accuracy'])
# 加载数据集
from keras.preprocessing.image import ImageDataGenerator
train_datagen = ImageDataGenerator(rescale=1./255, shear_range=0.2, zoom_range=0.2, horizontal_flip=True)
test_datagen = ImageDataGenerator(rescale=1./255)
training_set = train_datagen.flow_from_directory('training_set', target_size=(64, 64), batch_size=32, class_mode='binary')
test_set = test_datagen.flow_from_directory('test_set', target_size=(64, 64), batch_size=32, class_mode='binary')
# 训练模型
model.fit_generator(training_set, steps_per_epoch=len(training_set), epochs=25, validation_data=test_set, validation_steps=len(test_set))
# 保存模型
model.save('cat_dog_cnn.h5')
```
在这个代码中,我们使用了一个包含两个卷积层和池化层的卷积神经网络。我们使用了ImageDataGenerator来预处理数据集,并使用了fit_generator方法来训练模型。最后,我们将训练好的模型保存到cat_dog_cnn.h5文件中。
阅读全文