![基于Matlab的車牌識別(完整版)(共25頁)_第1頁](http://file4.renrendoc.com/view/29e29038829eb0937789700959c17fc7/29e29038829eb0937789700959c17fc71.gif)
![基于Matlab的車牌識別(完整版)(共25頁)_第2頁](http://file4.renrendoc.com/view/29e29038829eb0937789700959c17fc7/29e29038829eb0937789700959c17fc72.gif)
![基于Matlab的車牌識別(完整版)(共25頁)_第3頁](http://file4.renrendoc.com/view/29e29038829eb0937789700959c17fc7/29e29038829eb0937789700959c17fc73.gif)
![基于Matlab的車牌識別(完整版)(共25頁)_第4頁](http://file4.renrendoc.com/view/29e29038829eb0937789700959c17fc7/29e29038829eb0937789700959c17fc74.gif)
![基于Matlab的車牌識別(完整版)(共25頁)_第5頁](http://file4.renrendoc.com/view/29e29038829eb0937789700959c17fc7/29e29038829eb0937789700959c17fc75.gif)
版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、基于(jy)Matlab的車牌識別(shbi) 摘要(zhiyo):車牌識別技術是智能交通系統(tǒng)的重要組成部分,在近年來得到了很大的發(fā)展。本文從預處理、邊緣檢測、車牌定位、字符分割、字符識別五個方面,具體介紹了車牌自動識別的原理。并用MATLAB軟件編程來實現(xiàn)每一個部分,最后識別出汽車車牌。 一、設計原理車輛車牌識別系統(tǒng)的基本工作原理為:將攝像頭拍攝到的包含車輛車牌的圖像通過視頻卡輸入到計算機中進行預處理,再由檢索模塊對車牌進行搜索、檢測、定位,并分割出包含車牌字符的矩形區(qū)域,然后對車牌字符進行二值化并將其分割為單個字符,然后輸入JPEG或BMP格式的數(shù)字,輸出則為車牌號碼的數(shù)字。車牌自動識別是
2、一項利用車輛的動態(tài)視頻或靜態(tài)圖像進行車牌號碼、車牌顏色自動識別的模式識別技術。其硬件基礎一般包括觸發(fā)設備、攝像設備、照明設備、圖像采集設備、識別車牌號碼的處理機等,其軟件核心包括車牌定位算法、車牌字符分割算法和光學字符識別算法等。某些車牌識別系統(tǒng)還具有通過視頻圖像判斷車輛駛?cè)胍曇暗墓δ芊Q之為視頻車輛檢測。一個完整的車牌識別系統(tǒng)應包括車輛檢測、圖像采集、車牌識別等幾部分。當車輛檢測部分檢測到車輛到達時觸發(fā)圖像采集單元,采集當前的視頻圖像。車牌識別單元對圖像進行處理,定位出車牌位置,再將車牌中的字符分割出來進行識別,然后組成車牌號碼輸出。 二、設計(shj)步驟總體(zngt)步驟為:車輛(chl
3、ing)圖像采集圖像預處理車牌定位字符分割字符定位輸出結(jié)果基本的步驟:a.車牌定位,定位圖片中的車牌位置;b.車牌字符分割,把車牌中的字符分割出來;c.車牌字符識別,把分割好的字符進行識別,最終組成車牌號碼。車牌識別過程中,車牌顏色的識別依據(jù)算法不同,可能在上述不同步驟實現(xiàn),通常與車牌識別互相配合、互相驗證。(1)車牌定位:自然環(huán)境下,汽車圖像背景復雜、光照不均勻,如何在自然背景中準確地確定車牌區(qū)域是整個識別過程的關鍵。首先對采集到的視頻圖像進行大范圍相關搜索,找到符合汽車車牌特征的若干區(qū)域作為候選區(qū),然后對這些侯選區(qū)域做進一步分析、評判,最后選定一個最佳的區(qū)域作為車牌區(qū)域,并將其從圖象中分割
4、出來。車牌定位 對圖像開閉運算邊緣提取圖像預處理增強效果圖像導入原始圖像流程圖: (2)車牌字符分割 :完成(wn chng)車牌區(qū)域(qy)的定位后,再將車牌區(qū)域分割成單個字符,然后進行識別。字符分割一般采用垂直(chuzh)投影法。由于字符在垂直方向上的投影必然在字符間或字符內(nèi)的間隙處取得局部最小值的附近,并且這個位置應滿足車牌的字符書寫格式、字符、尺寸限制和一些其他條件。利用垂直投影法對復雜環(huán)境下的汽車圖像中的字符分割有較好的效果。流程圖:按左右寬度切割出字符分析垂直投影找到每個字符中心位置計算水平投影進行車牌水平校正去掉車牌的框架 (3)車牌字符識別 :字符依次分析顯示誤差最小的圖片名
5、字分析之差最小的圖片是哪張與數(shù)據(jù)庫的圖片相減切割出的字符送入庫中字符識別方法目前主要有基于模板匹配算法和基于人工神經(jīng)網(wǎng)絡算法?;谀0迤ヅ渌惴ㄊ紫葘⒎指詈蟮淖址祷?并將其尺寸大小縮放為字符數(shù)據(jù)庫中模板的大小,然后與所有的模板進行匹配,最后選最佳匹配作為結(jié)果?;谌斯ど窠?jīng)元網(wǎng)絡的算法有兩種:一種是先對待識別字符進行特征提取,然后用所獲得特征來訓練神經(jīng)網(wǎng)絡分配器;另一種方法是直接把待處理圖像輸入網(wǎng)絡,由網(wǎng)絡自動實現(xiàn)特征提取直至識別出結(jié)果。實際應用中,車牌識別系統(tǒng)的識別率與車牌質(zhì)量和拍攝質(zhì)量密切相關。車牌質(zhì)量會受到各種因素的影響,如生銹、污損、油漆剝落、字體褪色、車牌被遮擋、車牌傾斜、高亮反光、
6、多車牌、假車牌等等;實際拍攝過程也會受到環(huán)境亮度、拍攝亮度、車輛速度等等因素的影響。這些影響因素不同程度上降低了車牌識別的識別率,也正是車牌識別系統(tǒng)的困難和挑戰(zhàn)所在。為了提高識別率,除了不斷的完善識別算法,還應該想辦法克服各種光照條件,使采集到的圖像最利于識別。字符依次分析顯示誤差最小的圖片名字分析之差最小的圖片是哪張與數(shù)據(jù)庫的圖片相減切割出的字符送入庫中流程圖: 三 各模塊(m kui)的實現(xiàn):3.1輸入待處理的原始(yunsh)圖像:clear ;close all;%Step1 獲取(huq)圖像 裝入待處理彩色圖像并顯示原始圖像Scolor = imread(3.jpg);%imrea
7、d函數(shù)讀取圖像文件圖3.1原始圖像3.2圖像的灰度化:彩色圖像包含著大量的顏色信息,不但在存儲上開銷很大,而且在處理上也會降低系統(tǒng)的執(zhí)行速度,因此在對圖像進行識別等處理中經(jīng)常將彩色圖像轉(zhuǎn)變?yōu)榛叶葓D像,以加快處理速度。由彩色轉(zhuǎn)換為灰度的過程叫做灰度化處理。選擇的標準是經(jīng)過灰度變換后,像素的動態(tài)范圍增加,圖像的對比度擴展,使圖像變得更加清晰、細膩、容易識別。%將彩色圖像轉(zhuǎn)換為黑白并顯示Sgray = rgb2gray(Scolor);%rgb2gray轉(zhuǎn)換成灰度圖figure,imshow(Sgray),title(原始(yunsh)黑白圖像);圖3.2原始(yunsh)黑白圖像3.3對原始圖像進
8、行開操作(cozu)得到圖像背景圖像:s=strel(disk,13);%strei函數(shù)Bgray=imopen(Sgray,s);%打開sgray s圖像figure,imshow(Bgray);title(背景圖像);%輸出背景圖像圖3.3背景圖像3.4灰度圖像與背景(bijng)圖像作減法,對圖像進行(jnxng)增強處理:Egray=imsubtract(Sgray,Bgray);%兩幅圖相減figure,imshow(Egray);title(增強(zngqing)黑白圖像);%輸出黑白圖像圖3.4黑白圖像3.5取得最佳閾值,將圖像二值化:二值圖像是指整幅圖像畫面內(nèi)僅黑、白二值的圖像
9、。在實際的車牌處理系統(tǒng)中,進行圖像二值變換的關鍵是要確定合適的閥值,使得字符與背景能夠分割開來,二值變換的結(jié)果圖像必須要具備良好的保形性,不丟掉有用的形狀信息,不會產(chǎn)生額外的空缺等等。車牌識別系統(tǒng)要求處理的速度高、成本低、信息量大,采用二值圖像進行處理,能大大地提高處理效率。閾值處理的操作過程是先由用戶指定或通過算法生成一個閾值,如果圖像中某中像素的灰度值小于該閾值,則將該像素的灰度值設置為0或255,否則灰度值設置為255或0。fmax1=double(max(max(Egray);%egray的最大值并輸出雙精度型fmin1=double(min(min(Egray);%egray的最小值
10、并輸出雙精度型level=(fmax1-(fmax1-fmin1)/3)/255;%獲得最佳閾值bw22=im2bw(Egray,level);%轉(zhuǎn)換圖像為二進制圖像bw2=double(bw22);figure,imshow(bw2);title(圖像二值化);%得到二值圖像圖3.5二值圖像(t xin)3.6邊緣(binyun)檢測:兩個具有(jyu)不同灰度值的相鄰區(qū)域之間總存在邊緣,邊緣就是灰度值不連續(xù)的結(jié)果,是圖像分割、紋理特征提取和形狀特征提取等圖像分析的基礎。為了對有意義的邊緣點進行分類,與這個點相聯(lián)系的灰度級必須比在這一點的背景上變換更有效,我們通過門限方法來決定一個值是否有效
11、。所以,如果一個點的二維一階導數(shù)比指定的門限大,我們就定義圖像中的次點是一個邊緣點,一組這樣的依據(jù)事先定好的連接準則相連的邊緣點就定義為一條邊緣。經(jīng)過一階的導數(shù)的邊緣檢測,所求的一階導數(shù)高于某個閾值,則確定該點為邊緣點,這樣會導致檢測的邊緣點太多??梢酝ㄟ^求梯度局部最大值對應的點,并認定為邊緣點,去除非局部最大值,可以檢測出精確的邊緣。一階導數(shù)的局部最大值對應二階導數(shù)的零交叉點,這樣通過找圖像強度的二階導數(shù)的零交叉點就能找到精確邊緣點。grd=edge(bw2,canny)%用canny算子識別強度圖像中的邊界figure,imshow(grd);title(圖像邊緣提取);%輸出圖像邊緣圖3
12、.6像邊緣(binyun)提取3.7對得到(d do)圖像作開操作進行濾波:數(shù)學形態(tài)非線性濾波,可以用于抑制噪聲,進行特征提取、邊緣檢測、圖像分割等圖像處理(t xin ch l)問題。腐蝕是一種消除邊界點的過程,結(jié)果是使目標縮小,孔洞增大,因而可有效的消除孤立噪聲點;膨脹是將與目標物體接觸的所有背景點合并到物體中的過程,結(jié)果是使目標增大,孔洞縮小,可填補目標物體中的空洞,形成連通域。先腐蝕后膨脹的過程稱為開運算,它具有消除細小物體,并在纖細處分離物體和平滑較大物體邊界的作用;先膨脹后腐蝕的過程稱為閉運算,具有填充物體內(nèi)細小空洞,連接鄰近物體和平滑邊界的作用。對圖像做了開運算和閉運算,閉運算可
13、以使圖像的輪廓線更為光滑,它通常用來消掉狹窄的間斷和長細的鴻溝,消除小的孔洞,并彌補輪廓線中的斷裂。bg1=imclose(grd,strel(rectangle,5,19);%取矩形框的閉運算figure,imshow(bg1);title(圖像閉運算5,19);%輸出閉運算的圖像bg3=imopen(bg1,strel(rectangle,5,19);%取矩形框的開運算figure,imshow(bg3);title(圖像開運算5,19);%輸出開運算的圖像bg2=imopen(bg3,strel(rectangle,19,1);%取矩形框的開運算figure,imshow(bg2);ti
14、tle(圖像開運算19,1);%輸出開運算的圖像圖3.7.1閉運算(yn sun)的圖像 圖3.7.2開運算(yn sun)的圖像圖3.7.3開運算(yn sun)的圖像3.8對二值圖像進行區(qū)域提取,并計算區(qū)域特征參數(shù)。進行區(qū)域特征參數(shù)比較,提取車牌區(qū)域:a.對圖像每個區(qū)域進行標記,然后計算每個區(qū)域的圖像特征參數(shù):區(qū)域中心(zhngxn)位置、最小包含矩形、面積。L,num = bwlabel(bg2,8);%標注(bio zh)二進制圖像中已連接的部分Feastats = imfeature(L,basic);%計算圖像區(qū)域的特征(tzhng)尺寸Area=Feastats.Area;%區(qū)域
15、面積BoundingBox=Feastats.BoundingBox;%x y width height車牌的框架大小RGB = label2rgb(L, spring, k, shuffle); %標志圖像向RGB圖像轉(zhuǎn)換figure,imshow(RGB);title(圖像彩色標記);%輸出框架的彩色圖像圖3.8.1彩色圖像b. 計算出包含所標記的區(qū)域的最小寬和高,并根據(jù)先驗知識,比較誰的寬高比更接近實際車牌寬高比,將更接近的提取并顯示出來。計算矩形的高度框架的寬度和高度的范圍車牌的開始列車牌的開始行計算車牌長寬比獲取車牌二值子圖計算矩形的寬度 程序(chngx)流程圖 圖3.8.2灰度子
16、圖和二值子圖3.9對水平投影進行(jnxng)峰谷分析:對水平投影進行峰谷分析,計算(j sun)出車牌上邊框、車牌字符投影、車牌下邊框的波形峰上升點、峰下降點、峰寬、谷寬、峰間距離、峰中心位置參數(shù)。histcol1=sum(sbw1); %計算垂直投影histrow=sum(sbw1); %計算水平(shupng)投影figure,subplot(2,1,1),bar(histcol1);title(垂直(chuzh)投影(含邊框));%輸出垂直投影subplot(2,1,2),bar(histrow); title(水平投影(含邊框(binkung)));%輸出水平投影圖3.9.1垂直投影
17、和水平投影figure,subplot(2,1,1),bar(histrow); title(水平投影(含邊框));%輸出水平投影subplot(2,1,2),imshow(sbw1);title(車牌二值子圖);%輸出二值圖對水平投影進行峰谷分析:求水平投影的最小值取閾值計算谷寬度計算峰距離計算下降點找到峰中心位置求水平投影的平均值圖3.9.2水平(shupng)投影和二值圖 程序(chngx)流程圖3.10計算(j sun)車牌旋轉(zhuǎn)角度:a.車牌傾斜的原因?qū)е峦队?tuyng)效果峰股谷不明顯,在這里需要做車牌矯正處理。這里采取的線性擬合的方法,計算出車牌上邊或下邊圖像值為1的點擬合直線與
18、水平(shupng)X軸的夾角。求最大寬度為字符檢測上邊從頂邊至第一個峰下降點掃描從底邊至最后一個峰的上升點掃描找第一個為1的點標示出圖像大小程序(chngx)流程圖 (2)線性擬合,計算與x夾角fresult = fit(xdata,ydata,poly1); %poly1表示一介擬合 Y = p1*x+p2p1=fresult.p1;angle=atan(fresult.p1)*180/pi; %弧度換為度,360/2pi, pi=3.14 (3)旋轉(zhuǎn)車牌圖象subcol = imrotate(subcol1,angle,bilinear,crop); %旋轉(zhuǎn)車牌圖象sbw = imrot
19、ate(sbw1,angle,bilinear,crop);%旋轉(zhuǎn)圖像figure,subplot(2,1,1),imshow(subcol);title(車牌灰度子圖);%輸出車牌旋轉(zhuǎn)后的灰度圖像標題顯示車牌灰度子圖subplot(2,1,2),imshow(sbw);title();%輸出車牌旋轉(zhuǎn)后的灰度圖像title(車牌旋轉(zhuǎn)角: ,num2str(angle),度 ,Color,r);%顯示車牌的旋轉(zhuǎn)角度圖3.10.1旋轉(zhuǎn)后的灰度圖像(t xin)和旋轉(zhuǎn)角度b.旋轉(zhuǎn)車牌后重新計算車牌水平投影,去掉車牌水平邊框,獲取字符(z f)高度:histcol1=sum(sbw); %計算(j s
20、un)垂直投影histrow=sum(sbw); %計算水平投影figure,subplot(2,1,1),bar(histcol1);title(垂直投影(旋轉(zhuǎn)后));subplot(2,1,2),bar(histrow); title(水平投影(旋轉(zhuǎn)后));圖3.10.2垂直投影(旋轉(zhuǎn)后)和水平投影(旋轉(zhuǎn)后)figure,subplot(2,1,1),bar(histrow); title(水平投影(旋轉(zhuǎn)后));subplot(2,1,2),imshow(sbw);title(車牌二值子圖(旋轉(zhuǎn)后));圖3.10.3水平(shupng)投影(旋轉(zhuǎn)后)和車牌二值子圖(旋轉(zhuǎn)后)3.11去水平(
21、上下)邊框,獲取字符(z f)高度: a.通過以上水平投影、垂直投影分析計算,獲得了車牌字符高度、字符頂行與尾行、字符寬度、每個字符的中心位置,為提取分割字符具備(jbi)了條件。maxhight=max(markrow2);findc=find(markrow2=maxhight);rowtop=markrow(findc);rowbot=markrow(findc+1)-markrow1(findc+1);sbw2=sbw(rowtop:rowbot,:); %子圖為(rowbot-rowtop+1)行maxhight=rowbot-rowtop+1; %字符高度(rowbot-rowto
22、p+1)b.計算車牌垂直投影,去掉車牌垂直邊框,獲取車牌及字符平均寬度histcol=sum(sbw2); %計算垂直投影figure,subplot(2,1,1),bar(histcol);title(垂直投影(去水平邊框后));%輸出車牌的垂直投影圖像subplot(2,1,2),imshow(sbw2); %輸出垂直投影圖像title(車牌字符高度: ,int2str(maxhight),Color,r);%輸出車牌字符高度%對垂直投影進行峰谷分析求垂直投影的最小值取閾值計算字符上升點計算谷寬度計算字符距離找到字符中心位置求垂直投影的平均值圖3.11垂直投影圖像和車牌字符(z f)高度
23、程序流程圖c.計算(j sun)車牌上每個字符中心位置,計算最大字符寬度maxwidthl=0;for k=1:n1 markcol3(k)=markcol(k+1)-markcol1(k+1);%字符(z f)下降點 markcol4(k)=markcol3(k)-markcol(k); %字符寬度(上升點至下降點) markcol5(k)=markcol3(k)-double(uint16(markcol4(k)/2);%字符(z f)中心位置end markcol6=diff(markcol5); %字符中心(zhngxn)距離(字符中心點至下一個字符中心點)maxs=max(markc
24、ol6); %查找(ch zho)最大值,即為第二字符與第三字符中心距離findmax=find(markcol6=maxs);markcol6(findmax)=0;maxwidth=max(markcol6);%查找最大值,即為最大字符寬度d.提取分割字符,并變換為22行*14列標準子圖l=1;m2,n2=size(subcol);figure;for k=findmax-1:findmax+5 cleft=markcol5(k)-maxwidth/2; cright=markcol5(k)+maxwidth/2-2; if cleftn2 cright=n2; cleft=n2-maxw
25、idth; end SegGray=sbw(rowtop:rowbot,cleft:cright); SegBw1=sbw(rowtop:rowbot,cleft:cright); SegBw2 = imresize(SegBw1,22 14); %變換為22行*14列標準子圖 subplot(2,n1,l),imshow(SegGray); if l=7 title(車牌字符(z f)寬度: ,int2str(maxwidth),Color,r); end subplot(2,n1,n1+l),imshow(SegBw2); fname=strcat(F:MATLABworksamimage
26、,int2str(k),.jpg);%保存(bocn)子圖備選入樣本庫,并建立樣本庫 imwrite(SegBw2,fname,jpg) l=l+1;end3.12將計算計算獲取的字符(z f)圖像與樣本庫進行匹配,自動識別出字符代碼:進行車牌識別前需要使用樣本對神經(jīng)網(wǎng)絡進行訓練,然后使用訓練好的網(wǎng)絡對車牌進行識別。其具體流程為:使用漢字、字母、字母數(shù)字、數(shù)字四個樣本分別對四個子網(wǎng)絡進行訓練,得到相應的節(jié)點數(shù)和權值。對已經(jīng)定位好的車牌進行圖像預處理,逐個的特征提取,然后從相應的文件中讀取相應的節(jié)點數(shù)和權值,把車牌字符分別送入相應的網(wǎng)絡進行識別,輸出識別結(jié)果。樣本與數(shù)據(jù)庫中圖片相減計算誤差找到誤差最小圖片依次識別并識別建立數(shù)據(jù)庫程序流程圖 圖3.12識別的車牌號碼 四、設計結(jié)果(ji gu)及分析原始(yunsh)圖像: 預處理后:車牌定位和提?。?字符(z f)的分割和識別: 可以看出對于這個車牌,可以準確(zhnqu)的識別。原始(yunsh)圖像: 預處理: 車牌的定位(dngwi)和提取: 字符的分割和識別: 從上面結(jié)果可以看出,這張車牌的識別失敗了,將G誤識別為B了,K誤識為A,0識別為8,這在識別中是非常容易出錯的地方,因此(ync)需要在其他方面做些彌補,最后達到識別效果。在車牌識別的過程中數(shù)字庫的建立很重要,只有數(shù)字庫的準確(zhnqu)才能保證檢測出來
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度智能倉儲卷簾門系統(tǒng)采購及集成合同
- 2025年度區(qū)塊鏈技術應用項目開發(fā)與許可合同
- 2025年休假村租賃協(xié)議模板
- 2025年建筑工程模板工程承包合同書
- 2025年信用卡債務履行協(xié)議
- 2025年金剛石膜工具項目立項申請報告模范
- 2025年血液系統(tǒng)用藥項目規(guī)劃申請報告模范
- 2025年街頭籃球項目規(guī)劃申請報告
- 2025年放射性藥品項目提案報告模式
- 2025年生活用橡膠制品:塑膠盒項目規(guī)劃申請報告范文
- 工業(yè)機器人編程語言:Epson RC+ 基本指令集教程
- 2024年同等學力申碩統(tǒng)考英語卷
- 六年級下冊音樂全冊教案湖南文藝出版社湘教版
- 2023.05.06-廣東省建筑施工安全生產(chǎn)隱患識別圖集(高處作業(yè)吊籃工程部分)
- 2024年上海高考數(shù)學真題試題(原卷版+含解析)
- JTG 3362-2018公路鋼筋混凝土及預應力混凝土橋涵設計規(guī)范
- 電動汽車用驅(qū)動電機系統(tǒng)-編制說明
- 江蘇卷2024年高三3月份模擬考試化學試題含解析
- 門診導診課件
- 2024年四川省成都市新都區(qū)中考英語一診試卷(含解析)
- 《樹立正確的“三觀”》班會課件
評論
0/150
提交評論