婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python OpenCV實現邊緣檢測

Python OpenCV實現邊緣檢測

熱門標簽:宿遷星美防封電銷卡 湛江智能外呼系統廠家 地圖標注審核表 西藏房產智能外呼系統要多少錢 外呼并發線路 百度地圖標注沒有了 長沙高頻外呼系統原理是什么 ai電銷機器人源碼 ai電話機器人哪里好

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

1. Sobel 算子檢測

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

對于不連續的函數,有:

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

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

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

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

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

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

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 使用二階導數來檢測邊緣。 因為圖像是二維的,所以我們需要從兩個方向求導:

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

使用的卷積核是:

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)求出邊界的梯度和方向,公式如下:

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

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

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

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

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

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

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

import matplotlib
import cv2 as cv
import matplotlib.pyplot as plt
 
font = {
    "family": "Microsoft YaHei"
}
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 = cv.Canny(img, 0, 100)
plt.imshow(res, cmap=plt.cm.gray)
plt.title("Canny")
plt.show()

輸出:

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

您可能感興趣的文章:
  • OpenCV中Canny邊緣檢測的實現
  • Python實現Opencv cv2.Canny()邊緣檢測
  • 使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測
  • OpenCV實現灰度、高斯模糊、邊緣檢測的示例
  • Python使用Opencv實現邊緣檢測以及輪廓檢測的實現
  • 如何利用Python 進行邊緣檢測
  • python實現canny邊緣檢測
  • OpenCV半小時掌握基本操作之邊緣檢測

標簽:寧夏 漯河 大同 海南 盤錦 普洱 南平 林芝

巨人網絡通訊聲明:本文標題《Python OpenCV實現邊緣檢測》,本文關鍵詞  Python,OpenCV,實現,邊緣,檢測,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python OpenCV實現邊緣檢測》相關的同類信息!
  • 本頁收集關于Python OpenCV實現邊緣檢測的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲444eee在线观看| 亚洲欧美电影院| 国内精品国产三级国产a久久| 国产日韩欧美制服另类| 欧美日韩精品高清| 国产成人免费高清| 日本亚洲视频在线| 亚洲国产视频网站| 国产精品国产三级国产aⅴ原创| 欧美一区二区网站| 一本一道综合狠狠老| 成人美女视频在线观看18| 另类小说综合欧美亚洲| 午夜精品久久一牛影视| 伊人婷婷欧美激情| 最新高清无码专区| 亚洲美女区一区| 亚洲伦在线观看| 亚洲女性喷水在线观看一区| 国产精品理伦片| 国产精品理论片在线观看| 国产蜜臀97一区二区三区| 国产三级三级三级精品8ⅰ区| 日韩欧美高清在线| 日韩三级电影网址| 久久蜜桃香蕉精品一区二区三区| 精品国产一区二区三区忘忧草| 欧美一区欧美二区| 欧美变态tickle挠乳网站| 精品久久久久久久久久久院品网 | 欧美色涩在线第一页| 99国产精品久久久久久久久久 | 精品999久久久| 26uuuu精品一区二区| 国产人妖乱国产精品人妖| 国产女主播在线一区二区| 国产精品乱码一区二三区小蝌蚪| 亚洲精品中文在线| 亚洲成av人影院在线观看网| 美女国产一区二区三区| 国产伦精一区二区三区| 狠狠色丁香婷婷综合久久片| 成人免费视频播放| 一本色道久久综合亚洲91| 精品视频色一区| 久久久久国产精品厨房| 亚洲一区二区视频| 精品无人区卡一卡二卡三乱码免费卡| 丁香五精品蜜臀久久久久99网站| 欧美主播一区二区三区| 久久久久久久久99精品| 一区二区在线观看视频| 久久国产欧美日韩精品| 91免费观看视频| 欧美精品一区男女天堂| 一区二区三区中文字幕精品精品 | 日韩高清一级片| 国产精品99久久久久久久vr| 在线观看中文字幕不卡| 久久亚区不卡日本| 亚洲国产精品自拍| 粉嫩13p一区二区三区| 在线免费亚洲电影| 欧美激情在线免费观看| 亚洲第一激情av| 北条麻妃一区二区三区| 日韩美女视频在线| 一区二区不卡在线播放| 国产盗摄视频一区二区三区| 9191成人精品久久| 亚洲蜜桃精久久久久久久| 国产精品亚洲人在线观看| 欧美日韩国产乱码电影| 中文字幕日韩av资源站| 国产一区二区免费在线| 91精品久久久久久久99蜜桃| 一区二区三区在线影院| 国产久卡久卡久卡久卡视频精品| 欧美日韩成人在线| 亚洲精品国产精品乱码不99| jlzzjlzz国产精品久久| 国产亚洲一本大道中文在线| 日本不卡的三区四区五区| 欧美午夜电影一区| 一区二区三区自拍| 色婷婷av久久久久久久| 一区在线播放视频| 北岛玲一区二区三区四区 | 亚洲一区二区欧美激情| 91美女精品福利| 亚洲欧美在线视频| 国产福利精品一区| 国产亚洲一区二区三区四区| 国产在线日韩欧美| 久久久久久久电影| 国产精品18久久久久久久久久久久| 日韩午夜三级在线| 激情综合网av| 国产亚洲一区二区在线观看| 福利一区福利二区| 国产精品美女视频| 91蜜桃在线免费视频| 亚洲一二三四区不卡| 欧美性受xxxx黑人xyx性爽| 亚洲电影你懂得| 在线播放中文一区| 久久精品免费观看| 中文字幕免费一区| 在线观看日韩高清av| 五月婷婷综合激情| 日韩精品专区在线| 国产69精品久久99不卡| 国产精品久久久久永久免费观看| 99久久婷婷国产精品综合| 亚洲一区二区视频| 欧美大片在线观看一区| 成人精品一区二区三区中文字幕| 尤物在线观看一区| 精品入口麻豆88视频| 不卡视频一二三四| 日韩av午夜在线观看| 国产亚洲人成网站| 欧美性猛交xxxxxxxx| 韩国欧美一区二区| 一区二区三区四区在线| 日韩欧美中文字幕精品| 91在线免费看| 青青草国产成人99久久| 中文字幕免费一区| 91精品国产欧美日韩| 国产超碰在线一区| 无码av免费一区二区三区试看| 欧美xxxx在线观看| 日本韩国欧美在线| 国产资源在线一区| 亚洲成人资源在线| 中文字幕欧美三区| 日韩午夜在线影院| 91福利视频网站| 国产91精品一区二区| 美女在线观看视频一区二区| 亚洲人成网站在线| 久久久久88色偷偷免费| 欧美猛男超大videosgay| av电影一区二区| 国产一区二区在线视频| 亚洲中国最大av网站| 中文一区一区三区高中清不卡| 91麻豆精品国产91久久久久久久久 | 欧美日韩一区二区电影| 国产成人在线网站| 美女尤物国产一区| 亚洲国产综合在线| 亚洲天天做日日做天天谢日日欢 | 一区二区三区在线视频播放| 亚洲精品在线电影| 欧美一区二区三区在线视频| 91九色02白丝porn| 成人免费看视频| 国产高清亚洲一区| 激情深爱一区二区| 国产人伦精品一区二区| 亚洲精品一线二线三线| 欧美一区二区观看视频| 欧美三级资源在线| 色噜噜狠狠一区二区三区果冻| 福利视频网站一区二区三区| 激情文学综合丁香| 经典一区二区三区| 裸体健美xxxx欧美裸体表演| 一区二区三区 在线观看视频| 国产精品色一区二区三区| 久久九九国产精品| 国产欧美日韩卡一| 久久精品人人做人人爽人人| 久久精品免视看| 国产精品嫩草影院av蜜臀| 国产拍揄自揄精品视频麻豆| 久久久久久久久久久久久久久99| 久久伊99综合婷婷久久伊| 精品欧美一区二区三区精品久久 | www.av精品| 色综合婷婷久久| 色天使色偷偷av一区二区| 色诱亚洲精品久久久久久| 91麻豆国产福利在线观看| 在线观看国产91| 欧美亚洲愉拍一区二区| 欧美猛男男办公室激情| 日韩欧美资源站| 久久精品一区四区| 亚洲人123区| 午夜精品视频在线观看| 久久激情综合网| 不卡电影一区二区三区| 色综合色狠狠综合色| 欧美日韩小视频| 亚洲精品在线免费观看视频| 中文字幕中文字幕一区| 一级女性全黄久久生活片免费|