MNIST数据集,图像识别(二)

        预测所有的数字,现在我们将mnist.py文件里面从加载标签以后的代码做以修改。

def encode_digit(Y, digit):
    encoded_Y = np.zeros_like(Y)
    n_labels = Y.shape[0]
    for i in range(n_labels):
        if Y[i] == digit:
            encoded_Y[i][0] = 1
    return encoded_Y


TRAINING_LABELS = load_labels("../data/mnist/train-labels-idx1-ubyte.gz")
TEST_LABELS = load_labels("../data/mnist/t10k-labels-idx1-ubyte.gz")


Y_train = []
Y_test = []

for digit in range(10):
    Y_train.append(encode_digit(TRAINING_LABELS, digit))
    Y_test.append(encode_digit(TEST_LABELS, digit))

        修改分类算法里的代码,如下: 

# iterations为迭代次数
def train(X, Y, iterations, lr):
    w = np.zeros((X.shape[1], 1))  # 初始化权重w
    for i in range(iterations):
        # print("Iteration %4d => Loss: %.20f" % (i, loss(X, Y, w)))
        w -= gradient(X, Y, w) * lr
    return w


def test(X, Y, w, digit):
    total_examples = X.shape[0]
    correct_results = np.sum(classify(X, w) == Y)
    success_percent = correct_results * 100 / total_examples
    print("Correct classifications for digit %d: %d/%d (%.2f%%)" %
          (digit, correct_results, total_examples, success_percent))


for digit in range(10):
    # 训练模型
    w = train(mi.X_train, mi.Y_train[digit], iterations=100, lr=1e-5)
    # 模型测试
    test(mi.X_test, mi.Y_test[digit], w, digit)

        运行后,得到如下结果: 

        我们发现预测数字8的效果显然没有其它数字的效果好,进一步地说明我们的训练算法还有很大地改进空间,不过这样的结果还能接受!

参考文献:

Programming Machine Learning: Form Coding to Deep Learning.[M],Paolo Perrotta,2021.6. 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值