cnn实现mnist数据集分类
时间: 2023-09-04 13:08:11 浏览: 107
好的,下面是使用CNN实现MNIST数据集分类的Python代码:
```python
import tensorflow as tf
from tensorflow.keras import datasets, layers, models
# 加载MNIST数据集
(train_images, train_labels), (test_images, test_labels) = datasets.mnist.load_data()
# 数据预处理
train_images = train_images.reshape((-1, 28, 28, 1)) / 255.0
test_images = test_images.reshape((-1, 28, 28, 1)) / 255.0
# 构建CNN模型
model = models.Sequential([
layers.Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1)),
layers.MaxPooling2D((2, 2)),
layers.Conv2D(64, (3, 3), activation='relu'),
layers.MaxPooling2D((2, 2)),
layers.Conv2D(64, (3, 3), activation='relu'),
layers.Flatten(),
layers.Dense(64, activation='relu'),
layers.Dense(10, activation='softmax')
])
# 编译模型
model.compile(optimizer='adam',
loss='sparse_categorical_crossentropy',
metrics=['accuracy'])
# 训练模型
model.fit(train_images, train_labels, epochs=5, validation_data=(test_images, test_labels))
# 评估模型
test_loss, test_acc = model.evaluate(test_images, test_labels)
print('Test accuracy:', test_acc)
```
这段代码中,我们首先加载MNIST数据集,然后对数据进行预处理,将像素值缩放到[0, 1]的范围内。接着,我们构建了一个包含三个卷积层和两个全连接层的CNN模型,并使用`model.compile()`方法编译了模型,指定了优化器、损失函数和评估指标。最后,我们使用`model.fit()`方法训练模型,并在测试集上评估模型的性能。
阅读全文