日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Python OpenCV實現邊緣檢測

瀏覽:37日期:2022-08-06 15:48:00

本文實例為大家分享了Python OpenCV實現邊緣檢測的具體代碼,供大家參考,具體內容如下

1. Sobel 算子檢測

Sobel 算子是高斯平滑和微分運算的組合,抗噪能力很強,用途也很多,尤其是效率要求高但對細紋理不是很在意的時候。

對于不連續的函數,有:

Python OpenCV實現邊緣檢測

假設要處理的圖像為I,在兩個方向求導。

水平變化:用奇數大小的模板對圖像I卷積,結果為Gx。例如,當模板大小為3時,Gx為:

Python OpenCV實現邊緣檢測

垂直變化:用奇數大小的模板對圖像I卷積,結果為Gy。例如,當模板大小為3時,Gy為:

Python OpenCV實現邊緣檢測

在圖像的每個點,結合以上兩個結果,得到:

Python OpenCV實現邊緣檢測

極大值的位置是圖像的邊緣。

當核大小為3時,上述Sobel核可能會產生更明顯的誤差。 為了解決這個問題,可以使用 Scharr 函數。這個函數只對大小為 3 的核有效,運算速度和 Sobel 函數一樣快,但是結果更準確。 計算方法為:

Python OpenCV實現邊緣檢測

cv.Sobel(src, ddepth, dx, dy, dst, ksize, scale, delta, borderType)參數:src 傳入的圖像ddepth 圖像的深度dx、dy 指求導的階數,0表示這個方向上沒有求導,取值為0、1。ksize Sobel算子的大小,即卷積核的大小,必須為奇數1、3、5、7,默認為3。-1代表3x3的Scharr算子。scale 縮放導數的比例常數,默認情況為沒有伸縮系數。borderType 圖像邊界的模式,默認值為cv.BORDER_DEFAULT。

需要對x和y兩個方向都調用一次cv.Sobel()函數。然后,對每個方向調用cv.convertScaleAbs()函數將其轉回uint8格式,再調用cv2.addWeighted()函數將兩個方向組合起來。

2. Laplacian 算子檢測

Laplacian 使用二階導數來檢測邊緣。 因為圖像是二維的,所以我們需要從兩個方向求導:

Python OpenCV實現邊緣檢測

不連續函數的二階導數是:

Python OpenCV實現邊緣檢測

使用的卷積核是:

Python OpenCV實現邊緣檢測

cv.Laplacian(src, ddepth, ksize)參數:src 需要處理的圖像ddepth 圖像的深度,-1表示采用的是原圖像相同的深度,目標圖像的深度必須大于等于原圖像的深度ksize 算子的大小,即卷積核的大小,必須為1、3、5、7。

然后,對返回值調用cv.convertScaleAbs(res)即可獲得邊緣圖像。

3. Canny 邊緣檢測

Canny 邊緣檢測算法由4個步驟組成。

1)去噪。由于邊緣檢測容易受噪聲影響,首先使用5*5高斯濾波器去除噪聲。

2)計算圖像梯度。在平滑圖像上使用 Sobel 算子計算水平和垂直方向的一階導數(Gx 和 Gy)。 根據得到的兩個梯度圖(Gx和Gy)求出邊界的梯度和方向,公式如下:

Python OpenCV實現邊緣檢測

如果一個像素是一個邊緣,它的梯度方向總是垂直于邊緣。 梯度方向分為四類:垂直方向、水平方向和兩個對角線方向。

3)非極大值抑制。得到梯度的方向和大小后,掃描整個圖像去除那些非邊界點。 檢查每個像素點,看這個點的梯度是否在周圍具有相同梯度方向的點中最大。

Python OpenCV實現邊緣檢測

A點位于圖像的邊緣。在其梯度變化的方向,選擇像素B和C,檢查A點的梯度是否為極大值。 如果是極大值,則保留,否則A點將被抑制,最后得到的結果是邊緣細的二值圖像。

4)滯后閾值?,F在來確定真正的邊界。我們設置了兩個閾值:minVal 和 maxVal。 當圖像的灰度梯度高于 maxVal 時,認為是真正的邊界,低于minVal 的邊界將被丟棄。 如果介于兩者之間,則取決于該點是否連接到確定為真的邊界點。 如果是,則認為是邊界點,如果不是,則將其丟棄。 minVal 較小的閾值將間斷的邊緣連接起來,maxVal 較大的閾值檢測圖像中明顯的邊緣。如下圖:

Python OpenCV實現邊緣檢測

A 高于閾值 maxVal,因此它是真正的邊界點。雖然 C 低于 maxVal 但高于 minVal 并與 A 相連,所以它也被視為真正的邊界點。 B 會被丟棄,因為它低于 maxVal ,并且沒有連接到真正的邊界點。 所以,選擇合適的 maxVal 和 minVal 對于獲得好的結果非常重要。

cv.Canny(image, threshold1, threshold2)參數:image 灰度圖threshold1 minval,較小的閾值threshold2 maxval,較大的閾值

例:使用Sobel、Laplacian、Canny算法檢測下面圖像的邊緣。

Python OpenCV實現邊緣檢測

import matplotlibimport cv2 as cvimport matplotlib.pyplot as plt font = { 'family': 'Microsoft YaHei'}matplotlib.rc('font', **font) img = cv.imread('./image/horse.jpg', 0) # Sobelx = 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() # Schaarx = 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() # Laplacianres = cv.Laplacian(img, cv.CV_16S)res = cv.convertScaleAbs(res)plt.imshow(res, cmap=plt.cm.gray)plt.title('Laplacian')plt.show() # Cannyres = cv.Canny(img, 0, 100)plt.imshow(res, cmap=plt.cm.gray)plt.title('Canny')plt.show()

輸出:

Python OpenCV實現邊緣檢測

Python OpenCV實現邊緣檢測

Python OpenCV實現邊緣檢測

Python OpenCV實現邊緣檢測

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
高潮一区二区| 日韩大片在线播放| 91精品一区二区三区综合| 麻豆国产欧美一区二区三区| 国产欧美日韩一级| 国产情侣久久| 国产精品国产三级在线观看| 麻豆国产一区| 日韩高清成人| 91久久午夜| 日韩高清一区二区| 久久久久伊人| 日本在线精品| 综合色就爱涩涩涩综合婷婷| 蜜桃一区二区三区在线| 一区二区三区国产盗摄| 日本在线成人| 久久精品国内一区二区三区| 成人久久一区| 亚洲免费婷婷| 国产亚洲精品美女久久久久久久久久| 久久字幕精品一区| 黄色日韩在线| 91免费精品国偷自产在线在线| 国产伦精品一区二区三区视频| 日韩在线精品| 在线精品视频一区| 免费观看亚洲天堂| 亚洲视频综合| 日韩激情av在线| 成人国产精品一区二区免费麻豆| av资源亚洲| 蜜桃免费网站一区二区三区| 久久av综合| 在线观看免费一区二区| 久久国产欧美日韩精品| 99精品视频在线观看免费播放| 亚洲精品一二| 亚洲欧洲高清| 日本不卡视频在线| 不卡视频在线| 精品一区不卡| 日韩精品一区二区三区中文在线 | 香蕉成人av| 亚洲字幕久久| 日本在线精品| 国产精品亚洲四区在线观看 | 久久九九精品| 国产精品久久久久久模特| 高清av不卡| 免费亚洲一区| 日韩高清在线观看一区二区| 婷婷综合社区| 色爱综合av| 精品一区二区三区在线观看视频| 亚洲一区国产| 欧美不卡高清| 日韩理论片av| 91嫩草亚洲精品| 蜜桃久久久久| 国产伦精品一区二区三区千人斩| 亚洲香蕉久久| 在线亚洲自拍| 99日韩精品| 久久五月天小说| 久久婷婷av| 宅男在线一区| 欧美日韩激情| 2023国产精品久久久精品双| 中国字幕a在线看韩国电影| 国产精品v日韩精品v欧美精品网站| 日本不卡视频一二三区| 亚洲精品美女91| 日韩在线成人| 国产日韩中文在线中文字幕| 亚洲影视一区二区三区| 日韩一区二区三区高清在线观看| 中文字幕一区二区三区在线视频| 亚洲一二三区视频| 视频一区二区三区入口| 国产精品毛片| 日本成人在线视频网站| 国产精品hd| 亚洲成人国产| 日本不卡一区二区| 精品三区视频| 欧美粗暴jizz性欧美20| 亚洲丝袜啪啪| 国产在线日韩精品| 激情综合激情| 99在线精品免费视频九九视| 亲子伦视频一区二区三区| 五月天久久网站| 欧美少妇精品| 国产字幕视频一区二区| 男女男精品视频网| 国产精品一区二区中文字幕| 日韩精品专区| 日韩成人午夜精品| 成人片免费看| 日韩欧美2区| 日韩中文首页| 国产精品乱战久久久| 日韩欧美少妇| 国产精品一区二区99| 久久久精品久久久久久96| 日韩美女国产精品| 婷婷六月综合| 国产一区精品福利| 亚洲人成精品久久久| 国精品产品一区| 日韩精品视频一区二区三区| 成人片免费看| 日韩av成人高清| 伊人影院久久| 中文字幕在线高清| 久久不见久久见免费视频7| 蜜乳av另类精品一区二区| 日韩在线短视频| 免费视频一区二区三区在线观看| 亚洲欧美日本国产专区一区| 欧美黄色网页| zzzwww在线看片免费| 国产精品黄色| 日韩欧美另类中文字幕| 欧美日韩国产在线一区| 精品国产亚洲日本| 69堂精品视频在线播放| 日韩国产在线一| 偷拍亚洲精品| 日本成人一区二区| 亚洲精品第一| 日韩精品一二三| 美女精品一区| 亚洲日产av中文字幕| 在线观看亚洲精品福利片| 日韩一区精品字幕| 蜜臀久久99精品久久久久久9| 国产免费成人| 欧美日韩国产高清电影| 久久国产小视频| 亚洲欧洲一区二区天堂久久| 亚洲深爱激情| 蜜桃传媒麻豆第一区在线观看 | 久久xxx视频| 国产一区二区三区久久久久久久久| 精品视频国产| 91精品一区国产高清在线gif| 欧美日韩黑人| 日本不卡在线视频| 精品视频一区二区三区在线观看 | 国产美女高潮在线| 日本免费一区二区三区四区| 亚洲二区在线| 日韩二区在线观看| 高清久久精品| 午夜在线精品偷拍| 日本成人中文字幕| 在线中文字幕播放| 日韩精品一二三| 美腿丝袜亚洲三区| 夜夜精品视频| 欧美激情网址| 午夜国产一区二区| 国产精品中文字幕亚洲欧美| 国产在线看片免费视频在线观看| 91精品韩国| 日韩国产欧美视频| 色婷婷久久久| 国产亚洲一卡2卡3卡4卡新区| 丝袜av一区| 国产精品欧美在线观看| 午夜欧美在线| 久久香蕉网站| 每日更新成人在线视频| 91亚洲成人| 欧美欧美黄在线二区| 中国字幕a在线看韩国电影| 亚洲精品观看| 日韩视频一区| 久久国产日本精品| 桃色一区二区| 免费在线小视频| 国产黄色精品| 日本亚洲视频| 9久re热视频在线精品| 91日韩免费| 国产精品红桃| 日韩动漫一区| 午夜久久av | 欧美精品国产白浆久久久久| 婷婷成人基地| 精品国产18久久久久久二百| 亚洲精品动态| 香蕉久久夜色精品国产| 欧美天堂视频| а√天堂中文在线资源8| 美女精品久久| 精品国产乱码久久久久久1区2匹| 日韩欧美激情电影|