Python实现bp神经网络识别MNIST数据集

时间:2023-01-08 09:58:53

title: "Python实现bp神经网络识别MNIST数据集"

date: 2018-06-18T14:01:49+08:00

tags: [""]

categories: ["python"]


前言

训练时读入的是.mat格式的训练集,测试正确率时用的是png格式的图片

代码

#!/usr/bin/env python3
# coding=utf-8
import math
import sys
import os
import numpy as np
from PIL import Image
import scipy.io as sio def sigmoid(x):
return np.array(list(map(lambda i: 1 / (1 + math.exp(-i)), x))) def get_train_pattern():
# 返回训练集的特征和标签
# current_dir = os.getcwd()
current_dir = "/home/lxp/F/developing_folder/intelligence_system/bpneuralnet/"
train = sio.loadmat(current_dir + "mnist_train.mat")["mnist_train"]
train_label = sio.loadmat(
current_dir + "mnist_train_labels.mat")["mnist_train_labels"]
train = np.where(train > 180, 1, 0) # 二值化
return train, train_label def get_test_pattern():
# 返回测试集
# base_url = os.getcwd() + "/test/"
base_url = "/home/lxp/F/developing_folder/intelligence_system/bpneuralnet/mnist_test/"
test_img_pattern = []
for i in range(10):
img_url = os.listdir(base_url + str(i))
t = []
for url in img_url:
img = Image.open(base_url + str(i) + "/" + url)
img = img.convert('1') # 二值化
img_array = np.asarray(img, 'i') # 转化为int数组
img_vector = img_array.reshape(
img_array.shape[0] * img_array.shape[1]) # 展开成一维数组
t.append(img_vector)
test_img_pattern.append(t)
return test_img_pattern class BPNetwork:
# 神经网络类
def __init__(self, in_count, hiden_count, out_count, in_rate, hiden_rate):
""" :param in_count: 输入层数
:param hiden_count: 隐藏层数
:param out_count: 输出层数
:param in_rate: 输入层学习率
:param hiden_rate: 隐藏层学习率
"""
# 各个层的节点数量
self.in_count = in_count
self.hiden_count = hiden_count
self.out_count = out_count # 输入层到隐藏层连线的权重随机初始化
self.w1 = 0.2 * \
np.random.random((self.in_count, self.hiden_count)) - 0.1 # 隐藏层到输出层连线的权重随机初始化
self.w2 = 0.2 * \
np.random.random((self.hiden_count, self.out_count)) - 0.1 # 隐藏层偏置向量
self.hiden_offset = np.zeros(self.hiden_count)
# 输出层偏置向量
self.out_offset = np.zeros(self.out_count) # 输入层学习率
self.in_rate = in_rate
# 隐藏层学习率
self.hiden_rate = hiden_rate def train(self, train_img_pattern, train_label):
if self.in_count != len(train_img_pattern[0]):
sys.exit("输入层维数与样本维数不等")
# for num in range(10):
# for num in range(10):
for i in range(len(train_img_pattern)):
if i % 5000 == 0:
print(i)
# 生成目标向量
target = [0] * 10
target[train_label[i][0]] = 1
# for t in range(len(train_img_pattern[num])):
# 前向传播
# 隐藏层值等于输入层*w1+隐藏层偏置
hiden_value = np.dot(
train_img_pattern[i], self.w1) + self.hiden_offset
hiden_value = sigmoid(hiden_value) # 计算输出层的输出
out_value = np.dot(hiden_value, self.w2) + self.out_offset
out_value = sigmoid(out_value) # 反向更新
error = target - out_value
# 计算输出层误差
out_error = out_value * (1 - out_value) * error
# 计算隐藏层误差
hiden_error = hiden_value * \
(1 - hiden_value) * np.dot(self.w2, out_error) # 更新w2,w2是j行k列的矩阵,存储隐藏层到输出层的权值
for k in range(self.out_count):
# 更新w2第k列的值,连接隐藏层所有节点到输出层的第k个节点的边
# 隐藏层学习率×输入层误差×隐藏层的输出值
self.w2[:, k] += self.hiden_rate * out_error[k] * hiden_value # 更新w1
for j in range(self.hiden_count):
self.w1[:, j] += self.in_rate * \
hiden_error[j] * train_img_pattern[i] # 更新偏置向量
self.out_offset += self.hiden_rate * out_error
self.hiden_offset += self.in_rate * hiden_error def test(self, test_img_pattern):
"""
测试神经网络的正确率
:param test_img_pattern[num][t]表示数字num的第t张图片
:return:
"""
right = np.zeros(10)
test_sum = 0
for num in range(10): # 10个数字
# print("正在识别", num)
num_count = len(test_img_pattern[num])
test_sum += num_count
for t in range(num_count): # 数字num的第t张图片
hiden_value = np.dot(
test_img_pattern[num][t], self.w1) + self.hiden_offset
hiden_value = sigmoid(hiden_value)
out_value = np.dot(hiden_value, self.w2) + self.out_offset
out_value = sigmoid(out_value)
# print(out_value)
if np.argmax(out_value) == num:
# 识别正确
right[num] += 1
print("数字%d的识别正确率%f" % (num, right[num] / num_count)) # 平均识别率
print("平均识别率为:", sum(right) / test_sum) """
def test1: """ def run():
# 读入训练集
train, train_label = get_train_pattern() # 读入测试图片
test_pattern = get_test_pattern() # 神经网络配置参数
in_count = 28 * 28
hiden_count = 6
out_count = 10
in_rate = 0.1
hiden_rate = 0.1
bpnn = BPNetwork(in_count, hiden_count, out_count, in_rate, hiden_rate)
bpnn.train(train, train_label)
bpnn.test(test_pattern) # 单张测试
# 识别单独一张图片,返回识别结果
"""
while True:
img_name = input("输入要识别的图片\n")
base_url = "/home/lxp/F/developing_folder/intelligence_system/bpneuralnet/"
img_url = base_url + img_name
img = Image.open(img_url)
img = img.convert('1') # 二值化
img_array = np.asarray(img, 'i') # 转化为int数组
# 得到图片的特征向量
img_v = img_array.reshape(img_array.shape[0] * img_array.shape[1]) # 展开成一维数组
bpnn.test1(img_v) """ if __name__ == "__main__":
run()
# train, train_label = get_train_pattern()
# print(train_label[5][0])
# test = get_test_pattern()

数据集下载:

链接: https://pan.baidu.com/s/1ldWTSqVUm6l1cc4EDOzHpQ 提取码: mm93

Python实现bp神经网络识别MNIST数据集的更多相关文章

  1. 【Python】keras神经网络识别mnist

    上次用Matlab写过一个识别Mnist的神经网络,地址在:https://www.cnblogs.com/tiandsp/p/9042908.html 这次又用Keras做了一个差不多的,毕竟,现在 ...

  2. matlab练习程序(神经网络识别mnist手写数据集)

    记得上次练习了神经网络分类,不过当时应该有些地方写的还是不对. 这次用神经网络识别mnist手写数据集,主要参考了深度学习工具包的一些代码. mnist数据集训练数据一共有28*28*60000个像素 ...

  3. RNN入门(一)识别MNIST数据集

    RNN介绍   在读本文之前,读者应该对全连接神经网络(Fully Connected Neural Network, FCNN)和卷积神经网络( Convolutional Neural Netwo ...

  4. python构建bp神经网络_曲线拟合(一个隐藏层)__2.代码实现

    IDE:jupyter 抽象程度可能不是那么高,以后再优化. 理论和代码实现的差距还是挺大的 数据集请查看 python构建bp神经网络(一个隐藏层)__1.数据可视化 部分代码预览 git上传.ip ...

  5. SGD与Adam识别MNIST数据集

    几种常见的优化函数比较:https://blog.csdn.net/w113691/article/details/82631097 ''' 基于Adam识别MNIST数据集 ''' import t ...

  6. python对BP神经网络实现

    python对BP神经网络实现 一.概念理解 开始之前首先了解一下BP神经网络,BP的英文是back propagationd的意思,它是一种按误差反向传播(简称误差反传)训练的多层前馈网络,其算法称 ...

  7. deep_learning_LSTM长短期记忆神经网络处理Mnist数据集

    1.RNN(Recurrent Neural Network)循环神经网络模型 详见RNN循环神经网络:https://www.cnblogs.com/pinard/p/6509630.html 2. ...

  8. TensorFlow——LSTM长短期记忆神经网络处理Mnist数据集

    1.RNN(Recurrent Neural Network)循环神经网络模型 详见RNN循环神经网络:https://www.cnblogs.com/pinard/p/6509630.html 2. ...

  9. TensorFlow——CNN卷积神经网络处理Mnist数据集

    CNN卷积神经网络处理Mnist数据集 CNN模型结构: 输入层:Mnist数据集(28*28) 第一层卷积:感受视野5*5,步长为1,卷积核:32个 第一层池化:池化视野2*2,步长为2 第二层卷积 ...

随机推荐

  1. Html5+Css3制作下拉菜单的三种方式

    一.渐变式改变ol的高度 1.外部为ul标签,在每个li里嵌套一个ol列表2.设置外部li左浮动,内部ol标签绝对定位,外部li标签相对定位3.设置ol的高为0,溢出隐藏4.外部li标签:hover ...

  2. jackson-mapper使用工具类

    import com.google.common.collect.Lists;import org.codehaus.jackson.annotate.JsonMethod;import org.co ...

  3. MySql安装出现问题---无服务,修改密码

           之前在项目中一直使用的是SqlServer数据库,现在学习下MySql,下面是学习MySql的学习笔记. MySql简介       MySql是一种关联数据库管理系统(关系型),将数据 ...

  4. 64.SHELL

    SHELL 1. crontab定时器 编辑使用crontab -e 一共6列,分别是:分 时 日 月 周 命令 查看使用crontab -l 删除任务crontab -r 查看crontab执行日志 ...

  5. POJ 3436 ACM Computer Factory (拆点+输出解)

    [题意]每台计算机由P个零件组成,工厂里有n台机器,每台机器针对P个零件有不同的输入输出规格,现在给出每台机器每小时的产量,问如何建立流水线(连接各机器)使得每小时生产的计算机最多. 网络流的建图真的 ...

  6. 第一篇 Rewrite规则简介

    1.Rewirte主要的功能就是实现URL的跳转,它的正则表达式是基于Perl语言.可基于服务器级的(httpd.conf)和目录级的(.htaccess)两种方式.如果要想用到rewrite模块,必 ...

  7. 理解typename的两个含义

    理解typename的两个含义 问题:在下面的 template declarations(模板声明)中 class 和 typename 有什么不同? template<class T> ...

  8. &lbrack;SDOI2010&rsqb;粟粟的书架

    题目大意: 网址:https://daniu.luogu.org/problemnew/show/2468 大意:本题有两问: [1] 给定一个\(R*C\)的带权矩阵,询问\(2×10^5\)次在一 ...

  9. Python的lambda

    if else 可以用简单的三元运算符表示 if 1 == 1: name = 'wupeiqi' else: name = 'alex' --> name = 'wupeiqi' if 1 = ...

  10. 什么是HTTP及RFC

      HTTP:超文本传输协议(HyperText Transfer Protocol),是互联网上应用最为广泛的一种网络协议. 所有的www文件都必须遵守这个标准.设计HTTP最初的目的是为了提供发布 ...