识别基于神经网络的手写数字识别系统的设计与实现毕业论文

手写识别  时间:2021-04-16  阅读:()

中 南 大 学

本科生毕业论文设计题 目 基于神经网络的手写数字

识别系统的设计与实现

目录

摘要. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .Ⅰ

ABSTRACT. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .Ⅱ

第一章绪论. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1

1. 1手写体数字识别研究的发展及研究现状. . . . . . . . . . . . . . . . . . . . . . . . . . . . .1

1.2神经网络在手写体数字识别中的应用. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2

1.3论文结构简介. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3

第二章手写体数字识别. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4

2. 1手写体数字识别的一般方法及难点. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4

2.2图像预处理概述. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5

2.3图像预处理的处理步骤. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5

2.3. 1图像的平滑去噪. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5

2.3.2二值话处理. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6

2.3.3归一化. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .7

2.3.4细化. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .8

2.4小结. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .9

第三章特征提取. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .10

3. 1特征提取的概述. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .10

3.2统计特征. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .10

3.3结构特征. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11

3.3. 1结构特征提取. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11

3.3.2笔划特征的提取. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11

3.3.3数字的特征向量说明. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .12

3.3知识库的建立. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .12

第四章神经网络在数字识别中的应用. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .14

4. 1神经网络简介及其工作原理. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .14

4. 1. 1神经网络概述[14]. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .14

4. 1.2神经网络的工作原理. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .14

4.2神经网络的学习与训练[15]. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .15

4.3 BP神经网络. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .16

4.3. 1 BP算法. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .16

4.3.2 BP网络的一般学习算法. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .16

4.3.3 BP网络的设计. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .18

4.4 BP学习算法的局限性与对策. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .20

4.5对BP算法的改进. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .21

第五章系统的实现与结果分析. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .23

5. 1软件开发平台. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .23

5. 1. 1 MATLAB简介. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .23

5. 1.2 MATLAB的特点. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .23

5. 1.3使用MATLAB的优势. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .23

5.2系统设计思路. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .24

5.3系统流程图. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .24

5.4 MATLAB程序设计. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .24

5.5实验数据及结果分析. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .26

结论. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .27

参考文献. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .28

致谢. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .30

附录. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .31

摘要

手写体数字识别是模式识别中一个非常重要和活跃的研究领域数字识别也不是一项孤立的技术它所涉及的问题是模式识别的其他领域都无法回避的应用上作为一种信息处理手段字符识别有广阔的应用背景和巨大的市场需求。因此对数字识别的研究具有理论和应用的双重意义。

人工神经网络识别方法是近年该研究领域的一种新方法该方法具有一些传统技术所没有的优点 良好的容错能力、分类能力强、并行处理和自学习能力并且是离线训练和在线识别的。这些优点使它在手写体字符的识别中能对大量数据进行快速实时处理并达到良好的识别效果。

由于手写体数字识别难于建立精确的数学模型,所以本文采用BP神经网络对这一问题进行处理。神经网络模式识别的一个关键步骤是预处理和特征提取对于手写体数字识别本文采用了一种基于结构特征和统计特征的提取方法并用程序实现了这一特征提取过程。

通过测试本识别系统对于较规范的手写体数字的识别达到了很好的识别效果。关键词 手写体数字识别特征提取人工神经网络 MATLAB

I

AB STRACT

Handwritten character recognition is a very important and active research in patternrecognition.Theoretically, it is not an isolated technique. It concerns with the problem thatall the other areas of pattern recognition must confronted; practically, being a kind ofinformation processing measured, character recognition has a very broad applicationbackground and vast need of market. Thus, it is of both theoretical and practicals ignificance.

Artificial neural network recognition method is a new method of the research field inrecent years,and this method has some merit that traditional technique do not have;goodtolerance for error, strong sorting ability, strong parallel handling ability and strongself-learning ab ility as well as its o ff-line training and on-line reco gnizing.All these meritscontribute its perfect performance in handling vast data set and handling in timely manner.

It’s difficult to make accurate mathematics model for handwritten numeralrecognition, so BP neural networks is used here.The key steps of neural networks patternrecognition are preprocessing and feature subset selection. In this paper, algorithm offeature subset selection basing on structural characteristics and statistical characteristicshas been adopted in handwritten numeral recognition, and the process of feature subsetselection had been realized in program.

Recognition system in this paper has achieved a good rate of recognition in randomhandwritten numeral b y te st.

Keywo rd: handwritten numeral reco gnition, feature extraction, artificial neural network,MATLAB

I I

基于神经网络的手写数字识别系统的设计与实现 第一章绪论

第一章绪论

1.1手写体数字识别研究的发展及研究现状

模式识别[2]是六十年代初迅速发展起来的一门学科。由于它研究的是如何用机器来实现人(及某些动物)对事物的学习、识别和判断能力因而受到了很多科技领域研究人员的注意成为人工智能研究的一个重要方面。一个模式识别系统的基本职能是对系统所要处理的模式归属于哪一类做出判别从该系统的模式输入到系统做出判别之间主要包括信息检测、预处理、特征提取和分类几大环节。

字符识别是模式识别领域中的一个非常活跃的分支。一方面是由于问题本身的难度使之成为一个极具挑战性的课题另一方面是因为字符识别不是一项孤立的应用技术其中包含的模式识别领域中其他分支都会遇到的一些基本和共性的问题。从50年代开始许多的研究者就在这一研究领域开展了广泛的探索并为模式识别的发展产生了积极的影响。

字符识别从采用的输入设备来分可分为脱机识别又称为光学字符识别Optical Character Recognition,OCR和联机识别脱机字符又分为印刷体和手写字符识别从对书写者要求来分手写字符又分为限制性和非限制性的手写字符识别。在联机手写字符识别中计算机能够通过与计算机相连的手写输入设备获得输入字符笔划的顺序、笔划的方向以及字符的形状所以相对OCR来说它更容易识别一些。但联机字符识别有一个重要的不足就是要求输入者必须在指定的设备上书写然而人们在生活中大部分的书写情况是不满足这一要求的比如人们填写各种表格资料开具支票等。如果需要计算机去认识这些已经成为文字的东西就需要OCR技术。比起联机字符识别来 OCR不要求书写者在特定输入设备上书写它可以与平常一样书写所以OCR的应用更为广泛。OCR所使用的输入设备可以是任何一种图像采集设备如扫描仪、数字相机等。通过使用这类采集设备 OCR系统将书写者已经写好的文字作为图像输入到计算机中然后由计算机去识别。 由于OCR的输入只是简单的一副图像 它就不能像联机输入那样比较容易的从物理上获得字符笔划的顺序信息 因此OCR是一个更具挑战性的问题。

脱机字符识别OCR分为印刷体OCR和手写OCR。印刷体字符比手写体字符少了随机性它的识别相对容易些难点已经不在识别环节而在于字符的分割上。印刷体识别的错误绝大多数都是错误的分割引起的[3] 。对于手写体OCR无论是联机还是脱机识别手写体的识别都要经历由限制性手写体识别到非限制性手写体识别两个阶段。本文将以手写体数字为代表讨论非限制性手写体字符的识别。脱机字符识别的研究最早始于上个世纪六十年代是为了应付汉英翻译的需要。八十年代后的研究重心转移到脱机手写字符的识别上。对于小类别数的字符集如数字、

1

基于神经网络的手写数字识别系统的设计与实现 第一章绪论

字母的识别 已经可以做到对书写不加任何的限制。非限制性手写OCR的研究始终以阿拉伯数字为主导。这事因为第一十个阿拉伯数字是全世界的一套通用字符。第二在数字的许多应用场合如报表、账单、支票等手写体还难以被印刷体所替代而且对识别的可靠性要求极高。三 由于类别数少所以模式识别中的许多方法研究均可以以数字识别作为实验背景。对脱机手写体字符的研究人们由简单集成笔画密度、笔画方向和背景特征方法过渡到特征匹配方法进而过渡到结合神经网络方法随着对识别可靠性要求的提高九十年代以后多分类器集成方法成为了一个研究重点。

1.2神经网络在手写体数字识别中的应用

目前随着计算机的迅速发展性能价格比的不断提高模式识别技术已经从理论探讨为主发展到大量的实际应用人们将更多的注意力开始转向那些用于语音、图像、机器人以及人工智能等的模式识别实际问题。解决这些问题的关键是需要进行复杂而庞大的实时数据处理而现有计算机的存贮容量及计算复杂性的局限使得真正实时化的应用受阻。这种面向实时应用的模式识别问题促使人们开始将并行处理的神经网络[4]应用到模式识别而神经网络模式识别技术又将模式识别实时应用推进了一大步手写体数字识别就是这种应用的一个很重要的领域。

手写体数字识别是一项极具研究价值的课题随着神经网络[1]和模糊逻辑技术的发展人们对这一问题的研究又采用了许多新的方法和手段也使得这一古老的课题焕发出新的生命力[5]。 目前国际上有相当多的学者在研究这一课题它包括了模式识别领域中所有典型的问题:数据的采集、处理及选择、输入样本表达的选择、模式识别分类器的选择以及用样本集对识别器的有指导的训练。人工神经网络为手写体数字识别提供了新的手段。正是神经网络所具有的这种自组织自学习能力、推广能力、非线性和运算高度并行的能力使得模式识别成为目前神经网络最为成功的应用领域。

二十多年来人们在数字识别领域做了大量的研究工作所提出的各种方法在印刷体和手写印刷体数字识别方面已经取得了较好的成绩识别率稳定在96%左右。但是自由手写体数字的识别工作目前并不成熟仍旧是文字识别中最有挑战性的课题之一。

字符识别长期以来都是采用传统的识别方法对印刷体字符的识别率一般只是稳定在96左右不能进一步提高而对手写体字符的识别其研究还处于探索阶段其识别率还相当低 因此为了提高识别率就必须寻求新的方法和途径。

进入九十年代以来人工神经网络ANN技术发展十分迅速它具有模拟人类部分形象思维的能力是一种模仿人脑学习、记忆、推理等认知功能的新方法。

2

基于神经网络的手写数字识别系统的设计与实现 第一章绪论

特别是它的信息并行分布式处理能力和自学习功能等显著优点更是激起了人们对它的极大的兴趣。人工神经网络是由一些类似人脑神经元的简单处理单元相互连接而成的复杂网络。 已涌现出许多不同类型的ANN及相应的学习算法其中BP 或EBP-Error Back Propagation网络及学习算法得到了广泛关注和研究并在数字识别方面取得了许多有意义的应用成果。

1.3论文结构简介

本毕业设计主要解决以图像形式存在的手写体数字识别的问题。整体分为三个部分第一部分是图像预处理第二部分是对手写体数字的结构特征的提取第三部分是设计神经网络并对前面得到的样本数据进行学习和训练。

本文通过图像预处理和数字特征提取以后基于神经网络的判别方法然后结合使用了MATLAB工具箱中提供的人工神经网络函数设计了一种手写数字识别的新方法。实验表明该方法可以获得较好的识别率。

3

基于神经网络的手写数字系统的设计与实现 第二章手写数字识别

第二章手写体数字识别

2.1手写体数字识别的一般方法及难点

字符识别问题的研究已有几十年的历史了但时至今日字符识别的研究成果远未达到人们所期望的这其中有理论研究和技术实现等多方面因素.在理论方面我们对人类的视觉认知机理的研究还只是初步的远未达到深入和透彻的水平。在技术方面我们使用的计算机的运算水平和存储能力 比起人脑的信息存储和处理能力有很大差距. 因此 目前的文字识别只能建立在现有的理论基础上使用现有的技术来研究和解决问题。手写体数字识别是字符识别的一个分支 问题虽然简单但却有较大的实用价值。

数字的类别虽然只有十种笔划又简单其识别问题表面上是一个较简单的分类问题。但实际上虽然各种新的识别算法不断的推出。其识别率和误识率仍距实用有相当距离。手写阿拉伯数字具有变形多差异大的特点字形与书写人的职业、文化程度、书写习惯以及所使用笔墨纸张所处环境等都有关所以手写体数字变形多、规律复杂。具体地说有两个一是09十个数字中其中的一些数字字形相差不大使得准确区分某些数字相当困难;二是数字虽然只有十种但同一数字写法千差万别。不同的人写出的同一个数字都有差别 即使同一个人在不同的时候也会有不同的写法。笔划的书写顺序经常发生变化 因此极大地增加了匹配的难度。一般人写字时都不会一笔一划的书写为了节省时间连笔字是自然而然的事情对于结构识别而言连笔一方面使笔划种类大大增加甚至达到难以归纳的程度另一方面连笔又使得笔段抽取难度大增 因为连笔会增加一些冗余笔段连笔造成的畸变又会使笔段方向严重离散。总之连笔不论对于基于哪种基元的结构识别都是严峻的挑战。这是造成手写数字识别过程复杂、达到较高识别率困难的根本原因。

如图2. 1各种各样的手写体数字。

图2. 1各种各样的手写体数字

4

RAKsmart便宜美国/日本/中国香港VPS主机 低至月$1.99 可安装Windows

RAKsmart 商家这几年还是在做事情的,虽然他们家顺带做的VPS主机并不是主营业务,毕竟当下的基础云服务器竞争过于激烈,他们家主营业务的独立服务器。包括在去年开始有新增多个数据中心独立服务器,包括有10G带宽的不限流量的独立服务器。当然,如果有需要便宜VPS主机的他们家也是有的,比如有最低月付1.99美元的美国VPS主机,而且可选安装Windows系统。这里商家有提供下面六款六月份的活动便宜V...

青果网络618:洛杉矶CN2 GIA/东京CN2套餐年付199元起,国内高防独服套餐66折

青果网络怎么样?青果网络隶属于泉州市青果网络科技有限公司,青果网络商家成立于2015年4月1日,拥有工信部颁发的全网IDC/ISP/IP-VPN资质,是国内为数不多具有IDC/ISP双资质的综合型云计算服务商。青果网络是APNIC和CNNIC地址分配联盟成员,泉州市互联网协会会员单位,信誉非常有保障。目前,青果网络商家正式开启了618云特惠活动,针对国内外机房都有相应的优惠。点击进入:青果网络官方...

艾云年付125元圣何塞GTT,洛杉矶vps年付85元

艾云怎么样?艾云是一家去年年底成立的国人主机商家,商家主要销售基于KVM虚拟架构的VPS服务,机房目前有美国洛杉矶、圣何塞和英国伦敦,目前商家推出了一些年付特价套餐,性价比非常高,洛杉矶套餐低至85元每年,给500M带宽,可解奈飞,另外圣何塞也有特价机器;1核/1G/20G SSD/3T/2.5Gbps,有需要的朋友以入手。点击进入:艾云官方网站艾云vps促销套餐:KVM虚拟架构,自带20G的防御...

手写识别为你推荐
计算机网络实验系统支持ipad支持ipad支持ipad127.0.0.1DNS老是被修改为127.0.0.1,这是为什么?fusionchartsfusioncharts怎么生成图片至excelwin7如何关闭445端口如何关闭445端口,禁用smb协议firefoxflash插件安装火狐浏览器后,老是提示安装flash player?杀毒软件免费下载2013排行榜现在有那些杀毒软件是好用又免费的chrome18请问chrome18怎么关闭硬件加速?
双线虚拟主机 xenvps 最便宜虚拟主机 外贸主机 163网 512au linux空间 架设服务器 国外免费全能空间 静态空间 网络空间租赁 卡巴斯基免费试用 绍兴电信 Updog 架设邮件服务器 酸酸乳 电信宽带测速软件 乐视会员免费领取 中国电信宽带测速 magento主机 更多