手写数字识别:Python+BP神经网络

该项目使用Python3.6和PyQt5创建了一个手写数字识别应用,通过BP神经网络进行识别。训练数据来源于Mnist训练集,用户可以在画板上绘制数字,程序会进行实时识别。详细步骤包括环境配置、神经网络定义与训练、识别算法实现以及交互界面设计。
摘要由CSDN通过智能技术生成

此项目及使用方法已上传至Github,请移步至https://github.com/choutsugi/handwritten-number-recognizer查看。

1.简述

编程语言Python3.6
界面设计PyQt5
识别方法BP神经网络
训练数据Mnist训练集
手写数字获取画图板

2.环境配置

此项目使用python3.6.3版本,请做参考,更高或更低版本可能不适用本项目(无法安装依赖或程序异常退出)。
项目依赖:requirement.txt

numpy==1.12.0
Pillow==4.2.0
PyQt5==5.11.3
PyQt5-sip==4.19.19
PyQt5-stubs==5.11.3.0
sip==4.19.8

3.文件目录

项目文件列表:

文件/文件夹 用途
Mnist文件夹 手写数字训练集
Resource文件夹 界面设计相关图像
tmp文件夹 图像处理临时文件
bp_train.py 神经网络训练
Main.py 主程序
MainWidget.py 交互界面
NN.py 神经网络定义
PaintBoard.py 画板
recognize.py 识别算法
weights.npy 权重

4.主程序

main.py

from MainWidget import MainWidget
from PyQt5.QtWidgets import QApplication
from PyQt5.Qt import *
import sys

def main():
    app = QApplication(sys.argv)
    app.setWindowIcon(QIcon('./Resource/icon/xmf.ico'))
    mainWidget = MainWidget()  # 新建一个主界面
    mainWidget.show()  # 显示主界面

    exit(app.exec_())  # 进入消息循环

if __name__ == '__main__':
    main()

5.神经网络定义

NN.py

import numpy as np

def LabelBinarizer(label):
    relabel=np.zeros([len(label),10],dtype=np.int32)
    for i in range(len(label)):
        relabel[i][label[i]]=1
    return relabel

def tanh(x):
    return np.tanh(x)

def tanh_deriv(x):
    return 1.0 - np.tanh(x)*np.tanh(x)

def logistic(x):
    return 1/(1 + np.exp(-x))

def logistic_derivative(x):
    return logistic(x)*(1-logistic(x))

class NeuralNetwork:
    def __init__(self, layers, activation='tanh'):
 
        if activation == 'logistic':
            self.activation = logistic
            self.activation_deriv = logistic_derivative
        elif activation == 'tanh':
            self.activation = tanh
            self.activation_deriv = tanh_deriv

        self.weights = []
        for i in range(1, len(layers) - 1):
            self.weights.append((2*np.random.random((layers[i - 1] + 1, layers[i] + 1))-1)*0.25)
            self.weights.append((2*np.random.random((layers[i] + 1, layers[i + 1]))-1)*0.25)

    def fit(self, X, y, learning_rate=0.15, epochs=60000):
        X = np.atleast_2d(X)
        temp = np.ones([X.shape[0], X.shape[1]+1])
        temp[:, 0:-1] = X  
        X = temp
        y = np.array(y)

        for k in range(epochs):
            print(k+1)
            i = np.random.randint(X.shape[0])
            a = [X[i]]

            for l in range(len(self.weights)):  
                a.append(self.activation(np.dot(a[l], self.weights[l])))  
            error = y[i] - a[-1]  
            deltas = [error * self.activation_deriv(a[-1])] 
            
            for l in range(len(a) - 2, 0, -1): 
                deltas.append(deltas[-1].dot(self.weights[l].T)*self.activation_deriv(a[l]))
            deltas.reverse()
            for i in range(len(self.weights)):
                layer = np.atleast_2d(a[i])
                delta = np.atleast_2d(deltas[i])
                self.weights[i] += learning_rate * layer.T.dot(delta)
        np.save("weights",self.weights)

    def predict(self, x):
        self.weights=np.load("weights.npy")
        x = np.array(x)
        temp = np.ones(x.shape[0]+
  • 9
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
### 回答1: BP神经网络是一种常用的人工神经网络,可以用于数字识别。在Python中,可以使用第三方库如TensorFlow、Keras、PyTorch等来实现BP神经网络。具体实现步骤包括:1.准备数字数据集;2.将数据集分为训练集和测试集;3.构建BP神经网络模型;4.训练模型;5.测试模型准确率。通过不断调整神经网络的参数和结构,可以提高数字识别的准确率。 ### 回答2: BP神经网络(BP neural network)是一种常用的人工神经网络算法,可以实现数字识别。在Python中,可以使用一些库来实现此功能,例如TensorFlow、PyTorch或Keras。 首先需要准备一个数字识别数据集,比如常用的MNIST数据集。该数据集包含了大量的数字图像和对应的标签。可以使用Python的相关库,如scikit-learn或TensorFlow提供的API,快速获取和加载这些数据。 接下来,需要搭建BP神经网络模型。可以使用上述库提供的各种API、类和函数来创建一个神经网络模型。可以选择不同的网络架构,比如使用多个隐藏层,每个隐藏层有不同的神经元数量。也可以根据实际情况设置不同的激活函数和损失函数,如ReLU、sigmoid或softmax等。 然后,使用训练集对模型进行训练。通过多次迭代,将输入的数字图像与其对应的输出标签进行比较,并通过反向传播算法不断调整模型的权重和偏置,以使模型的损失函数逐渐减小。 最后,使用测试集对训练好的模型进行测试和评估。将测试集中的数字图像输入到模型中,然后与对应的真实标签进行比较,计算模型的准确率和其他评估指标。 总结来说,使用Python中的相关库和算法,可以实现BP神经网络来进行数字识别。通过准备数据集、搭建模型、训练模型和评估模型的过程,可以实现高效准确地识别数字的功能。 ### 回答3: 实现数字识别的方法之一是使用BP神经网络BP神经网络是一种常见的人工神经网络,它通过反向传播算法来训练和优化网络参数。 在Python中,我们可以使用一些开源的深度学习库(如TensorFlow、Keras或PyTorch)来实现BP神经网络进行数字识别。 首先,需要准备一个包含大量数字的训练集和测试集。我们可以使用MNIST(Modified National Institute of Standards and Technology)数据集,它包含了60000个训练样本和10000个测试样本。 然后,我们可以使用Python中的深度学习库来创建和训练BP神经网络模型。下面是一个使用Keras库的示例代码: 1. 引入所需库: ```python import numpy as np from keras.models import Sequential from keras.layers import Dense from keras.datasets import mnist ``` 2. 加载和预处理数据集: ```python (x_train, y_train), (x_test, y_test) = mnist.load_data() x_train = x_train.reshape(x_train.shape[0], 784).astype('float32') / 255 x_test = x_test.reshape(x_test.shape[0], 784).astype('float32') / 255 y_train = np_utils.to_categorical(y_train) y_test = np_utils.to_categorical(y_test) ``` 3. 构建神经网络模型: ```python model = Sequential() model.add(Dense(units=512, input_dim=784, activation='relu')) model.add(Dense(units=512, activation='relu')) model.add(Dense(units=10, activation='softmax')) ``` 4. 编译和训练模型: ```python model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy']) model.fit(x_train, y_train, validation_data=(x_test, y_test), epochs=10, batch_size=128) ``` 5. 对新样本进行预测: ```python predictions = model.predict(x_test) ``` 以上是BP神经网络实现数字识别Python代码示例。在实际操作中,还可以进行模型调参、数据增强和模型评估等进一步优化措施。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值