




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第PythonOpenCV實(shí)現(xiàn)邊緣檢測(cè)本文實(shí)例為大家分享了PythonOpenCV實(shí)現(xiàn)邊緣檢測(cè)的具體代碼,供大家參考,具體內(nèi)容如下
1.Sobel算子檢測(cè)
Sobel算子是高斯平滑和微分運(yùn)算的組合,抗噪能力很強(qiáng),用途也很多,尤其是效率要求高但對(duì)細(xì)紋理不是很在意的時(shí)候。
對(duì)于不連續(xù)的函數(shù),有:
假設(shè)要處理的圖像為I,在兩個(gè)方向求導(dǎo)。
水平變化:用奇數(shù)大小的模板對(duì)圖像I卷積,結(jié)果為Gx。例如,當(dāng)模板大小為3時(shí),Gx為:
垂直變化:用奇數(shù)大小的模板對(duì)圖像I卷積,結(jié)果為Gy。例如,當(dāng)模板大小為3時(shí),Gy為:
在圖像的每個(gè)點(diǎn),結(jié)合以上兩個(gè)結(jié)果,得到:
極大值的位置是圖像的邊緣。
當(dāng)核大小為3時(shí),上述Sobel核可能會(huì)產(chǎn)生更明顯的誤差。為了解決這個(gè)問(wèn)題,可以使用Scharr函數(shù)。這個(gè)函數(shù)只對(duì)大小為3的核有效,運(yùn)算速度和Sobel函數(shù)一樣快,但是結(jié)果更準(zhǔn)確。計(jì)算方法為:
cv.Sobel(src,ddepth,dx,dy,dst,ksize,scale,delta,borderType)
參數(shù):
src傳入的圖像
ddepth圖像的深度
dx、dy指求導(dǎo)的階數(shù),0表示這個(gè)方向上沒(méi)有求導(dǎo),取值為0、1。
ksizeSobel算子的大小,即卷積核的大小,必須為奇數(shù)1、3、5、7,默認(rèn)為3。-1代表3x3的Scharr算子。
scale縮放導(dǎo)數(shù)的比例常數(shù),默認(rèn)情況為沒(méi)有伸縮系數(shù)。
borderType圖像邊界的模式,默認(rèn)值為cv.BORDER_DEFAULT。
需要對(duì)x和y兩個(gè)方向都調(diào)用一次cv.Sobel()函數(shù)。然后,對(duì)每個(gè)方向調(diào)用cv.convertScaleAbs()函數(shù)將其轉(zhuǎn)回uint8格式,再調(diào)用cv2.addWeighted()函數(shù)將兩個(gè)方向組合起來(lái)。
2.Laplacian算子檢測(cè)
Laplacian使用二階導(dǎo)數(shù)來(lái)檢測(cè)邊緣。因?yàn)閳D像是二維的,所以我們需要從兩個(gè)方向求導(dǎo):
不連續(xù)函數(shù)的二階導(dǎo)數(shù)是:
使用的卷積核是:
cv.Laplacian(src,ddepth,ksize)
參數(shù):
src需要處理的圖像
ddepth圖像的深度,-1表示采用的是原圖像相同的深度,目標(biāo)圖像的深度必須大于等于原圖像的深度
ksize算子的大小,即卷積核的大小,必須為1、3、5、7。
然后,對(duì)返回值調(diào)用cv.convertScaleAbs(res)即可獲得邊緣圖像。
3.Canny邊緣檢測(cè)
Canny邊緣檢測(cè)算法由4個(gè)步驟組成。
1)去噪。由于邊緣檢測(cè)容易受噪聲影響,首先使用5*5高斯濾波器去除噪聲。
2)計(jì)算圖像梯度。在平滑圖像上使用Sobel算子計(jì)算水平和垂直方向的一階導(dǎo)數(shù)(Gx和Gy)。根據(jù)得到的兩個(gè)梯度圖(Gx和Gy)求出邊界的梯度和方向,公式如下:
如果一個(gè)像素是一個(gè)邊緣,它的梯度方向總是垂直于邊緣。梯度方向分為四類(lèi):垂直方向、水平方向和兩個(gè)對(duì)角線(xiàn)方向。
3)非極大值抑制。得到梯度的方向和大小后,掃描整個(gè)圖像去除那些非邊界點(diǎn)。檢查每個(gè)像素點(diǎn),看這個(gè)點(diǎn)的梯度是否在周?chē)哂邢嗤荻确较虻狞c(diǎn)中最大。
A點(diǎn)位于圖像的邊緣。在其梯度變化的方向,選擇像素B和C,檢查A點(diǎn)的梯度是否為極大值。如果是極大值,則保留,否則A點(diǎn)將被抑制,最后得到的結(jié)果是邊緣細(xì)的二值圖像。
4)滯后閾值?,F(xiàn)在來(lái)確定真正的邊界。我們?cè)O(shè)置了兩個(gè)閾值:minVal和maxVal。當(dāng)圖像的灰度梯度高于maxVal時(shí),認(rèn)為是真正的邊界,低于minVal的邊界將被丟棄。如果介于兩者之間,則取決于該點(diǎn)是否連接到確定為真的邊界點(diǎn)。如果是,則認(rèn)為是邊界點(diǎn),如果不是,則將其丟棄。minVal較小的閾值將間斷的邊緣連接起來(lái),maxVal較大的閾值檢測(cè)圖像中明顯的邊緣。如下圖:
A高于閾值maxVal,因此它是真正的邊界點(diǎn)。雖然C低于maxVal但高于minVal并與A相連,所以它也被視為真正的邊界點(diǎn)。B會(huì)被丟棄,因?yàn)樗陀趍axVal,并且沒(méi)有連接到真正的邊界點(diǎn)。所以,選擇合適的maxVal和minVal對(duì)于獲得好的結(jié)果非常重要。
cv.Canny(image,threshold1,threshold2)
參數(shù):
image灰度圖
threshold1minval,較小的閾值
threshold2maxval,較大的閾值
例:使用Sobel、Laplacian、Canny算法檢測(cè)下面圖像的邊緣。
importmatplotlib
importcv2ascv
importmatplotlib.pyplotasplt
font={
"family":"MicrosoftYaHei"
matplotlib.rc("font",**font)
img=cv.imread("./image/horse.jpg",0)
#Sobel
x=cv.Sobel(img,cv.CV_16S,1,0)
y=cv.Sobel(img,cv.CV_16S,0,1)
absx=cv.convertScaleAbs(x)
absy=cv.convertScaleAbs(y)
res=cv.addWeighted(absx,0.5,absy,0.5,0)
plt.imshow(res,cmap=plt.cm.gray)
plt.title("Sobel")
plt.show()
#Schaar
x=cv.Sobel(img,cv.CV_16S,1,0,ksize=-1)
y=cv.Sobel(img,cv.CV_16S,0,1,ksize=-1)
absx=cv.convertScaleAbs(x)
absy=cv.convertScaleAbs(y)
res=cv.addWeighted(absx,0.5,absy,0.5,0)
plt.imshow(res,cmap=plt.cm.gray)
plt.title("Schaar")
plt.show()
#Laplacian
res=cv.Laplacian(img,cv.CV_16S)
res=cv.convertScaleAbs(res)
plt.imshow(res,cmap=plt.cm.gray)
plt.title("Laplacian")
plt.show()
#Canny
res=
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 測(cè)量安全教育培訓(xùn)課件
- 2025年福建泉州出口加工區(qū)投資管理有限責(zé)任公司招聘筆試參考題庫(kù)含答案解析
- 2025年國(guó)家東方電氣集團(tuán)科學(xué)技術(shù)研究院有限公司招聘筆試參考題庫(kù)含答案解析
- 2025年貴州六盤(pán)水市鐘山區(qū)糧食收儲(chǔ)購(gòu)銷(xiāo)有限公司招聘筆試參考題庫(kù)含答案解析
- 2025年四川內(nèi)江市國(guó)有資產(chǎn)經(jīng)營(yíng)管理有限責(zé)任公司招聘筆試參考題庫(kù)含答案解析
- 2025年甘肅臨夏州藍(lán)河水利水電設(shè)計(jì)咨詢(xún)有限公司招聘筆試參考題庫(kù)含答案解析
- 2025年福建平潭綜合實(shí)驗(yàn)區(qū)土地開(kāi)發(fā)集團(tuán)有限公司招聘筆試參考題庫(kù)含答案解析
- 軍區(qū)宣傳合同范例
- 2025年浙江余姚市金瑞資產(chǎn)經(jīng)營(yíng)有限公司招聘筆試參考題庫(kù)附帶答案詳解
- 家長(zhǎng)會(huì)安全教育課件小學(xué)
- 知道網(wǎng)課智慧《自動(dòng)化生產(chǎn)線(xiàn)實(shí)訓(xùn)》測(cè)試答案
- 智慧管網(wǎng)項(xiàng)目建設(shè)方案
- 山東省煙臺(tái)市牟平區(qū)(五四制)2023-2024學(xué)年九年級(jí)下學(xué)期期中考試數(shù)學(xué)試題
- 2024年注冊(cè)安全工程師考試題庫(kù)及參考答案(完整版)
- SYT 0440-2021 工業(yè)燃?xì)廨啓C(jī)安裝技術(shù)規(guī)范-PDF解密
- DL-T 572-2021電力變壓器運(yùn)行規(guī)程-PDF解密
- 《17 他們那時(shí)候多有趣啊》公開(kāi)課一等獎(jiǎng)創(chuàng)新教學(xué)設(shè)計(jì)及反思
- 2023屆高三物理一輪復(fù)習(xí)89熱學(xué)中的變質(zhì)量問(wèn)題(解析版)
- 人教版 美術(shù) 三年級(jí)下冊(cè)全冊(cè)表格式教案教學(xué)設(shè)計(jì)
- 2021年全國(guó)高中數(shù)學(xué)聯(lián)賽浙江賽區(qū)初賽試題
- 公路工程質(zhì)量檢驗(yàn)評(píng)定標(biāo)準(zhǔn) 第二冊(cè)機(jī)電工程 JTG 2182-2020
評(píng)論
0/150
提交評(píng)論