毕业论文-基于Matlab的指纹识别
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
毕业论文基于Matlab的指纹识别
姓名
院(系)
专业班级
学号
指导教师
职称
论文答辩日期
学生承诺书
本人郑重声明:所提交的学位论文,全部是本人在指导教师的指导下,和同学们的协助下独立完成的工作研究成果。
文中除了特别标注和致谢的地方外,学位论文中不包含其他人或集体已经发表或撰写过的研究成果。
对本文的研究做出重要贡献的个人和集体,均已在文中以明确方式标明。
本人完全意识到本声明的法律结果由本人承担。
签名:_____________日期:_______________
摘要
随着科学技术的不断发展,自动化的指纹识别技术如今已经被人们广泛地应用在银行、商业交易、公安部门、海关部门等需要对人的身份进识别的领域,而本文所描述的是对自动化指纹识别系统的研究现状以及自动化指纹识别系统的基本算法和流程,本实验是利用MATLAB2012来进行了指纹识别系统的仿真和实验的。
然而在生物识别技术的快速发展的今天,人们通过研究发现了每一个人的指纹都具有唯一性和不变性。
也正因为这样,指纹识别技术正在逐步的发展成为一种新的身份识别技术,并且凭借它良好的安全性以及可靠性,逐步有取代传统身份认证的方式趋势。
本文简单的介绍了指纹识别图像的预处理的方法和步骤。
指纹图像预处理之后将会得到一个宽度为统一像素的细化后的二值化图像,最后再根据特定的指纹图像的端点以及交叉点的特征进行对指纹自动匹配。
本论文中采用MATLAB2012编程实现所有算法。
关键词:指纹识别技术指纹图像预处理指纹识别 MATLAB2012
目录
1 绪论 (1)
1.1 生物特征识别的意义 (1)
1.2 生物特征识别分类 (2)
2 指纹识别的原理和方法 (5)
指纹识别的基本原理 (5)
指纹识别系统工作流程 (5)
指纹识别技术的方法 (7)
神经网络指纹识别算法 (7)
2.3.2 滤波特征和不变矩指纹识别算法 (7)
指纹匹配算法 (9)
3 指纹识别算法的实现 (10)
3.1 指纹图像的预处理 (10)
图像的平滑 (10)
图像的归一化 (12)
图像的纹理方向 (13)
图像的二值化 (15)
纹线细化 (16)
3.2 指纹图像的特征提取和特征匹配 (19)
3.2.1 特征提取 (19)
3.2.2 特征点匹配 (20)
4 系统实现 (22)
仿真实验前期准备 (22)
4.1.1 仿真实验的实验软件 (22)
4.1.2 仿真实验数据的选取 (22)
4.1.3 仿真实验界面的设计 (23)
仿真实验算法 (24)
4.2 指纹图像的预处理 (25)
4.3 实验结果与分析 (31)
4.4 实验结果分析与总结 (40)
5 小结 (41)
参考文献
Abstract
致谢
仲恺农业工程学院毕业论文(设计)成绩评定表
1 绪论
如今,生物特征识别领域中的最为成熟的应用技术之一--指纹识别技术。
其实它已经有非常悠久的历史了。
很久以前,指纹识别技术已经很早就应用于刑事侦查和司法鉴定领域了,很多人不知道的是。
随着计算机网络和信息处理技术的快速发展,这门历史悠久的指纹识别技术也开拓了更多更广阔的市场,自动的指纹识别技术和与其相关的产品越来越多的应用在普通人的生活当中。
1.1 生物特征识别的意义
生物识别技术(Biometric Identification Technology)的定义是:利用人体的不同的生物特征来进行对人的身份进行认证的一种技术[1]。
这是因为人的生物特征是唯一的,可以区分与他人不同的特征。
并且我们还可以通过技术测量或者是自动识别来检验出生理特性以及行为方式,我们所说的这个特征分为生理特征、行为特征。
我们对生物特性来进行提取并放入数据库,再将提取出来的人的唯一特征和它的身份一一对应起来。
典型的生物识别系统的主要所示:
图1.1 生物识别系统主要结构框图
在当今世界的很多计算机系统中,其中包含了很多非常机密非常军方的系统,而这些系统都是简单的使用“账号户名+密码”的方式来进行对用户的身份的认证以及访问的控制。
但事实上,这种设计方案却经常遇到一些很常见的问题。
比如,设置的密码容易被人们忘记,密码太多一时容易混乱,而且与此同时,密码毕竟不会很长很复杂所以也很容易被他人所窃取。
而最重要的一点是,如果用户一时间忘记了当初他设置的密码,他就不能进入系统了,当然忘记密码可以通过身份认证来重新设定密码来恢复工作,但
是这样做很耗费时间,而且身份认证的手续麻烦,条件很多,这会给用户带来很多损失。
很多有关机构通过调查,表明了因为用户忘记密码而产生的一连串问题已经成为阻碍人们生活的一个重要问题。
人们而为了防止这类事件的频繁发生,一种新的身份认证手段便由此而生,这便是“人体的生物特征识别技术”。
它的诞生是因为每一个人自身所具有的生物特征不同,而这种不同恰好可以对每个人的真实身份来进行识别和认证。
然而我们的这些生物特征大部分都具备“人格各异”、“始终不变”和“随时携带”的这三个主要的特点,然而这也确保了我们的生物特征识别技术的精确性以及可靠性。
1.2 生物特征识别分类
目前为止,有很多生物特征识别技术。
但是,它们当中有的已经逐步得到应用和推广,而有的还仅仅处于实验研究的阶段。
(1)虹膜识别
虹膜识别技术:利用人眼虹膜终身不变性,虹膜差异,为人类识别的技术是虹膜识别技术。
虹膜识别技术与其相对应的算法结合之后,可以达到很高的精度。
(2)视网膜识别
视网膜识别技术:是使用激光照射在人的眼球背面,从中获得具有唯一性的视网膜特征来进行身份的识别。
(3)面部识别
面部识别技术:通过对人的面部表情特征,以及这些表情特征之间的相互关系,来进行对比和识别的就是脸部识别。
(4)手写体识别
手写体识别:所谓的手写体识别就是将手写的文字进行数字化的一个过程,通过测量图像本身以及写字的动作,以及在每个字母与字母之间,人们的用不同的速度、写字不同的顺序等来进行识别的,手写体识别和语音识别是一样的,都是一种人体行为测定学。
(5)语音识别
语音识别:语音识别的定义就是通过不断地测量、通过记录出语音的波形和声音的变化特征,再根据现场所采集到的语音样本和登记过的语音模板进行的匹配,最后再通过计算机来进行判断。
语言识别和其他的行为识别技术一样,因为人的语音变化的范围太大,所以有时候而很难进行一些精准的匹配;同时语音还会随着发音的音量、发音的速度和不同的音质变化导致采集到语音会与要对比的模板有不同的结果。
(6)基因识别
DNA基因识别:基因识别是当今世界最准确的生物识别方法之一。
但实现该技术所需的设备非常复杂而且非常昂贵,而且还需要专业的技术人员来进行操作这些设备,而且基因识别所花费的时间会很长,所以DNA基因识别技术到目前为止还不能广泛的应用在日常生活中。
(7)指纹识别
指纹识别技术:对“全局特征”、“局部特征”进行分析的技术就是我们所说的指纹识别技术。
而且我们每一个人的指纹都具有独一无二的特征点,而且这些特征点都是可以测量的。
每一个特征点还会伴随着大概七个左右不同的特征。
可想而知,我们有10个手指,将产生至少4900的独立功能并可以测量的数据。
这将意味:指纹识别技术是一个门可靠的身份识别技术。
根据不同的人的指纹也会有不同,即使是同一个人,也会有不同的指纹。
而且纹线走向、纹线的断点、交叉点的不同更加决定了指纹都具有“唯一”的这种特性,这恰恰就是指纹识别技术的原理。
不仅如此,我们的指纹也是不会随着我们年龄的增长而发生太大的变化,也就是说我们指纹是终生不变的。
利用唯一性和稳定性这个指纹的特性,可以将一个人身份个人信息和他所对应的指纹联系起来。
实现的方法就是:通过对他的指纹样本的预先保存,再和指纹模板进行配对和比较。
再利用计算机对指纹图像进行快速的识别。
这样就能很快的识别出指纹所对应的的人的真实身份了。
从而达到一种身份认证和识别的功能。
常用的几种生物特征识别技术的技术性能比较如表1.1所示:
表1.1 常用生物识别技术比较
由表中很明显得可以知道,指纹识别已经是各种生物特征识别领域中综合性能最好的技术之一。
正因如此,指纹识别技术在当今的身份认证系统中被人们广泛的应用了。
2 指纹识别的原理和方法
指纹识别技术其实是比较复杂的。
自动识别技术与人工识别技术的方式不同,很多掌握生物识别技术的公司并不是直接对指纹图像进行存储的。
而是多年来在各个公司及其研究机构产生了很多数字化的算法。
指纹识别算法最终还是归结在指纹图象上找到并比对指纹的特征。
1.指纹的特征
总体特征和局部特征是我们用来定义指纹和识别指纹的两个重要的特征。
总体特征:那些光靠人的眼睛就可以很直接的区分到的生物特征被我们称为是总体特征。
环型、弓型、螺旋型这都是指纹的总体特征。
而且其他的指纹螺纹图案也都是基于这三种基本的螺纹图案的。
因此,仅仅依靠这三种基本的螺纹图案来区分指纹是远远不够的,但是,这样做只是为了做一个粗略的分类,因为这样就可以大大减少搜索数据库时的工作量。
局部特征:所谓的局部特征就是指纹图像上的节点的特征,这些具有某种特征的节点我们称之为特征点。
我们知道:一般特征,有时两个指纹是相同的,但我们正在谈论的代表局部特征点的特征,这将是不同的。
2.指纹的特征点
我们知道,手指的指纹的纹路并不是连续的,它们有些是打断的,有些是光滑的,有些是弯的,有些是直的,有些是分开的。
而这些指纹的断点、分叉点还有转折点就被我们称作为“特征点”。
正因为有了这些特征点,才保证了我们的指纹是唯一的。
读取采集到指纹图象、提取特征点、保存特征点数据和对特征点数据进行比对是指纹识别技术主要的四个步骤。
首先,指纹要通过指纹采集设备(Fingerprint acquisition device),常见的采集设备有光学取像设备、超声波扫描取像设备、晶体传感器等。
其中,运用的最多的是晶体传感器。
接着,将采集到的指纹图像转换为计算机内可以识别的数字图像就是我们所说的灰度图。
但是,由于我们在采集过程中,难以避免因为手指或者是仪器的原因,导致采集到
图像存在比较多的噪声。
所以,为了使我们采集到的图像变得更清晰,以便于后续特征提取的操作方便,对指纹图像进行增强和滤波处理,处理后的图像再进一步的二值化、细化[5],是我们必须要做的事情。
而这些步骤就被称作是指纹图像的预处理。
然后,在细化后的指纹点线图上提取出我们需要的特征值,删去我们不需要的伪特征值,最终得到我们用进行匹配的细节点。
采集到的图像细节点与模板中的细节点进行比对,最终完成指纹匹配。
本文着重研究了图像预处理和细节特征提取这两个关键部分。
接着,一套用数字类型表示的指纹特征点数据就会录入到计算机指纹识别软件。
这是一种只能由指纹信息转换成特征点数据的单方向的转换数据。
对于不同的两枚指纹,也会产生两组不相同的特征数据。
这就是识别软件的数据点。
它代表的是指纹的纹路上的交叉点、断点或者纹路围圈处的位置坐标信息。
这些数据点就有七种以上对应的的唯一特征。
这些数据,就是模板,被保存为1K大小的记录下来。
最后,把两个指纹的模板进行比较,通过计算机来完成。
再计算出这两个指纹模板的相似程度。
最终根据相似度得到两个指纹的匹配结果。
指纹识别系统框图如图2.1所示。
图2.1 指纹识别系统工作原理框图
本文主要研究了:基于LVQ神经网络的识别算法。
不变矩和滤波特征的指纹识别算法。
指纹点模匹配算法这三种算法。
根据我们已知的三种指纹识别算法,来进行仿真实验,实验通过Matlab2012软件完成,下面分别是这三种算法的优缺点。
选用哪种特征是神经网络识别方法中的关键性问题。
通过分析同种类型的指纹,我们发现了这两组指纹的差别主要体现在它们所对应的每个细节点上。
因此我们就提取了指纹的细节点特征,将这些细节点特征作为识别特征,再将每个样本提取出来的细节点特征,构造成一个80×1维的向量。
这个向量包含了20个特征点,而每个特征点又包含了4维的向量。
矢量化的LVQ神经网络模型是我们对特征点计算的手段。
基于这种方法的聚类特性和自组织特性,所以矢量化的LVQ神经网络模型可以很好地给出特性模式,通过多维空间的概率分布,来估算出指纹的匹配度。
图2.2 基于神经网络的自动指纹识别模型
2.3.2 滤波特征和不变矩指纹识别算法
本文所使用的主要算法是滤波特征和不变矩指纹识别算法。
滤波特征识别算法:大小不变,不变的位置,方向不变,这是特征指纹图像必须满足的三个特点。
大小不变性是很容易满足的。
而在滤波特征提取算法中,位置不变性,
则是通过确定指纹图像的中心点位置来实现的。
通过在匹配阶段,建立起多个角度的旋转特征向量来实现指纹图像的方向不变性。
而滤波特征的提取算法,包括了4 个步骤。
一是先确定指纹图像的中心点。
作为需要处理的指纹区域的中心位置,记为R01 区域;二是以中心位参考点,对R01 区域来进行适当的划分,得到一定大小的块;三是运用一组Gabor 滤波器,对R01 区域做八个不同方向的滤波运算;四是对滤波后的图像,分别计算出每一块中。
图像灰度值相对于均值的平均绝对偏差。
进而得到特征向量或特征编码。
这种指纹识别算法。
首先要对指纹图像提取滤波特征,然后在特征向量上(由滤波特征值构成的)进行匹配。
不变矩识别算法的基本思路是:
1、搜索预处理后的二值化图像中,所有可能成为目标的区域。
2、计算出R01区域中7个不变矩特征,求出与模板匹配程度最高的R01区域进
行匹配。
其中相似度度量采用欧式距离( Euclidean distance)。
这里,搜索算法为系统使用的最简单的顺序查找方法。
就是对数据库文件,逐一搜索。
一张指纹数字图像图片被系统读入时,就会根据上述的方法,先对这一幅指纹数字图像进行特征值提取和编码,并保存到临时变量中去。
系统的指纹数字图像数据库文件里同时也会保存一组指纹数字图像灰度偏差的特征。
过程如下:
1.申请内存空间。
将匹配结果的临时变量进行保存,对输入系统的要匹配的指纹数字图像的编码进行保存。
2. 搜索系统的数据库文件。
当数据库文件为空时,程序结束查找。
3. 当系统的数据库文件不为空时。
由于在指纹数字图像在入库的时候,指纹数字图像是按一定排列顺序的编码。
同样地,系统也将匹配的指纹数字图像的图象编码设置同样的顺序。
这样系统就按照一定得顺序进行匹配。
这样可以通过欧氏距离( E D)匹配算法,来判断两个指纹数字图像之间的欧氏距离。
前面提到系统是对一张指纹数字图像进行两次编码的保存。
将相对应的特征向量进行比较,取其中最小的一个作为系统比对的结果输出。
这里是通过欧式距离来实现的对比数据库中模板图像和待测试图像相对应的特征点向量距离计算的。
对于计算机计算出来的数据,如果匹配指数小于定值 T,则被认为是匹配成功,否则匹配失败。
简单的说,欧氏距离( Euclidean distance)就是将两组特征向量相减,然后求出他们对应之间的差的平方和,然后开根号。
举个例子来说吧:A=(1,2,3)B=(4,5,6)则他们之间的距离就是 d=sqrt((1-4)2+(2-5)2+(3-6)2)。
接着识别系统就逐一搜索数
据库中的数据文件,求的他们距离的最小数值。
如果对比的两张指纹数字图像的特征向量之间的距离是 0,则系统会认为这两张数字图像是同一张,或者说来自于同一手指。
从而达到识别的功能。
欧氏距离表示的是两张指纹数字图像的特征向量的相似程度。
距离越近就越容易相互干扰,误码率也就越高,也就越相似。
指纹匹配算法:是指在调整过程中的指纹特征值。
它要匹配的是指纹图像和预先存储图像特征值。
英国的专家亨利认为,只要13共同特征点存在的两个指纹图像的比例,就可以认为这两个要比较指纹图像是相同的指纹。
下图为指纹匹配算法的流程图。
图2.3 指纹匹配算法的流程图
3 指纹识别算法的实现
3.1 指纹图像的预处理
精确的指纹识别技术是非常依赖于脊的图案信息来识别特征的细节结构的。
然而,在自动指纹识别过程中,由于各种因素的影响手指本身的图像,该指纹传感器采集的原始状态的指纹图像将受到不同程度的干扰,并且图像将通常包含大量的噪音,导致指纹图像质量严重下降。
为了确保指纹图像可以进行有效的匹配过程。
图像预处理是自动指纹识别系统中最重要的一步,图像预处理的好坏会直接影响到指纹识别的好坏。
预处理的目的是为了在图像中除去噪声,使图像变成清晰的线,从而提高了指纹图像可以被识别的有效区域的清晰度,方便指纹特征提取。
而图像的预处理大致可以划分为以下几步:
灰度,平滑滤波,归一化,二值化,细化。
主要流程如下图:
图3.1 预处理主要流程
图像的平滑
指纹图像预处理的过程第一步是对原始指纹图像的灰度图进行平滑处理。
所谓平滑化处理是通过在原始指纹图像滤波和处理选择适当的滤波处理中,图像过滤掉不必要的高频分量。
光滑的主要作用是尽量保持边缘线的图像完好,除去原始指纹图象的离散的,孤立的高对比度的像素。
而在后续的指纹图像处理过程中,这可能会造成的计算与分析误差,但与此同时也可以尽量的消除指纹图像中由于图像噪声的存在导致的纹路中脊线上会出现的很多的微小疵点[26]。
本文是采取直方图均衡化的方法[27]来实现图象的增强。
从原始图像直方图相对浓缩成灰色区中的所有直方图中的均衡处理的均匀灰度范围是中心思想。
对于图像的空间域点增强过程是通过增强函数t=EH(s)来完成的。
t、s分别代表着目标图像和原始图像上的像素点(x,y),在进行均衡化处理时,增强函数EH需要满足两个条件:[28][29]
(1)增强函数在EH(s)在0≤s≤L-1的范围内。
(2)对于0≤s≤L-1应当有0≤EH(s)≤L-1,它保证了在变换过程中灰度值的动态范围是一致的。
同理,对于反变换过程s=EH-1(t),在0≤t≤1时函数也必须满足上述两个条件。
通过该函数可以完成s到t的均匀分布转换。
具体方法是:
(1)给出原始图像所有灰度级别S
k
,k=0,1…,L-1。
(2)统计原始图像各灰度级别的像素数n
k。
(3)计算原始图像的直方图。
用式
P(S
k )= n
k
/n, k=0,1…,L-1 (3-1)
(4)计算原始图像的累计直方图:
t
k = EH(S
k
)=∑(n
i
/n)=∑P
s
(s
i
),(k=0,1,2……L-1)(3-2)
(5)进行取整计算:
t
k =int[(N-1) t
k
+k/N] (3-3)
(6)确定映射关系S
k -t
k。
(7)统计出新的直方图以及各灰度级的像素数n
k。
(8)计算出新的直方图:
P l (t
k
)= n
k
/n (3-4)
上述步骤的求和区间为0- k,根据该方程可以将原图像的各像素灰度值直接转换成直方图。
2012处理后的一幅指纹图像直方图。
分别均衡化前和均衡化后的指纹图像对应的直方图。
结论:通过对比前后的两组图像可以看出,经过均衡化处理之后很多在原始图像中原本看不清的细节也会变得十分清晰。
图像的归一化
为平滑的指纹图像,这样做是为了进行平滑更高的强度分布获得的平均灰度。
从频域分析的角度来看,判断为图像的低频分量的分布。
归一化相应处理程序的数学模型可以用下列公式来描述:
G ij = ()2.2*1j window i window
yx y i window x j window I window ++=-=-+∑∑ (3-5) 公式中,I 是平滑处理后的指纹图像,G 是平滑处理后的灰度分布图。
使用高强度化之后,根据该平均灰度地图进一步计算灰度的像素的平均值,与周围的像素的灰度的变化的平均值平滑处理,从而得到归一化的图像。
该过程可由下列公式来描述:
().255
ij ij ij ij I Min R -= (3-6)
ij ij ij Min I V =- (3-7)
ij ij ij Max I V =+ (3-8)
ij ij ij Max Min =- (3-9)
()2.||
2*1j window
i window yx yx y i window x j window ij I G V window ++=-=--=+∑∑ (3-10)
公式中,平滑后的指纹图像I ,高强度后的灰度分布图G ,指纹灰度变化的梯度分布图V ,归一化后的指纹图像R 。
2012处理后的高强度滤波指纹图像的灰度分布,图3.4所示为归一化处理后的指纹图像。
图3.3高强度滤波后灰度分布图
归一化处理后的图像具有相同的方差,具有相同的背景和前景的色彩,和归一化是不会改变的指纹脊图案信息的图像。
图像的纹理方向
为了方便分析和处理方便,应该以沿指定区域或指定像素为中心,在window 长为半径的参考邻域中,在3600方向上的灰度变化梯度最小的方向定义为该指定区域或指定像素的方向。
在1987年,提出了方向图分解方法。
采用的是以下这个公式来进行表示的:
()1|,(,)|L
m m m d Min C i j C i j ==-∑ (3-11)
而第二种方法则是通过对峰值点来识别纹线的存在性。
这一方法对于清晰的纹线是十分理想的,但对于三角点或者是灰度均匀区域,这种峰值就不明显了。
本文是通过八方向场法来进行计算的
具体步骤是:先用以下所列的公式来分别求出指纹图像中各个像素的灰度变化的梯度值大小在D[0]00(1800)、D[1]450 (2250)、D[2]900 (2700)、D[3]1350 (3150)八个方向上的分量:
111111111111||||||||.||||||||yx yx yx yx j window i window y x yx y x yx ij y i window x j window y x yx y x yx y x yx y x yx I I I I I I I I D I I I I I I I I -+++--++=-=--+-++--+-⎛⎫ ⎪-+- ⎪= ⎪-+- ⎪ ⎪-+-⎝⎭
∑∑ (3-12) 式中,I 表示的是指纹图像,window 是参考邻与的窗口值。
将灰度变化的梯度值在00(1800)方向上的分量变化计作:dh[0]=d[0]
将灰度变化的梯度值在450 (2250) 方向上的分量变化计作:2
将灰度变化的梯度值在900 (2700) 方向上的分量变化计作:dh[2]=d[2]
灰度变化的梯度值在1350 (3150) 方向上的分量变化计作:2。