国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

OpenCV種支持標準卷積邊緣填充做法

OpenCV學堂 ? 來源:OpenCV學堂 ? 作者:OpenCV學堂 ? 2022-07-12 14:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

概述

OpenCV在使用卷積進行圖像處理過程種,如何處理邊緣像素錨定輸出兩個技術細節一直是很多人求而不得的疑惑。其實OpenCV在做卷積濾波時會對圖像進行邊界填充,實現對邊緣像素的卷積計算的支持,不同填充方式不同錨定點會得到圖像卷積輸出不同的結果。

邊界填充

我們首先來看一下OpenCV種支持標準卷積邊緣填充做法,OpenCV支持的有如下幾種卷積邊緣填充算法:

常量邊界

BORDER_CONSTANT

iiiiii|abcdefgh|iiiiiii

邊界復制

BORDER_REPLICATE

aaaaaa|abcdefgh|hhhhhhh

邊界反射

BORDER_REFLECT

fedcba|abcdefgh|hgfedcb

邊界換行

BORDER_WRAP

cdefgh|abcdefgh|abcdefg

邊界反射101

BORDER_REFLECT_101

gfedcb|abcdefgh|gfedcba

邊界透明-很不幸運的是OpenCV4已經不支持啦!

BORDER_TRANSPARENT

uvwxyz|abcdefgh|ijklmno

默認填充方式

OpenCV中 filter2D, blur, GaussianBlur等卷積操作默認支持為BORDER_DEFAULT(BORDER_REFLECT_101)

各種不同方式對邊緣的填充效果如下:

ad3a60fa-01a9-11ed-ba43-dac502259ad0.jpg

上圖背景為紅色,填充上下左右四個像素大小邊緣!右下角為原圖,左上角圖像為常量邊緣填充效果(i=0黑色)。

相關代碼實現如下:

image=cv.imread("D:/images/qxx.png");
ih,iw=image.shape[:2]
border=4

#邊界填充
b1=cv.copyMakeBorder(image,border,border,border,border,cv.BORDER_CONSTANT)
b2=cv.copyMakeBorder(image,border,border,border,border,cv.BORDER_REPLICATE)
b3=cv.copyMakeBorder(image,border,border,border,border,cv.BORDER_REFLECT)
b4=cv.copyMakeBorder(image,border,border,border,border,cv.BORDER_WRAP)
b5=cv.copyMakeBorder(image,border,border,border,border,cv.BORDER_REFLECT_101)

#邊界填充類型說明
cv.putText(image,"input",(20,20),cv.FONT_HERSHEY_PLAIN,1.0,(255,0,0))
cv.putText(b1,"BORDER_CONSTANT",(20,20),cv.FONT_HERSHEY_PLAIN,1.0,(255,0,0))
cv.putText(b2,"BORDER_REPLICATE",(20,20),cv.FONT_HERSHEY_PLAIN,1.0,(255,0,0))
cv.putText(b3,"BORDER_REFLECT",(20,20),cv.FONT_HERSHEY_PLAIN,1.0,(255,0,0))
cv.putText(b4,"BORDER_WRAP",(20,20),cv.FONT_HERSHEY_PLAIN,1.0,(255,0,0))
cv.putText(b5,"BORDER_REFLECT_101",(20,20),cv.FONT_HERSHEY_PLAIN,1.0,(255,0,0))

#拼接結果輸出
h=b1.shape[0]*2+8
w=b1.shape[1]*3+16
bh,bw=b1.shape[:2]
result=np.zeros([h,w,3],dtype=np.uint8)
result[:,:,:]=(0,0,255)
result[0:bh,0:bw,:]=b1;
result[0:bh,bw+8:bw+bw+8,:]=b2;
result[0:bh,bw+bw+16:bw+bw+bw+16,:]=b3;
result[bh+8:bh+bh+8,0:bw,:]=b4;
result[bh+8:bh+bh+8,bw+8:bw+bw+8,:]=b5;
result[bh+12:bh+12+ih,bw+bw+20:bw+bw+20+iw,:]=image;

#顯示
cv.imshow("result",result)
cv.imwrite("D:/border_result.png",result)
cv.waitKey(0)
cv.destroyAllWindows()

錨定位置

在進行卷積處理的時候,卷積mask與對應的像素塊點乘得到輸出,把輸出結果賦值給哪個像素點是由錨定參數anchor決定,以自定義濾波函數filter2D為例說明

voidcv::filter2D(
InputArraysrc,
OutputArraydst,
intddepth,
InputArraykernel,
Pointanchor=Point(-1,-1),
doubledelta=0,
intborderType=BORDER_DEFAULT
)
其中
kernel - 表示輸入的自定義卷積核大小
anchor - 表示錨定點位置,默認情況Point(-1,-1)表示是卷積核的中心位置
borderType - 表示邊緣填充的像素大小,ksize/2其中ksize表示卷積核大小

上述函數在卷積核為奇數的時候,卷積核的中心位置很容易確定,比如3x3的卷積核大小,中心位置為Point(1,1)5x5的卷積核大小中心位置為Point(2,2)

但是當卷積核大小為偶數的時候,很多人都搞不清楚中心位置是如何確定的,其實這個時候中心也為(ksize/2), 對2x2的卷積核,中心位置為Point(1,1),4x4的卷積核中心位置為Point(2,2)

錨定位置對卷積結果的影響

以2x2與4x4的卷積核為與3x3與5x5的像素數據為例

情況一

2x2卷積核對3x3的像素塊

ad5a1eb8-01a9-11ed-ba43-dac502259ad0.png

ad6c6776-01a9-11ed-ba43-dac502259ad0.png

當錨定點為默認(1,1)/(-1,-1)時候:

ad7e1552-01a9-11ed-ba43-dac502259ad0.png

當錨定點設置為(0,0)時:

ad91dfe2-01a9-11ed-ba43-dac502259ad0.png

可以看到二者的輸出結果全然不同,原因在于當錨定點不同的時候,卷積mask的開始位置也會不不同,圖示如下:

ada20f98-01a9-11ed-ba43-dac502259ad0.jpg

情況二:

4x4卷積核對5x5的像素塊:

adb38278-01a9-11ed-ba43-dac502259ad0.png

使用BORDER_DEFAULT填充方式,填充之后為:

adc6234c-01a9-11ed-ba43-dac502259ad0.png

不同錨定位置的均值卷積輸出結果:

ade1a13a-01a9-11ed-ba43-dac502259ad0.jpg

三個不同錨定點對應卷積mask的起始位置與錨定像素輸出:

adfc7d98-01a9-11ed-ba43-dac502259ad0.jpg

代碼演示如下:

src=np.zeros([3,3],dtype=np.uint8)
src[0,0]=16
src[1,1]=8
src[2,2]=4
print("
inputimage:
",src)

k1=[[1,0],[0,-1]]
print("
kernel:
",k1)
result=cv.copyMakeBorder(src,1,1,1,1,cv.BORDER_DEFAULT)
print("
BORDER_DEFAULT邊界填充:
",result)
dst=cv.filter2D(src,cv.CV_32F,np.asarray(k1),None,anchor=(0,0),borderType=cv.BORDER_DEFAULT)
print("
filter2D:
",dst)
print("
")

src=np.zeros([5,5],dtype=np.uint8)
src[0,0]=32
src[1,1]=16
src[2,2]=8
src[3,3]=4
src[4,4]=2
print("
input:
",src)
k2=np.ones([4,4],dtype=np.int32)
print("
kernel:
",k2)
result=cv.copyMakeBorder(src,3,3,3,3,cv.BORDER_DEFAULT)
print("
邊界填充:
",result)
dst=cv.filter2D(src,cv.CV_32F,np.asarray(k2),None,anchor=(-1,-1),borderType=cv.BORDER_DEFAULT)
print("
filter2DResult:
",dst)

原文標題:詳解OpenCV卷積濾波之邊緣處理與錨定輸出

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

審核編輯:彭靜

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

    關注

    3

    文章

    4417

    瀏覽量

    67504
  • 代碼
    +關注

    關注

    30

    文章

    4968

    瀏覽量

    73960
  • OpenCV
    +關注

    關注

    33

    文章

    652

    瀏覽量

    44787

原文標題:詳解OpenCV卷積濾波之邊緣處理與錨定輸出

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    沒有專利的opencv-python 版本

    opencv-python==3.4.15.55 -i https://pypi.tuna.tsinghua.edu.cn/simple 注意:3.4.x 核心版同樣無專利風險,但僅支持 Python
    發表于 12-13 12:37

    卷積運算分析

    卷積運算的基礎運算是乘加運算(MAC,Multiplication and Accumulation),本文設計了基本運算單元PE模塊來實現MAC運算。對于卷積運算而言,一次性至少處理一個感受域規模
    發表于 10-28 07:31

    NMSIS庫的使用

    nmsis core、nmsis dsp和nmsis nn三個組件,分別提供了對處理器核心和外設、數字信號處理庫和神經網絡內核的支持。 卷積、激活、池化是卷積神經網絡中常用的三操作,
    發表于 10-24 09:58

    機器視覺雙雄YOLO 和 OpenCV 到底有啥區別?別再傻傻分不清!

    很多人一聽到 “YOLO”和“OpenCV” ,總以為它們是同一東西。其實, 一個是AI算法,一個是視覺工具庫;一個會“識別”,一個會“處理” 。本文帶你深入了解兩者的核心區別與協同關系,以及它們
    的頭像 發表于 10-14 16:00 ?1258次閱讀
    機器視覺雙雄YOLO 和 <b class='flag-5'>OpenCV</b> 到底有啥區別?別再傻傻分不清!

    零成本鋼鐵俠手套!樹莓派+OpenCV 秒變手勢遙控器!

    大家好,這是一個樹莓派和OpenCV的連載專題。使用樹莓派與OpenCV實現姿態估計和面部特征點追蹤使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統使用樹莓派和OpenCV實現手部
    的頭像 發表于 08-16 16:16 ?1270次閱讀
    零成本鋼鐵俠手套!樹莓派+<b class='flag-5'>OpenCV</b> 秒變手勢遙控器!

    如何使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統?

    大家好,這是一個樹莓派和OpenCV的連載專題。使用樹莓派與OpenCV實現姿態估計和面部特征點追蹤使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統使用樹莓派和OpenCV實現手部
    的頭像 發表于 08-14 17:45 ?1572次閱讀
    如何使用樹莓派與<b class='flag-5'>OpenCV</b>實現面部和運動追蹤的云臺系統?

    如何使用樹莓派+OpenCV實現姿態估計和面部特征點追蹤?

    大家好,這是一個樹莓派和OpenCV的連載專題。使用樹莓派與OpenCV實現姿態估計和面部特征點追蹤使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統使用樹莓派和OpenCV實現手部
    的頭像 發表于 08-13 17:44 ?1308次閱讀
    如何使用樹莓派+<b class='flag-5'>OpenCV</b>實現姿態估計和面部特征點追蹤?

    AI 邊緣計算網關:開啟智能新時代的鑰匙?—龍興物聯

    智能化決策的關鍵。卷積神經網絡在圖像識別方面表現卓越,在智能工廠產品質量檢測中,能快速準確識別產品缺陷;循環神經網絡擅長處理時間序列數據,可對設備故障進行精準預測。 在通信技術與協議支持上,AI 邊緣
    發表于 08-09 16:40

    邊緣計算網關支持斷點續傳嗎

    邊緣計算網關通常支持斷點續傳功能 。斷點續傳功能是邊緣計算網關的重要特性之一,它能夠在網絡中斷或設備故障時,將采集到的數據暫存在本地存儲空間中,待網絡恢復后再將數據上傳至云平臺,從而保證數據的完整性
    的頭像 發表于 05-27 15:25 ?772次閱讀

    溝槽填充技術介紹

    圖2.2是現代CMOS 器件剖面的示意圖。一般來說,水平方向的尺寸微縮幅度比垂直方向的幅度更大,這將導致溝槽(包含接觸孔)的深寬比(aspect ratio)也隨之提高,為避免溝槽填充過程中產生空穴
    的頭像 發表于 05-21 17:50 ?1524次閱讀
    溝槽<b class='flag-5'>填充</b>技術介紹

    漢思新材料HS711板卡級芯片底部填充封裝膠

    漢思新材料HS711是一專為板卡級芯片底部填充封裝設計的膠水。HS711填充膠主要用于電子封裝領域,特別是在半導體封裝中,以提供機械支撐、應力緩沖和保護芯片與基板之間的連接免受環境因素的影響。漢思
    的頭像 發表于 04-11 14:24 ?1046次閱讀
    漢思新材料HS711板卡級芯片底部<b class='flag-5'>填充</b>封裝膠

    芯片底部填充填充不飽滿或滲透困難原因分析及解決方案

    芯片底部填充膠(Underfill)在封裝工藝中若出現填充不飽滿或滲透困難的問題,可能導致芯片可靠性下降(如熱應力失效、焊點開裂等)。以下是系統性原因分析與解決方案:一、原因分析1.材料特性問題膠水
    的頭像 發表于 04-03 16:11 ?1705次閱讀
    芯片底部<b class='flag-5'>填充</b>膠<b class='flag-5'>填充</b>不飽滿或滲透困難原因分析及解決方案

    多協議邊緣計算網關EG8200-新升級-支持99%PLC協議 #plc #物聯網

    邊緣計算
    成都縱橫智控科技
    發布于 :2025年03月13日 17:14:18

    如何使用MATLAB實現一維時間卷積網絡

    本文對一維卷積操作進行介紹,包括一維擴展卷積和一維因果卷積,以及 MATLAB 對一維卷積支持情況。在最后通過一個實例演示如何在 MATL
    的頭像 發表于 03-07 09:15 ?2108次閱讀
    如何使用MATLAB實現一維時間<b class='flag-5'>卷積</b>網絡

    請問OpenVINO?工具套件是否支持使用非對稱卷積支持模型?

    無法確定使用非對稱卷積的模型是否受 OpenVINO? Toolkit 的支持
    發表于 03-06 07:58