搭建CNN网络训练mnist数据集

1. 加载需要的包

import tensorflow as tf
from tensorflow import keras
from tensorflow.keras import layers, optimizers, losses, datasets, Sequential
from tensorflow.keras.datasets import mnist
from tensorflow.keras.layers import Dense, Dropout, Activation, Flatten, Conv2D, MaxPooling2D, GlobalMaxPool2D
from tensorflow.keras.optimizers import RMSprop
import matplotlib.pyplot as plt
import numpy as np

2. 载入数据集

# 将数据集载入,x_train为训练集数据,y_train为训练集标签,x_test为测试集数据,y_test为测试集标签
(x_train, y_train), (x_test, y_test) = mnist.load_data()
#数据集的变换
x_train = x_train.reshape(60000, 28, 28, 1)
x_test = x_test.reshape(10000, 28, 28, 1)
x_train = x_train.astype('float32')
x_test = x_test.astype('float32')
x_train /= 255 #把数值变成0-1之间的浮点数。
x_test /=255
y_train = keras.utils.to_categorical(y_train, num_classes=10)
y_test = keras.utils.to_categorical(y_test, num_classes=10)

3. 搭建网络模型

# 构建CNN网络
model = Sequential()
model.add(Conv2D(32, (3, 3), padding='same',input_shape=x_train.shape[1:])) # 卷积层
model.add(Activation('relu'))

model.add(MaxPooling2D(pool_size=(2, 2))) # 最大池化层

model.add(Conv2D(64, (3, 3), padding='same')) # 卷积层
model.add(Activation('relu'))

model.add(GlobalMaxPool2D()) # 全局池化层

model.add(Flatten())

model.add(Dense(10)) # 全连接输出层
model.add(Activation('softmax'))
print(model.summary())
model.compile(loss='categorical_crossentropy', optimizer=RMSprop(), metrics=['accuracy'])

在这里插入图片描述

4. 模型训练

#模型训练
history = model.fit(x_train, y_train, 
                    batch_size=128, 
                    epochs=10, 
                    verbose=1, 
                    validation_data=(x_test, y_test))

在这里插入图片描述

5. 模型测试

# 模型测试
score = model.evaluate(x_test, y_test, verbose=1)
print('Test loss:', score[0])
print('Test accuracy:', score[1]) # 识别准确率

在这里插入图片描述

6. 训练过程可视化

# 绘制CNN网络训练过程中训练集和测试集合的准确率值
plt.plot(history.history['accuracy'])
plt.plot(history.history['val_accuracy'])
plt.title('Model accuracy')
plt.ylabel('Accuracy')
plt.xlabel('Epoch')
plt.legend(['Train', 'Test'], loc='upper left')
plt.show()

在这里插入图片描述

# 绘制CNN网络训练过程中训练集和测试集合的损失值
plt.plot(history.history['loss'])
plt.plot(history.history['val_loss'])
plt.title('Model loss')
plt.ylabel('Loss')
plt.xlabel('Epoch')
plt.legend(['Train', 'Test'], loc='upper left')
plt.show()

在这里插入图片描述

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: MNIST 数据集是一个用来识别手写数字的常见数据集。要使用 CNN 实现 MNIST 数据集的识别,需要执行以下步骤: 1. 准备数据。MNIST 数据集包含 60000 张训练图像和 10000 张测试图像。图像是 28x28 的灰度图像,每张图像都有一个与之对应的标签(数字)。 2. 构建 CNN 模型。CNN 通常由输入层、卷积层、池化层和全连接层组成。首先,输入层接受图像数据。然后,卷积层会使用不同的卷积核(又称滤波器)对输入进行卷积,从而提取图像的特征。池化层则会将提取的特征缩小,以减小模型的复杂度。最后,全连接层会将特征映射到输出,即对应的标签。 3. 训练模型。使用训练数据训练模型。训练过程,模型会自动调整权重和偏置,以使模型的预测更准确。 4. 评估模型。使用测试数据评估模型的准确率。这有助于检查模型是否过拟合或欠拟合,并且可以为进一步提升模型性能提供线索 ### 回答2: CNN卷积神经网络(Convolutional Neural Network)的缩写,它是一种深度学习网络结构,可以用于图像识别任务。MNIST数据集是一个常用的手写数字识别数据集,包含了60000个训练样本和10000个测试样本,每个样本都是一个28×28像素的灰度图像。下面是使用CNN实现MNIST数据集识别的步骤: 1. 数据准备:首先,我们需要将MNIST数据集导入到程序。可以使用Python的numpy和matplotlib库来加载和处理数据。数据集包含了训练集和测试集,每个样本都有对应的标签。 2. 构建CNN模型:我们需要设计一个合适的卷积神经网络模型来训练和识别MNIST数据集CNN通常由卷积层、池化层和全连接层组成。可以使用Keras或PyTorch等深度学习库来构建模型,选择适当的网络结构和参数进行训练。 3. 模型训练:将准备好的训练数据输入到CNN模型进行训练训练过程,模型会自动调整参数,通过反向传播算法更新权重。训练可以通过设置合适的超参数(如学习率、批次大小和训练轮数)来进行。 4. 模型评估:训练完成后,使用测试集评估模型的性能。将测试集输入到已训练好的模型进行预测,并与测试集的真实标签进行对比。可以使用准确率等指标来评估模型的性能。 5. 模型应用:训练好的CNN模型可以应用于实际图像识别任务。使用模型对新的手写数字图像进行预测,输出对应的数字标签。 通过以上步骤,我们可以使用CNN实现对MNIST数据集的识别。CNN在图像识别任务取得了很好的效果,其卷积和池化操作可以有效地提取图像的特征,从而实现高精度的识别。 ### 回答3: CNN是一种深度学习算法,可以应用于图像识别任务,其非常经典的一个应用就是用CNN实现MNIST数据集的识别。 MNIST数据集是一个由手写数字组成的数据集,其包含了60000个训练样本和10000个测试样本,每个样本是一个28×28像素的灰度图像。 CNN的结构通常由卷积层、池化层和全连接层构成。首先,卷积层通过使用卷积核对输入图像进行卷积操作,提取图像的特征。卷积操作可以捕获图像的边缘、纹理等特征。接下来,经过池化层的操作,通过降低特征图的维度,减少参数数量,同时保留主要的特征。最后,通过全连接层将提取的特征输入到 softmax 分类器,实现对不同数字的分类。 具体实现,可以使用Python语言和深度学习框架TensorFlow来实现CNN模型。首先,加载MNIST数据集,并对图像进行预处理,将其归一化到0-1之间。然后,搭建CNN模型,可以选择合适的卷积核大小、池化方式和激活函数等。接着,定义损失函数,一般使用交叉熵损失函数。最后,使用优化算法,如梯度下降法,来不断调整模型参数,使得损失函数最小化。 训练模型时,将训练样本输入CNN模型,通过反向传播算法进行参数的更新,直到达到预设的停止条件。训练完成后,使用测试集评估模型的性能,计算准确率等指标。 通过实现CNN模型对MNIST数据集的识别,可以获得很高的准确率,达到甚至超过人类的识别能力。这个实验可以帮助我们理解深度学习CNN在图像识别领域的应用,并为以后深入研究和实践提供基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vicky__3021

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值