<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何在OpenCV中使用基于深度學習的邊緣檢測?

INDEMIND ? 來源:INDEMIND ? 作者:INDEMIND ? 2023-05-19 09:52 ? 次閱讀

在這篇文章中,我們將學習如何在OpenCV中使用基于深度學習的邊緣檢測,它比目前流行的canny邊緣檢測器更精確。邊緣檢測在許多用例中是有用的,如視覺顯著性檢測,目標檢測,跟蹤和運動分析,結構從運動,3D重建,自動駕駛,圖像到文本分析等等。

01 什么是邊緣檢測?

邊緣檢測是計算機視覺中一個非常古老的問題,它涉及到檢測圖像中的邊緣來確定目標的邊界,從而分離感興趣的目標。最流行的邊緣檢測技術之一是Canny邊緣檢測,它已經成為大多數計算機視覺研究人員和實踐者的首選方法。讓我們快速看一下Canny邊緣檢測。

02 Canny邊緣檢測算法

1983年,John Canny在麻省理工學院發明了Canny邊緣檢測。它將邊緣檢測視為一個信號處理問題。其核心思想是,如果你觀察圖像中每個像素的強度變化,它在邊緣的時候非常高。

在下面這張簡單的圖片中,強度變化只發生在邊界上。所以,你可以很容易地通過觀察像素強度的變化來識別邊緣。

627d3b08-f575-11ed-90ce-dac502259ad0.png

現在,看下這張圖片。強度不是恒定的,但強度的變化率在邊緣處最高。(微積分復習:變化率可以用一階導數(梯度)來計算。)

62856076-f575-11ed-90ce-dac502259ad0.png

Canny邊緣檢測器通過4步來識別邊緣:

去噪:因為這種方法依賴于強度的突然變化,如果圖像有很多隨機噪聲,那么會將噪聲作為邊緣。所以,使用5×5的高斯濾波器平滑你的圖像是一個非常好的主意。

梯度計算:下一步,我們計算圖像中每個像素的強度的梯度(強度變化率)。我們也計算梯度的方向。

628aea96-f575-11ed-90ce-dac502259ad0.png

梯度方向垂直于邊緣,它被映射到四個方向中的一個(水平、垂直和兩個對角線方向)

非極大值抑制:現在,我們想刪除不是邊緣的像素(設置它們的值為0)。你可能會說,我們可以簡單地選取梯度值最高的像素,這些就是我們的邊。然而,在真實的圖像中,梯度不是簡單地在只一個像素處達到峰值,而是在臨近邊緣的像素處都非常高。因此我們在梯度方向上取3×3附近的局部最大值。

628f5892-f575-11ed-90ce-dac502259ad0.png

遲滯閾值化:在下一步中,我們需要決定一個梯度的閾值,低于這個閾值所有的像素都將被抑制(設置為0)。而Canny邊緣檢測器則采用遲滯閾值法。遲滯閾值法是一種非常簡單而有效的方法。我們使用兩個閾值來代替只用一個閾值:

高閾值 = 選擇一個非常高的值,這樣任何梯度值高于這個值的像素都肯定是一個邊緣。

低閾值 = 選擇一個非常低的值,任何梯度值低于該值的像素絕對不是邊緣。

在這兩個閾值之間有梯度的像素會被檢查,如果它們和邊緣相連,就會留下,否則就會去掉。

629463aa-f575-11ed-90ce-dac502259ad0.jpg

遲滯閾值化

03

Canny 邊緣檢測的問題:

由于Canny邊緣檢測器只關注局部變化,沒有語義(理解圖像的內容)理解,精度有限(很多時候是這樣)。

Canny邊緣檢測器在這種情況下會失敗,因為沒有理解圖像的上下文

語義理解對于邊緣檢測是至關重要的,這就是為什么使用機器學習或深度學習的基于學習的檢測器比canny邊緣檢測器產生更好的結果。

04 OpenCV中基于深度學習的邊緣檢測

OpenCV在其全新的DNN模塊中集成了基于深度學習的邊緣檢測技術。你需要OpenCV 3.4.3或更高版本。這種技術被稱為整體嵌套邊緣檢測或HED,是一種基于學習的端到端邊緣檢測系統,使用修剪過的類似vgg的卷積神經網絡進行圖像到圖像的預測任務。

HED利用了中間層的輸出。之前的層的輸出稱為side output,將所有5個卷積層的輸出進行融合,生成最終的預測。由于在每一層生成的特征圖大小不同,它可以有效地以不同的尺度查看圖像。

62a1899a-f575-11ed-90ce-dac502259ad0.png

網絡結構:整體嵌套邊緣檢測

HED方法不僅比其他基于深度學習的方法更準確,而且速度也比其他方法快得多。這就是為什么OpenCV決定將其集成到新的DNN模塊中。以下是這篇論文的結果:

62aaff8e-f575-11ed-90ce-dac502259ad0.png

05 在OpenCV中訓練深度學習邊緣檢測的代碼

OpenCV使用的預訓練模型已經在Caffe框架中訓練過了,可以這樣加載:

shdownload_pretrained.sh

網絡中有一個crop層,默認是沒有實現的,所以我們需要自己實現一下。

wKgaomRm1uGAJ7HRAADz-LOEw_w207.jpg

現在,我們可以重載這個類,只需用一行代碼注冊該層。

cv.dnn_registerLayer('Crop',CropLayer)

現在,我們準備構建網絡圖并加載權重,這可以通過OpenCV的dnn.readNe函數。

net=cv.dnn.readNet(args.prototxt,args.caffemodel)

現在,下一步是批量加載圖像,并通過網絡運行它們。為此,我們使用cv2.dnn.blobFromImage方法。該方法從輸入圖像中創建四維blob。

blob=cv.dnn.blobFromImage(image,scalefactor,size,mean,swapRB,crop)

其中:

image:是我們想要發送給神經網絡進行推理的輸入圖像。

scalefactor:圖像縮放常數,很多時候我們需要把uint8的圖像除以255,這樣所有的像素都在0到1之間。默認值是1.0,不縮放。

size:輸出圖像的空間大小。它將等于后續神經網絡作為blobFromImage輸出所需的輸入大小。

swapRB:布爾值,表示我們是否想在3通道圖像中交換第一個和最后一個通道。OpenCV默認圖像為BGR格式,但如果我們想將此順序轉換為RGB,我們可以將此標志設置為True,這也是默認值。

mean:為了進行歸一化,有時我們計算訓練數據集上的平均像素值,并在訓練過程中從每幅圖像中減去它。如果我們在訓練中做均值減法,那么我們必須在推理中應用它。這個平均值是一個對應于R, G, B通道的元組。例如Imagenet數據集的均值是R=103.93, G=116.77, B=123.68。如果我們使用swapRB=False,那么這個順序將是(B, G, R)。

crop:布爾標志,表示我們是否想居中裁剪圖像。如果設置為True,則從中心裁剪輸入圖像時,較小的尺寸等于相應的尺寸,而其他尺寸等于或大于該尺寸。然而,如果我們將其設置為False,它將保留長寬比,只是將其調整為固定尺寸大小。

在我們這個場景下:

inp=cv.dnn.blobFromImage(frame,scalefactor=1.0,size=(args.width,args.height),

mean=(104.00698793,116.66876762,122.67891434),swapRB=False,

crop=False)

現在,我們只需要調用一下前向方法。

wKgZomRm1ySAZhH3AABT1sXeocQ395.jpg

結果:

審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 邊緣檢測
    +關注

    關注

    0

    文章

    91

    瀏覽量

    18131
  • OpenCV
    +關注

    關注

    29

    文章

    612

    瀏覽量

    40890
  • 深度學習
    +關注

    關注

    73

    文章

    5260

    瀏覽量

    120117
  • 高斯濾波器
    +關注

    關注

    0

    文章

    9

    瀏覽量

    1711
  • dnn
    dnn
    +關注

    關注

    0

    文章

    56

    瀏覽量

    8975

原文標題:干貨丨在OpenCV中基于深度學習的邊緣檢測

文章出處:【微信號:gh_c87a2bc99401,微信公眾號:INDEMIND】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Rayeager PX2開發板測試opencv邊緣檢測效果

    ``Rayeager PX2開發板測試opencv邊緣檢測效果,運算速率測試因為沒法加鏈接,所以視頻請在優酷搜索標題名稱,更多詳情大家可以在芯客網論壇查看,謝謝!``
    發表于 01-14 15:20

    【DragonBoard 410c試用體驗】之OpenCV中canny算子邊緣檢測

    `具體介紹之前,先來一起看看邊緣檢測的一般步驟 濾波:邊緣檢測的算法主要是基于圖像強度的一階和二階導數,但導數通常對噪聲很敏感,因此必須采用濾波器來改善與噪聲有關的
    發表于 09-11 23:24

    openCV邊緣檢測原理是什么?

    openCV是通過什么原理來實現邊緣檢測
    發表于 10-10 06:21

    OpenCV3編程入門-源碼例程全集-canny邊緣檢測

    OpenCV3編程入門-源碼例程全集-canny邊緣檢測,感興趣的小伙伴們可以瞧一瞧。
    發表于 09-18 16:27 ?2次下載

    邊緣檢測綜合示例_OpenCV3編程入門-源碼例程

    OpenCV3編程入門-源碼例程全集-邊緣檢測綜合示例,感興趣的小伙伴們可以瞧一瞧。
    發表于 09-18 17:02 ?0次下載

    在Vivado中如何實現OpenCV設計

    觀看視頻,了解OpenCV庫和其在一些典型應用中的使用,以及Zynq-7000 SoC的優點和如何實現OpenCV設計。同時您還能學習到如何在設計流程
    的頭像 發表于 11-20 06:46 ?3720次閱讀

    何在您選擇的邊緣計算框架中使用EdgeScale

    如何使用EdgeScale管理一組異構邊緣計算節點,以及如何在您選擇的邊緣計算框架(AWS Greengrass、Azure IoT Edge等)中使用EdgeScale。
    的頭像 發表于 01-23 07:06 ?2285次閱讀
    如<b class='flag-5'>何在</b>您選擇的<b class='flag-5'>邊緣</b>計算框架<b class='flag-5'>中使</b>用EdgeScale

    什么是邊緣檢測?邊緣檢測的算法由來

    在這篇文章中,我們將學習何在OpenCV中使用基于深度學習
    的頭像 發表于 03-12 10:00 ?8295次閱讀

    何在OpenCV中使用基于深度學習邊緣檢測

    邊緣檢測是計算機視覺中一個非常古老的問題,它涉及到檢測圖像中的邊緣來確定目標的邊界,從而分離感興趣的目標。最流行的邊緣
    的頭像 發表于 04-18 10:25 ?1649次閱讀
    如<b class='flag-5'>何在</b><b class='flag-5'>OpenCV</b><b class='flag-5'>中使</b>用基于<b class='flag-5'>深度</b><b class='flag-5'>學習</b>的<b class='flag-5'>邊緣</b><b class='flag-5'>檢測</b>

    OpenCV使用深度學習邊緣檢測的流程

    導讀 分析了Canny的優劣,并給出了OpenCV使用深度學習邊緣檢測的流程。 在這篇文章中,我們將
    的頭像 發表于 05-08 11:05 ?2042次閱讀
    <b class='flag-5'>OpenCV</b>使用<b class='flag-5'>深度</b><b class='flag-5'>學習</b>做<b class='flag-5'>邊緣</b><b class='flag-5'>檢測</b>的流程

    在MFC中使OpenCV的教程下載

    在MFC中使OpenCV的教程下載
    發表于 06-26 14:35 ?2次下載

    何在OpenCV中實現CUDA加速

    OpenCV4.x中關于CUDA加速的內容主要有兩個部分,第一部分是之前OpenCV支持的圖像處理與對象檢測傳統算法的CUDA加速;第二部分是OpenCV4.2版本之后開始支持的針對
    的頭像 發表于 09-05 10:03 ?4707次閱讀

    何在OpenCV中使用基于深度學習邊緣檢測?

    邊緣檢測是計算機視覺中一個非常古老的問題,它涉及到檢測圖像中的邊緣來確定目標的邊界,從而分離感興趣的目標。
    的頭像 發表于 05-18 10:10 ?688次閱讀
    如<b class='flag-5'>何在</b><b class='flag-5'>OpenCV</b><b class='flag-5'>中使</b>用基于<b class='flag-5'>深度</b><b class='flag-5'>學習</b>的<b class='flag-5'>邊緣</b><b class='flag-5'>檢測</b>?

    何在深度學習結構中使用紋理特征

    來源:AI公園,作者:TraptiKalra編譯:ronghuaiyang導讀這是前一篇文章的繼續,在這篇文章中,我們將討論紋理分析在圖像分類中的重要性,以及如何在深度學習中使用紋理分
    的頭像 發表于 10-10 09:15 ?742次閱讀
    如<b class='flag-5'>何在</b><b class='flag-5'>深度</b><b class='flag-5'>學習</b>結構<b class='flag-5'>中使</b>用紋理特征

    OpenCV庫在圖像處理和深度學習中的應用

    本文深入淺出地探討了OpenCV庫在圖像處理和深度學習中的應用。從基本概念和操作,到復雜的圖像變換和深度學習模型的使用,文章以詳盡的代碼和解
    的頭像 發表于 08-18 11:33 ?572次閱讀
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>