楊智勇,劉研奇,劉佳豪,繆 陳
(1.湖北工業(yè)大學(xué)機(jī)械工程學(xué)院,湖北 武漢 430068;2.中國人民解放軍95997部隊(duì),北京 100071;3.國網(wǎng)湖南省電力有限公司檢修公司,湖南 長沙 410004)
隨著汽車成為人們?nèi)粘3鲂械某S霉ぞ?,車身表面的刮痕成為其使用過程中無法避免的問題。目前,車身刮痕檢測較多采用人工目視的方式,以上海大眾汽車廠為例,汽車車身完成上漆后,工人從不同角度通過觀察、觸摸等方式檢測和標(biāo)記微小瑕疵[1]。該方式漏檢率高、成本高、速度慢,且油漆對工人的健康造成危害。針對該問題,提出一種代替人工的計(jì)算機(jī)自動檢測方法顯得尤為重要。
車身刮痕檢測包括:刮痕圖像預(yù)處理、刮痕邊緣檢測、刮痕識別定位和修復(fù)等步驟。
其中,車身刮痕邊緣檢測的準(zhǔn)確性直接影響著后續(xù)刮痕識別定位精度,一旦邊緣檢測不準(zhǔn)確,直接影響刮痕中心線的提取,降低了車身刮痕的定位精度。因此,提升邊緣檢測準(zhǔn)確性對于后續(xù)刮痕的精確定位十分重要。
抑制圖像噪聲及獲取更多的圖像邊緣特征是邊緣提取的關(guān)鍵。傳統(tǒng)的重新啟動、Canny和Sobel等邊緣檢測算法已被廣泛應(yīng)用于工業(yè)圖像檢測領(lǐng)域,但仍存在對噪聲敏感、識別的邊緣不連續(xù)、無法辨別邊緣與紋理等問題,故采用傳統(tǒng)的邊緣檢測算法對提取含噪聲的車身刮痕邊緣效果不佳。目前,國內(nèi)外已有大量學(xué)者對含噪圖像邊緣檢測方法開展研究。其中,神經(jīng)網(wǎng)絡(luò)算法、啟發(fā)式算法[2]等搜索能力強(qiáng)、定位精度高,但實(shí)現(xiàn)成本高且建立模型需大量訓(xùn)練樣本,效率較低[3];文獻(xiàn)[4]通過小波變換對光照不均圖像進(jìn)行增強(qiáng)處理,引入神經(jīng)網(wǎng)絡(luò)求解增強(qiáng)系數(shù),該方法雖圖像處理效果好但也增加了計(jì)算負(fù)擔(dān);文獻(xiàn)[5]提出基于小波變換的邊緣檢測方法,該方法具有一定的抗噪性,但對微弱邊緣的檢測能力不足。文獻(xiàn)[6]提出基于MAS 的小波算法,用于鋼板表面缺陷邊緣檢測,利用尺度區(qū)分邊緣的類型,有效提取出鋼板表面缺陷圖像,但同樣對微弱邊緣的檢測能力不足。
小波變換在多尺度分析和時頻局部化方面表現(xiàn)良好,適用于檢測局部突變信號,是濾除圖像噪聲和邊緣檢測的有效工具,廣泛應(yīng)用于工業(yè)邊緣異常檢測中[7]。數(shù)學(xué)形態(tài)學(xué)是通過一定形狀、大小的結(jié)構(gòu)元素去檢測和提取圖像中的對應(yīng)形狀,從而實(shí)現(xiàn)對圖像處理與識別的目的,其本質(zhì)上一種非線性濾波方法,簡化圖像數(shù)據(jù)的同時也保證邊緣的形狀特性,因此數(shù)學(xué)形態(tài)學(xué)能檢測到真正的邊緣且運(yùn)算效率高[8]。
基于此,提出一種融合小波變換和數(shù)學(xué)形態(tài)學(xué)的汽車刮痕邊緣檢測方法,將兩種檢測算法的結(jié)果進(jìn)行融合,得到最終的邊緣檢測結(jié)果。
具體包括對兩種算法的檢測結(jié)果進(jìn)行小波分解分別得到邊緣圖像的高頻分量和低頻分量,兩圖像的低頻分量根據(jù)能量大小分配權(quán)重得到融合后圖像的低頻分量,相對應(yīng)的高頻分量通過對比其絕對值大小,選擇偏大的作為融合后圖像的高頻分量,將融合的高低頻分量進(jìn)行重構(gòu),得到融合后的邊緣圖像。
汽車車身刮痕檢測系統(tǒng),如圖1所示。主要包括機(jī)械臂、攝像頭、光源、機(jī)械臂運(yùn)動平臺和噴漆裝置。其中,4個攝像頭分布于車身的四周,在噴漆房頂部和底部分布專用光源,確保攝像頭采集車身圖片樣本。通過智能算法檢測采集到的車身圖片,獲取車身刮痕的空間坐標(biāo),伺服控制搭載有噴漆頭的機(jī)械臂末端運(yùn)動至車身刮痕正上方,執(zhí)行噴漆操作。
圖1 車身刮痕檢測系統(tǒng)Fig.1 Car Body Scratch Detection System
圖2 車身刮痕邊緣檢測流程圖Fig.2 Flow Chart of Car Body Scratch Edge Detection
小波變換的實(shí)質(zhì)是信號被平滑函數(shù)低通濾波后的導(dǎo)數(shù),小波模極大值法是沿著圖像的梯度方向,在不同尺度下檢測圖像信號,對應(yīng)點(diǎn)的模極大值會產(chǎn)生相應(yīng)變換。小波函數(shù)對應(yīng)平滑函數(shù)的導(dǎo)數(shù)時,由小波模極大值找到圖像的邊緣點(diǎn)[9]。
設(shè)θ(x,y)為二維可微高斯平滑函數(shù),具有良好的局部化特征且滿足條件:
設(shè)圖像f(x,y)∈L2(R2),平滑函數(shù)做卷積運(yùn)算得到平滑后的圖像:
設(shè)ψ(x,y)是θ(x,y)的一階導(dǎo)數(shù),對θ(x,y)在x,y方向上分別求偏導(dǎo)數(shù),得到兩個二維小波變換函數(shù)分別為:
因此,當(dāng)尺度為S時,二進(jìn)制小波沿著水平和垂直兩個方向分解出來的兩個分量構(gòu)成了圖像f(x,y)被θs(x,y)平滑后的圖像梯度矢量。
所以梯度矢量的大小為梯度矢量的模:
梯度矢量的方向與水平方向的夾角為相角:
于是,沿著梯度矢量方向的極大值點(diǎn)為刮痕圖像的邊緣點(diǎn)。通過小波變換的邊緣檢測雖能提升噪聲魯棒性,但仍會漏檢很多微弱邊緣,造成邊緣檢測精度較低。為了得到較好的邊緣檢測精度,需要融合更多的邊緣細(xì)節(jié)信息。
數(shù)學(xué)形態(tài)學(xué)理論是一種建立在集合論基礎(chǔ)之上的非線性濾波方法,近幾年在圖像處理方面被得到了迅速發(fā)展與完善[10-11]。在邊緣檢測方面,采用形態(tài)學(xué)檢測方法能獲得較好的圖像邊緣連續(xù)性。
設(shè)f(x,y)為輸入圖像,B(x,y)為結(jié)構(gòu)元素,抗噪型檢測算子如下:
抗噪膨脹型:
抗噪腐蝕型:
抗噪膨脹腐蝕型:
傳統(tǒng)的單結(jié)構(gòu)元素只能檢測出與結(jié)構(gòu)元素同方向的邊緣,無法很好地檢測車身刮痕這種形狀多變的復(fù)雜邊緣。
因此,通過反復(fù)實(shí)驗(yàn)分析,提出一種多結(jié)構(gòu)元素的數(shù)學(xué)形態(tài)學(xué)檢測算子:
定義新的邊緣檢測算子為:
由式(13)將得到的三種抗噪算子分別檢測后做平均運(yùn)算得到完整邊緣,而式(13)前半部分得到的邊緣圖像細(xì)節(jié)不豐富,因此在式(13)后半部分迭加上一些邊緣的細(xì)節(jié)信息,使邊緣更加清晰連續(xù)。
當(dāng)形態(tài)學(xué)結(jié)構(gòu)元素的方向與邊緣垂直時,才能較好地檢測出各點(diǎn)的邊緣,因此形態(tài)學(xué)結(jié)構(gòu)元素的方向應(yīng)與圖像平均梯度方向平行。由于汽車刮痕邊緣形狀不定,選取如下結(jié)構(gòu)元素:B1至B4為4 個(3×3)的方形結(jié)構(gòu)元素,對應(yīng)的方向角為0°,90°,45°,135°。
圖像中的行和列的增加方向分別為+x方向和+y方向。設(shè)φ為圖像平均梯度向量與x軸正方向的夾角。當(dāng)圖像梯度方向近似與x軸垂直,即取B1最符合;
當(dāng)梯度方向近似為x方向,即時,取B2最符合;
當(dāng)梯度方向近似為x軸成方向,即取B3最符合;
當(dāng)梯度方向近似與x軸成,即π,取B4最符合。
因此,構(gòu)造的結(jié)構(gòu)元素能滿足大部分邊緣的檢測要求,設(shè)刮痕源圖像經(jīng)過預(yù)處理后的灰度圖像為f',分別根據(jù)構(gòu)造的四個結(jié)構(gòu)元素Bi按照新的邊緣檢測算子進(jìn)行運(yùn)算,然后將四個運(yùn)算結(jié)果進(jìn)行加權(quán)合成得到邊緣圖像,運(yùn)算式如下:
小波變換能有效濾除刮痕邊緣提取過程中的圖像噪聲,并準(zhǔn)確定位刮痕的位置。形態(tài)學(xué)方法檢測出的圖像邊緣連續(xù)性好,能很好表達(dá)刮痕邊緣的細(xì)節(jié)信息。為了充分利用兩種檢測算法的優(yōu)點(diǎn),克服單一檢測算法的不足,融合小波變換和形態(tài)學(xué)這兩種檢測算法的運(yùn)算結(jié)果,減少圖像噪聲干擾,使邊緣細(xì)節(jié)信息更加清晰,為后續(xù)研究提供技術(shù)支持?;谛〔ㄗ儞Q和改進(jìn)形態(tài)學(xué)的邊緣檢測流程為:
(1)采集汽車車身刮痕圖像,得到待處理的車身刮痕源圖像樣本。
(2)對源圖像應(yīng)用多尺度小波變換,利用模極大值法提取刮痕邊緣,得到邊緣圖像A。
(3)應(yīng)用多結(jié)構(gòu)元素?cái)?shù)學(xué)形態(tài)學(xué)邊緣檢測算法,對源圖像提取邊緣得到邊緣圖像B。
(4)設(shè)步驟1中得到得圖像邊緣為A(x,y),步驟(2)中得到得圖像邊緣為B(x,y),T(x,y)為融合A,B兩幅圖像后的邊緣圖像。具體融合步驟如下所示:
①分別對兩幅邊緣的圖像進(jìn)行小波變換,得到高頻和低頻分量。
②計(jì)算A,B兩幅圖像低頻帶內(nèi)的局部區(qū)域Q的能量,即將區(qū)域內(nèi)像素點(diǎn)的灰度值平方累加乘以權(quán)重。
式中:w(q)—權(quán)重;
Q—p的一個領(lǐng)域;
C—像素點(diǎn)的灰度值。
同理計(jì)算圖像B的能量S(B,p)。
③根據(jù)式(14)計(jì)算所得兩圖像的能量S計(jì)算匹配度:
匹配度計(jì)算中,式(16)計(jì)算所得值越接近1代表該點(diǎn)匹配度高。
④設(shè)置一個閾值e,定義閾值大小范圍在(0.5~1)之間。如果MAB<e,直接選擇該點(diǎn)能量大的像素灰度值,舍棄其余:
如果MAB>e,根據(jù)能量大小分配權(quán)重:
高頻分量的融合,如式(19)所示:
式中:HA—邊緣圖像A的高頻分量;HB—邊緣圖像B高頻分量。取HA、HB中絕對值大的作為融合后圖像的高頻分量,定義為HF。分別得到融合圖像的高低頻分量后,通過小波逆變換重構(gòu)邊緣圖像,得到最后的邊緣融合圖像T(x,y)。
為噴漆機(jī)器人實(shí)驗(yàn)平臺,如圖3所示。噴漆裝置安裝在噴漆房內(nèi),車輛與噴漆房內(nèi)壁間距約為1m,6R機(jī)械臂安裝在XY運(yùn)動平臺上,通過伺服驅(qū)動帶動機(jī)械臂到達(dá)車身周圍任意位置。機(jī)械臂末端裝有噴涂裝置,該裝置包括噴槍、噴壺、連接件等。噴漆房內(nèi)分布多個D65光源的(明亮度為(800~1000)lux)燈箱,保證光照充足的同時減少車身表面的反光,保證采集到的圖像能滿足計(jì)算需要。
圖3 噴漆機(jī)器人實(shí)驗(yàn)平臺Fig.3 Experimental Platform of Painting Robot
為評價(jià)所提出算法是否合理,需要驗(yàn)證該算法對車身刮痕邊緣檢測的有效性并對檢測結(jié)果進(jìn)行評估。評價(jià)指標(biāo)包括查準(zhǔn)率Precision、查全率Recall 以及綜合評價(jià)指標(biāo)F-measure,F(xiàn)measure是Precison和Recall的加權(quán)調(diào)和平均[12]:
式中:P—Precision;R—Recall;F—F-measure。
在實(shí)驗(yàn)中,通過融合算法對1000個車身刮痕數(shù)據(jù)集樣本進(jìn)行了測試,測試效果,如圖4所示。各項(xiàng)評價(jià)指標(biāo)的精度均能穩(wěn)定分布在80%左右,由此驗(yàn)證了融合算法針對車身刮痕邊緣提取的有效性。
圖4 刮痕檢測效果Fig.4 Effect of Scratch Detection
融合算法對車身蓋板、汽車翼子板與車門處的刮痕邊緣檢測結(jié)果,如圖5(a)~圖5(c)所示。分析可知:通過提出的小波變換與形態(tài)學(xué)融合算法進(jìn)行檢測,得到的刮痕邊緣圖像的輪廓連續(xù)、清晰,且目標(biāo)刮痕的邊緣能從整體的車身背景中被檢測出來,3類場景中的刮痕邊緣在亮度和邊緣保持度上都符合人眼視覺,表明本檢測系統(tǒng)通過融合算法在針對車身不同部位的刮痕進(jìn)行邊緣檢測時,對車身不同部位刮痕的檢測效果良好,算法具有一定的魯棒性,能達(dá)到檢測時所需的預(yù)期效果,不僅很好地排除了背景的干擾,分離出了目標(biāo)刮痕邊緣,也保證了圖像的完整性。
圖5 不同部位刮痕融合算法處理結(jié)果Fig.5 Scratch Fusion Algorithm Processing Results of Different Parts
不同算法對車身同一處刮痕的邊緣檢測結(jié)果,如圖6所示。分析可知:傳統(tǒng)的邊緣檢測算法對噪聲比較敏感,且邊緣不夠連續(xù)。單一的小波模極大值邊緣檢測算法能有效降噪,但也存在邊緣信息不夠豐富的缺點(diǎn),而采用改進(jìn)的形態(tài)學(xué)邊緣檢測方法確保了邊緣的連續(xù)性。融合算法很好地解決了噪聲問題的同時,也保留了刮痕的有效邊緣信息,保證了汽車邊緣的連續(xù)性,為后續(xù)的檢測工作提供了支持。
圖6 不同算法邊緣檢測結(jié)果Fig.6 Different Algorithm Edge Detection Results
為了定量分析不同算法檢測結(jié)果的好壞,選擇信噪比SNR和峰值信噪比PSNR衡量圖像處理質(zhì)量的好壞。通過手動向車身蓋板處的刮痕源圖像中加入3%的椒鹽噪聲,為了定量分析不同算法對車身含噪圖像的邊緣檢測結(jié)果。含噪圖像通過不同邊緣檢測算法處理后的PSNR和SNR值,如表1所示。傳統(tǒng)的邊緣檢測算法結(jié)果,如表1 所示。其SNR 均低于5dB,PSNR 也低于20dB,改進(jìn)后的形態(tài)學(xué)算法對刮痕邊緣的處理結(jié)果相比于傳統(tǒng)的形態(tài)學(xué)算法,均有3dB的提升。而融合了小波模極大值后的融合算法,相比于單一的改進(jìn)形態(tài)學(xué)算法,處理結(jié)果的PSNR 和SNR 均進(jìn)一步提升了約2dB。從柱狀圖描述分析可知,從左至右,不同算法的SNR與PSNR值均保持遞增狀態(tài),證明了從左到右各算法的對車身刮痕的邊緣檢測效果逐漸改善,融合算法的處理效果最佳,如圖7所示。依次對圖像添加不同濃度的噪聲后結(jié)果,如表2所示。
表1 不同邊緣檢測算法PSNR、SNR值Tab.1 PSNR and SNR Values of Different Edge Detection Algorithms
表2 不同濃度下PSNR、SNR值Tab.2 PSNR and SNR Values at Different Concentrations
圖7 不同邊緣檢測算法PSNR、SNR柱狀圖Fig.7 Different Edge Detection Algorithms Histogram of PSNR and SNR
圖8 不同噪聲PSNR變化曲線Fig.8 PSNR Curve of Different Noises
圖9 不同噪聲SNR變化曲線圖Fig.9 SNR Curve of Different Noises
依次對圖像分別添加(1~10)%的噪聲,從相應(yīng)的PSNR 和SNR值曲線變化來看,隨著噪聲濃度的增加,二種算法的相應(yīng)數(shù)值均保持穩(wěn)定降低,隨著噪聲濃度從1%增加至10%的,二者的PSNR與SNR值均大約只降低了15dB且沒有發(fā)生曲線的驟升和驟降,表明這兩種算法在處理含噪的車身刮痕圖像時,表現(xiàn)穩(wěn)定,算法具有很好的魯棒性。從二者的曲線變化圖進(jìn)一步分析,改進(jìn)的形態(tài)學(xué)算法和融合算法在刮痕的邊緣檢測上,針對不同的噪聲濃度時,融合算法的PSNR和SNR值均高于改進(jìn)的數(shù)學(xué)形態(tài)學(xué)算法,進(jìn)一步說明了融合算法對車身的刮痕邊緣檢測效果優(yōu)于改進(jìn)的形態(tài)學(xué)算法。
針對車身刮痕圖像檢測中因?yàn)樵肼暤拇嬖谑沟密嚿砉魏圻吘墮z測不清晰的問題,提出一種基于小波模極大值和數(shù)學(xué)形態(tài)學(xué)的邊緣檢測算法。該算法將小波模極大值邊緣檢測法和經(jīng)過改進(jìn)的形態(tài)學(xué)邊緣檢測算法相結(jié)合。在傳統(tǒng)形態(tài)學(xué)基礎(chǔ)之上,引入了抗噪邊緣檢測算子,并進(jìn)一步優(yōu)化,同時引入不同方向的結(jié)構(gòu)元素。算法通過小波變換將兩種邊緣檢測算法得到的結(jié)果進(jìn)行分解分別得到其圖像的高低頻分量,兩圖像低頻分量根據(jù)圖像能量大小分配權(quán)重進(jìn)行融合,高頻分量通過對比絕對值大小,取二者中較大值作為融合后圖像的高頻分量,然后通過小波逆變換重構(gòu)融合后的高頻和低頻分量,得到最終的刮痕邊緣融合結(jié)果。通過對比分析可知,融合算法對提高圖像信噪比,增強(qiáng)圖像邊緣連續(xù)性有效果明顯。雖提出的融合算法在邊緣檢測的結(jié)果中表現(xiàn)不錯,但仍有進(jìn)一步提升的空間??紤]在未來的研究中,尋找出小波的最優(yōu)分解尺度并提出更多的數(shù)學(xué)形態(tài)學(xué)結(jié)構(gòu)元素,使得邊緣更加清晰連續(xù),因此需要繼續(xù)改進(jìn)方法,并進(jìn)行量化分析。