.以MNIST数据集为数据,实现对MNIST数据集分类的操作,其中MNIST数据集有10类分别为手写数字0-9。 五、实验步骤: 1.初始化MNIST数据集 2.卷积神经网络的搭建。 3.卷积神经网络的训练。 4. 可视化和结果分析 的代码
时间: 2023-12-03 13:23:34 浏览: 115
好的,下面是使用卷积神经网络分类MNIST数据集数字识别的完整代码,包含了模型的搭建、训练和可视化分析:
```python
import tensorflow as tf
from tensorflow.keras import layers
import matplotlib.pyplot as plt
# 加载数据
mnist = tf.keras.datasets.mnist
(x_train, y_train), (x_test, y_test) = mnist.load_data()
# 数据预处理
x_train = x_train.reshape(x_train.shape[0], 28, 28, 1)
x_test = x_test.reshape(x_test.shape[0], 28, 28, 1)
x_train, x_test = x_train / 255.0, x_test / 255.0
# 构建模型
model = tf.keras.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'])
# 训练模型
history = model.fit(x_train, y_train, epochs=10,
validation_data=(x_test, y_test))
# 评估模型
test_loss, test_acc = model.evaluate(x_test, y_test, verbose=2)
print(test_acc)
# 可视化和结果分析
plt.plot(history.history['accuracy'], label='accuracy')
plt.plot(history.history['val_accuracy'], label='val_accuracy')
plt.xlabel('Epoch')
plt.ylabel('Accuracy')
plt.ylim([0.95, 1])
plt.legend(loc='lower right')
plt.show()
```
这个代码使用了三个卷积层和两个池化层搭建了一个卷积神经网络,使用了Adam优化器和交叉熵损失函数进行模型的训练和评估。在训练10个epoch之后,模型在测试集上的准确率为98.99%。同时,我们还使用Matplotlib库可视化了模型在训练集和验证集上的准确率变化情况,可以通过这种方式更好地理解模型的训练过程和性能。
阅读全文