亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python OpenCV實現(xiàn)邊緣檢測

 更新時間:2021年08月24日 11:23:34   作者:sxqczzxsh  
這篇文章主要為大家詳細(xì)介紹了Python OpenCV實現(xiàn)邊緣檢測,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

1. Sobel 算子檢測

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

對于不連續(xù)的函數(shù),有:

假設(shè)要處理的圖像為I,在兩個方向求導(dǎo)。

水平變化:用奇數(shù)大小的模板對圖像I卷積,結(jié)果為Gx。例如,當(dāng)模板大小為3時,Gx為: 

垂直變化:用奇數(shù)大小的模板對圖像I卷積,結(jié)果為Gy。例如,當(dāng)模板大小為3時,Gy為:

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

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

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

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

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

2. Laplacian 算子檢測

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

不連續(xù)函數(shù)的二階導(dǎo)數(shù)是:

使用的卷積核是:

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

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

3.  Canny 邊緣檢測

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

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

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

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

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

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

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

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

cv.Canny(image, threshold1, threshold2)
參數(shù):
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()

輸出:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python matplotlib修改默認(rèn)字體的操作

    Python matplotlib修改默認(rèn)字體的操作

    這篇文章主要介紹了Python matplotlib修改默認(rèn)字體的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • python如何統(tǒng)計字符串漢字?jǐn)?shù)量

    python如何統(tǒng)計字符串漢字?jǐn)?shù)量

    這篇文章主要介紹了python如何統(tǒng)計字符串漢字?jǐn)?shù)量問題,
    2024-05-05
  • pandas中實現(xiàn)將相同ID的字符串進行合并

    pandas中實現(xiàn)將相同ID的字符串進行合并

    這篇文章主要介紹了pandas中實現(xiàn)將相同ID的字符串進行合并問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Python實用技巧之輕松處理大型文件

    Python實用技巧之輕松處理大型文件

    Python在文件處理方面提供了非常強大的支持,然而,當(dāng)處理大型文件時,標(biāo)準(zhǔn)的文件處理技術(shù)會導(dǎo)致高內(nèi)存使用,所以下面我們就來看看如何在Python中有效地處理大型文件吧
    2024-03-03
  • pycharm中報ModuleNotFoundError:No?module?named?'tensorflow'錯誤解決

    pycharm中報ModuleNotFoundError:No?module?named?'tensor

    這篇文章主要給大家介紹了關(guān)于pycharm中報ModuleNotFoundError:No?module?named?'tensorflow'錯誤的解決方法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • Python關(guān)于sys.argv[]的用法及說明

    Python關(guān)于sys.argv[]的用法及說明

    sys.argv[]是Python中用于從程序外部獲取參數(shù)的列表,參數(shù)索引從0開始,0索引代表腳本名稱本身,后續(xù)索引代表傳遞給腳本的參數(shù),通過指定索引可以獲取特定的參數(shù),如sys.argv[1]獲取第一個傳入?yún)?shù),當(dāng)傳入多個參數(shù)時,可以通過切片或循環(huán)獲取全部參數(shù)
    2024-09-09
  • 在OpenCV里使用Camshift算法的實現(xiàn)

    在OpenCV里使用Camshift算法的實現(xiàn)

    這篇文章主要介紹了在OpenCV里使用Camshift算法的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Python常見報錯解決方案總結(jié)(新手拯救指南)

    Python常見報錯解決方案總結(jié)(新手拯救指南)

    我們再使用python難免會出現(xiàn)各種各樣的報錯,下面這篇文章主要給大家介紹了關(guān)于Python常見報錯解決方案的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • 使用python來玩一次股票代碼詳解

    使用python來玩一次股票代碼詳解

    這篇文章主要介紹了使用python來玩一次股票代碼詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2023-01-01
  • Python查找函數(shù)f(x)=0根的解決方法

    Python查找函數(shù)f(x)=0根的解決方法

    這篇文章主要介紹了Python查找函數(shù)f(x)=0根的解決方法,涉及Python數(shù)學(xué)運算函數(shù)求解的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05

最新評論