ImageVerifierCode 换一换
格式:DOC , 页数:31 ,大小:2.47MB ,
资源ID:2474999      下载积分:12 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/2474999.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(数字图像处理车牌识别课程设计matlab实现附源代码.doc)为本站上传会员【a199****6536】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

数字图像处理车牌识别课程设计matlab实现附源代码.doc

1、数字图像处理车牌识别课程设计matlab实现附源代码 ———————————————————————————————— 作者: ———————————————————————————————— 日期: 2 个人收集整理 勿做商业用途

2、 精品实验项目 字符识别预处理的设计与实现 专 业:电子信息工程 姓 名: 高 勇 学 号:2010021204 指导老师:郑蕊蕊 目录 一、 实验类型:设计性实验 3 二、 实验目的 3 三、 实验设备: 扫描仪、安装有MATLAB软件的计算机 3 四、 实验内容及原理 3 (1)字符图像的获取 3 (2)字符图像预处理 3 (3

3、字符图像分割 3 (4)函数的作用 4 五、 实验步骤 8 1.载入车牌图像: 8 2。将彩图转换为灰度图并绘制直方图: 9 3。 用roberts算子进行边缘检测: 10 4.图像实施腐蚀操作: 10 5。平滑图像 11 6. 删除二值图像的小对象 12 7.车牌定位 12 8.字符分割与识别 14 9。车牌识别: 20 六、 思考题 27 一、 实验类型:设计性实验 二、 实验目的 1. 掌握图像的获取、预处理和分割的原理及MATLAB实现方法. 2. 掌握使用扫描仪和计算机获取数字图像的方法,理解扫描仪的原理。 3. 自学一种字符图像

4、的分割算法并用MATLAB编程实现该算法。 三、 实验设备: 扫描仪、安装有MATLAB软件的计算机 四、 实验内容及原理 (1)字符图像的获取 用扫描仪获取图像是字符图像处理常用的数字化过程的方法之一.以办公设备中常用的台式扫描仪为例,其主要性能指标有x、y方向的分辨率、色彩分辨率(色彩位数)、扫描幅面和接口方式等,这些指标都可以从扫描仪的说明手册中获得。分辨率的单位是dpi(Dot Per Inch),意思是每英寸的像素点数。 扫描仪工作时,首先由可移动带状光源将光线照在欲输入的图稿上,并沿y方向扫描稿件,产生表示图像特征的反射光或透射光.照射到原稿上的光线经反射后穿过一个很窄的

5、缝隙,形成沿x方向的光带,经光学系统采集和过滤成RGB三色光带分别照射到RGB分量的CCD上,CCD将光信号转换为模拟电信号。内部电路的A/D变换器将模拟电信号转变为数字电子信号输送给计算机.将稿件全部扫描一遍,一幅完整的图像就输入到计算机中去了。 (2)字符图像预处理 根据扫描仪扫描的文档实际情况,有选择地用MATLAB编程实现字符图像倾斜校正、滤波、灰度化、二值化和归一化等图像预处理。根据具体需要,还可进行图像的正交变换、边缘提取、形态学和图像细化等操作. (3)字符图像分割 通过查找资料,自学字符图像分割的常用算法,根据原始扫描图像的实际情况,设计一种字符图像分割的方法并用MAT

6、LAB编程实现,并绘制流程图。 字符分割 车辆 输出车牌号码 字符识别 车牌的定位 图像预处理 图像采集 图1 流程图 (4)函数的作用 1。Imerode 功能:对图像实现腐蚀操作,即膨胀操作的反操作. 用法:IM2 = imerode(IM,SE) IM2 = imerode(IM,NHOOD) IM2 = imerode(IM,SE,PACKOPT,M) IM2 = imerode(...,PADOPT) IM2 = imerode(IM,SE) 腐蚀灰度,二值,压缩二值图像IM,返回IM2.参数SE为由strel函数返回的结构

7、元素或者结构元素对象组. IM2 = imerode(IM,NHOOD)腐蚀图像IM,这里NHOOD是定义结构元素邻域0和1的矩阵。 IM2 = imerode(...,PADOPT)指出输出图像的大小(是否与输入图像大小一致)。 2。imdilate 功能:对图像实现膨胀操作。 用法:IM2 = imdilate(IM,SE) IM2 = imdilate(IM,NHOOD) IM2 = imdilate(IM,SE,PACKOPT) IM2 = imdilate(.。.,PADOPT) IM2 = imdilate(IM,SE) 膨胀灰度,二值,压缩二值图像IM,返回IM

8、2。参数SE为由strel函数返回的结构元素或者结构元素对象组。 IM2 = imdilate(IM,NHOOD)膨胀图像IM,这里NHOOD是定义结构元素邻域0和1的矩阵. IM2 = imdilate(IM,SE,PACKOPT)定义IM是否是一个压缩的二值图像。 IM2 = imdilate(。..,PADOPT)指出输出图像的大小。 3.strel 功能:用于膨胀腐蚀及开闭运算等操作的结构元素对象(本论坛随即对膨胀腐蚀等操作进行讲解)。 用法:SE = strel(shape,parameters) 创建由指定形状shape对应的结构元素.其中shape的种类有 ‘ar

9、bitrary’,’pair’,'diamond’,’periodicline’,’disk',’rectangle' ’line','square’,'octagon 参数parameters一般控制SE的大小. 4.edge BW = edge(I) 采用灰度或一个二值化图像I作为它的输入,并返回一个与I相同大小的二值化图像BW,在函数检测到边缘的地方为1,其他地方为0。 BW = edge(I,’sobel’) 自动选择阈值用Sobel算子进行边缘检测。 BW = edge(I,'sobel',thresh) 根据所指定的敏感度阈值thresh,用Sobel算子进

10、行边缘检测,它忽略了所有小于阈值的边缘.当thresh为空时,自动选择阈值。 BW = edge(I,’sobel’,thresh,direction) 根据所指定的敏感度阈值thresh,在所指定的方向direction上,用Sobel 算子进行边缘检测。Direction可取的字符串值为horizontal(水平方向)、vertical(垂直方向)或both(两个方向)。 [BW,thresh] = edge(I,'sobel’,..。) 返回阈值 BW = edge(I,'prewitt') 自动选择阈值用prewitt算子进行边缘检测。 BW = edge(I,

11、’prewitt',thresh) 根据所指定的敏感度阈值thresh,用prewitt算子进行边缘检测,它忽略了所有小于阈值的边缘。当thresh为空时,自动选择阈值. BW = edge(I,'prewitt’,thresh,direction) 根据所指定的敏感度阈值thresh,在所指定的方向direction上,用prewitt算子进行边缘检测。Direction可取的字符串值为horizontal(水平方向)、vertical(垂直方向)或both(两个方向)默认方向为both。 BW = edge(I,'roberts') 自动选择阈值用roberts算子进行边缘检测。

12、 BW = edge(I,’roberts',thresh) 根据所指定的敏感度阈值thresh,用Roberts算子进行边缘检测,它忽略了所有小于阈值的边缘。当thresh为空时,自动选择阈值。 本文为互联网收集,请勿用作商业用途文档为个人收集整理,来源于网络 5。Imclose 功能:对图像实现闭运算,闭运算也能平滑图像的轮廓,但与开运算相反,它一般融合窄的缺口和细长的弯口,去掉小洞,填补轮廓上的缝隙。 用法:IM2 = imclose(IM,SE) IM2 = imclose(IM,NHOOD) 用法和imopen相同。 6.imopen 功能:对图像实现开运算,开运算一

13、般能平滑图像的轮廓,消弱狭窄的部分,去掉细的突出。 用法:IM2 = imopen(IM,SE) IM2 = imopen(IM,NHOOD) IM2 = imopen(IM,SE)用 结构元素SE实现灰度图像或二值图像的IM的形态开运算。SE可以是单个结构元素对象或者结构元素对象数组。 IM2 = imopen(IM,NHOOD)用结构元素strel(NHOOD)执行开运算. 7。bwareaopen 功能:删除小面积对象 格式: BW2 = bwareaopen(BW,P,conn) 作用: 删除二值图像BW中面积小于P的对象,默认情况下conn使用8邻域. 8.t

14、ic和toc函数 这两个函数一般配合使用,tic表示计时的开始,toc表示计时的结束. 格式如: tic 任意表达式 toc t=toc 9.fspecial 功能:用于建立预定义的滤波算子,其语法格式为: h = fspecial(type) h = fspecial(type,para) 其中type指定算子的类型,para指定相应的参数; type的类型有: 1、’average’ averaging filter 为均值滤波,参数为hsize代表模板尺寸,默认值为【3,3】. ’disk’ circular averaging filter 为圆形区

15、域均值滤波,参数为radius代表区域半径,默认值为5. 'gaussian' Gaussian lowpass filter 为高斯低通滤波,有两个参数,hsize表示模板尺寸,默认值为【3 3】,sigma为滤波器的标准值,单位为像素,默认值为0.5. ’prewitt’ Prewitt horizontal edge-emphasizing filter 用于边缘增强,大小为【3 3】,无参数 'sobel' Sobel horizontal edge—emphasizing filter 用于边缘提取,无参数 9。 filter2 J = filter2(h,I)

16、使用指定的滤波器h对I进行滤波,结果保存在J中 10。bwarea 函数功能:计算二值图像中对象的总面积. 调用格式: total = bwarea(BW) 估算二值图像BW中对象的总面积。 返回的total是一个标量, 它的值大致地反映了和图像中on像素的个数。由于对于不同像素类型, 度量标准不同, 因此结果可能并不十分精确。BW可以是数值类型(整型、浮点型)或者逻辑类型。对于数值类型, 像素值不为0被视为on.返回值total是double类型的。 11。sum 功能:函数求和 sum(x,2)表示矩阵x的横向相加,求每行的和,结果是列向量。 而缺省的sum(x)就是竖

17、向相加,求每列的和,结果是行向量。 A〉0的结果是得到一个逻辑矩阵,大小跟原来的A一致, A中大于零的元素的位置置为1,小于等于零的位置置为0。 所以横向求和以后,就是求A中每行大于零的元素个数。 12。 round 功能:四舍五入 调用格式:Y = round(X) 在matlab中round也是一个四舍五入函数。 五、 实验步骤 1。载入车牌图像: I=imread(’car1。jpg'); figure(1),imshow(I);title(’original image’);%将车牌的原图显示出来,结果如下: 2.将彩图转换为灰度图并绘制直方图: I1=

18、rgb2gray(I);%将彩图转换为灰度图 figure(2),subplot(1,2,1),imshow(I1);title('gray image'); figure(2),subplot(1,2,2),imhist(I1);title('灰度图直方图’);%绘制灰度图的直方图 结果如下所示: 3。 用roberts算子进行边缘检测: I2=edge(I1,'roberts',0。18,’both');%选择阈值0.18,用roberts算子进行边缘检测 figure(3),imshow(I2);title(’roberts operator edge detection

19、 image'); 结果如下: 4.图像实施腐蚀操作: se=[1;1;1]; I3=imerode(I2,se);%对图像实施腐蚀操作,即膨胀的反操作 figure(4),imshow(I3);title(’corrosion image'); 5。平滑图像 se=strel(’rectangle',[25,25]);%构造结构元素以正方形构造一个se I4=imclose(I3,se);% 图像聚类、填充图像 figure(5),imshow(I4);title(’smothing image'); 结果如下所示: 6。 删除二值图像的小对象 I

20、5=bwareaopen(I4,2000);% 去除聚团灰度值小于2000的部分 figure(6),imshow(I5);title(’remove the small objects’); %用imshow函数显示滤波后图像 结果如下所示 : 7.车牌定位 [y,x,z]=size(I5);%返回I5各维的尺寸,存储在x,y,z中 myI=double(I5);%将I5转换成双精度 tic %tic表示计时的开始,toc表示计时的结束 Blue_y=zeros(y,1);%产生一个y*1的零阵 for i=1:y for j=1:x

21、 if(myI(i,j,1)==1) %如果myI(i,j,1)即myI的图像中坐标为(i,j)的点值为1,即该点为车牌背景颜色蓝色 %则Blue_y(i,1)的值加1 Blue_y(i,1)= Blue_y(i,1)+1;%蓝色像素点统计 end end end [temp MaxY]=max(Blue_y);%Y方向车牌区域确定 %temp为向量yellow_y的元素中的最大值,MaxY为该值的索引 PY1=MaxY; while ((Blue_y(

22、PY1,1)>=5)&&(PY1>1)) PY1=PY1-1; end PY2=MaxY; while ((Blue_y(PY2,1)〉=5)&&(PY2〈y)) PY2=PY2+1; end IY=I(PY1:PY2,:,:); %行方向车牌区域确定 %%%%%% X方向 %%%%%%%%% Blue_x=zeros(1,x);%进一步确定x方向的车牌区域 for j=1:x for i=PY1:PY2 if(myI(i,j,1)==1) B

23、lue_x(1,j)= Blue_x(1,j)+1; end end end PX1=1; while ((Blue_x(1,PX1)〈3)&&(PX1PX1)) PX2=PX2—1; end PX1=PX1—1;%对车牌区域的校正 PX2=PX2+1; dw=I(PY1:PY2—8,PX1:PX2,:)

24、 t=toc; figure(7),subplot(1,2,1),imshow(IY),title(’Line direction areas');%行方向车牌区域确定 figure(7),subplot(1,2,2),imshow(dw),title(’positioning color images');%定位后的车牌区域如下所示: 8.字符分割与识别 1) 车牌的进一步处理 对分割出的彩色车牌图像进行灰度转换、二值化、均值滤波、腐蚀膨胀以及字符分割以从车牌图像中分离出组成车牌号码的单个字符图像,对分割出来的字符进行预处理(二值化、归一化),然后分析提取,对分割出的

25、字符图像进行识别给出文本形式的车牌号码。代码如下: imwrite(dw,’dw。jpg');%将彩色车牌写入dw文件中 a=imread('dw.jpg');%读取车牌文件中的数据 b=rgb2gray(a);%将车牌图像转换为灰度图 imwrite(b,’gray licence plate.jpg');%将灰度图像写入文件中 figure(8);subplot(3,2,1),imshow(b),title(’车牌灰度图像') g_max=double(max(max(b))); g_min=double(min(min(b))); T=round(g_max-(g_max

26、—g_min)/3); % T 为二值化的阈值 [m,n]=size(b); d=(double(b)〉=T); % d:二值图像 imwrite(d,’binary licence plate.jpg’); subplot(3,2,2),imshow(d),title(’before filtering binary licence plate') %均值滤波前 % 滤波 h=fspecial(’average',3); %建立预定义的滤波算子,average为均值滤波,模板的尺寸为3*3 d=im2bw(round(filter2(h,d)));%使用指定的滤波器h对h

27、进行d即均值滤波 imwrite(d,’after average licence plate。jpg'); subplot(3,2,3),imshow(d),title('after average licence plate’) % 某些图像进行操作 % 膨胀或腐蚀 % se=strel(’square’,3); % 使用一个3X3的正方形结果元素对象对创建的图像进行膨胀 % ’line'/'diamond’/’ball’。.。 se=eye(2); % eye(n) returns the n-by-n identity matrix 单位矩阵 [m,n]=size(d

28、返回矩阵b的尺寸信息, 并存储在m,n中 if bwarea(d)/m/n>=0。365 %计算二值图像中对象的总面积与整个面积的比是否大于0.365 d=imerode(d,se);%如果大于0。365则图像进行腐蚀 elseif bwarea(d)/m/n〈=0.235 %计算二值图像中对象的总面积与整个面积的比是否小于0.235 d=imdilate(d,se);%如果小于则实现膨胀操作 end imwrite(d,’expansion or corrosion the licence plate.jpg’); subplot(3,2,4),imsho

29、w(d),title('expansion or corrosion the licence plate'); 运行结果如下所示: 2) 字符分割 在汽车牌照自动识别过程中,字符分割有承前启后的作用.它在前期牌照定位的基础上进行字符的分割,然后再利用分割的结果进行字符识别。字符识别的算法很多,因为车牌字符间间隔较大,不会出现字符粘连情况,所以此处采用的方法为寻找连续有文字的块,若长度大于某阈值,则认为该块有两个字符组成,需要分割.一般分割出来的字符要进行进一步的处理,以满足下一步字符识别的需要.但是对于车牌的识别,并不需要太多的处理就已经可以达到正确识别的目的。在此只进行了归一化处理

30、然后进行后期处理。 % 寻找连续有文字的块,若长度大于某阈值,则认为该块有两个字符组成,需要分割 %首先创建子函数qiege与getword,而后调用子程序,将车牌的字符分割开并且进行归一化处理 d=qiege(d); [m,n]=size(d); subplot(3,2,5),imshow(d),title(n) k1=1;k2=1;s=sum(d);j=1; while j~=n while s(j)==0 j=j+1; end k1=j; while s(j)~=0 && j<=n-1 j=j+1

31、 end k2=j—1; if k2-k1>=round(n/6.5) [val,num]=min(sum(d(:,[k1+5:k2—5]))); d(:,k1+num+5)=0; % 分割 end end % 再切割 d=qiege(d); % 切割出 7 个字符 y1=10;y2=0.25;flag=0;word1=[]; while flag==0 [m,n]=size(d); left=1;wide=0; while sum(d(:,wide+1))~=0

32、 wide=wide+1; end if wide

33、/all〉y2 flag=1;word1=temp; % WORD 1 end d(:,[1:wide])=0;d=qiege(d); end end % 分割出第二个字符 [word2,d]=getword(d); % 分割出第三个字符 [word3,d]=getword(d); % 分割出第四个字符 [word4,d]=getword(d); % 分割出第五个字符 [word5,d]=getword(d); % 分割出第六个字符 [word6,d]=getword(d); % 分割出第七个字

34、符 [word7,d]=getword(d); figure(9); subplot(2,7,1),imshow(word1),title('1’); subplot(2,7,2),imshow(word2),title('2’); subplot(2,7,3),imshow(word3),title('3’); subplot(2,7,4),imshow(word4),title('4'); subplot(2,7,5),imshow(word5),title('5'); subplot(2,7,6),imshow(word6),title(’6'); subplot(2,

35、7,7),imshow(word7),title(’7’); [m,n]=size(word1); % 商用系统程序中归一化大小为 40*20,此处演示 word1=imresize(word1,[40 20]); word2=imresize(word2,[40 20]); word3=imresize(word3,[40 20]); word4=imresize(word4,[40 20]); word5=imresize(word5,[40 20]); word6=imresize(word6,[40 20]); word7=imresize(word7,[40 20]

36、 subplot(2,7,8),imshow(word1),title(’1’); subplot(2,7,9),imshow(word2),title(’2’); subplot(2,7,10),imshow(word3),title('3'); subplot(2,7,11),imshow(word4),title(’4’); subplot(2,7,12),imshow(word5),title(’5’); subplot(2,7,13),imshow(word6),title(’6’); subplot(2,7,14),imshow(word7),title('7

37、’); imwrite(word1,'1.jpg’); imwrite(word2,’2。jpg’); imwrite(word3,'3。jpg’); imwrite(word4,'4。jpg'); imwrite(word5,’5.jpg'); imwrite(word6,’6.jpg'); imwrite(word7,'7。jpg'); 运行结果如下: 9.车牌识别: 模板匹配是图象识别方法中最具代表性的基本方法之一,它是将从待识别的图象或图象区域f(i,j)中提取的若干特征量与模板T(i,j)相应的特征量逐个进行比较,计算它们之间规格化的互相关量,其中互相关量最大

38、的一个就表示期间相似程度最高,可将图象归于相应的类。也可以计算图象与模板特征量之间的距离,用最小距离法判定所属类。 此处采用相减的方法来求得字符与模板中哪一个字符最相似,然后找到相似度最大的输出。汽车牌照的字符一般有七个,大部分车牌第一位是汉字,通常代表车辆所属省份,紧接其后的为字母与数字。车牌字符识别与一般文字识别在于它的字符数有限,汉字共约50多个,大写英文字母26个,数字10个。为了实验方便,结合本次设计所选汽车牌照的特点,只建立了7个数字26个字母与10个数字的模板。其他模板设计的方法与此相同. 首先取字符模板,接着依次取待识别字符与模板进行匹配,将其与模板字符相减,得到的0越多那

39、么就越匹配。把每一幅相减后的图的0值个数保存,即为识别出来的结果。 识别的流程图如下所示: 建立自动识别的代码表 读取分割出来的字符 第一个字符与模板中的汉字模板进行匹配 第二个字符与模板中的字母模板进行匹配 待识别字符与模板字符相减,值越小相似度越大,找到最小的一个即为匹配的最好的 识别完成,输出此模板对应值 后5个字符与模板中的字母与数字模板进行匹配 源代码如下: liccode=char([’0’:’9’ 'A':’Z' ’苏豫陕鲁京辽浙']); %建立自动识别字符代码表 SubBw2=zeros(40,20); l=1; for I=1:7

40、 ii=int2str(I); t=imread([ii,’。jpg']); SegBw2=imresize(t,[40 20],’nearest’); SegBw2=double(SegBw2)〉20; if l==1 %第一位汉字识别 kmin=37; kmax=43; elseif l==2 %第二位 A~Z 字母识别 kmin=11; kmax=3

41、6; else l〉=3 %第三位以后是字母或数字识别 kmin=1; kmax=36; end for k2=kmin:kmax fname=strcat(’字符模板\',liccode(k2),’.jpg'); SamBw2 = imread(fname); SamBw2=double(SamBw2)>1; for

42、 i=1:40 for j=1:20 SubBw2(i,j)=SegBw2(i,j)-SamBw2(i,j); end end % 以上相当于两幅图相减得到第三幅图 Dmax=0; for k1=1:40 for l1=1:20 if ( SubBw2(k1,l1) > 0 | SubBw2(k1,l1) <

43、0 ) Dmax=Dmax+1; end end end Error(k2)=Dmax; end Error1=Error(kmin:kmax); MinError=min(Error1); findc=find(Error1==MinError); Code(l*2—1)=liccode(findc(1)+kmin-1);

44、 Code(l*2)=’ ’; l=l+1; end figure(10),imshow(dw),title ([’车牌号码:’, Code],'Color',’b'); 通过以上的方法,我对另外一幅图像进行了检测,也有较好的识别效果。下面是对另一幅车牌照的检测,结果如下所示: 六、 思考题 1。扫描仪是图像信号输入设备。它对原稿进行光学扫描,然后将光学图像传送到光电转换器中变为模拟电信号,又将模拟电信号变换成为数字电信号,最后通过计算机接口送至个人收集整理,勿做商业用途文档为个人收集整理,来源于网络 计算机中。在扫描仪获取图像的过程中,有两个元件起到关键作用.一个是CCD,它光 信号转换成为电信号;另一个是A/D变换器,它将模拟电信号变为数字电信号。 2。在字符图像预处理中采用了字符图像倾斜校正、滤波、灰度化、二值化和归一化等图像预处理方法. 3。字符分割的方法有python 、vb、javascript、asp :split php是explode。 31

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服