日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【OpenCV 例程200篇】90. 频率域陷波滤波器

發(fā)布時間:2025/3/15 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【OpenCV 例程200篇】90. 频率域陷波滤波器 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

【OpenCV 例程200篇】90. 頻率域陷波濾波器

歡迎關注 『OpenCV 例程200篇』 系列,持續(xù)更新中
歡迎關注 『Python小白的OpenCV學習課』 系列,持續(xù)更新中


5.2 陷波濾波器 (Notch Filter)

陷波濾波器阻止或通過預定的頻率矩形鄰域中的頻率,是重要的選擇性濾波器。

陷波濾波器可以在某一個頻率點迅速衰減輸入信號,以達到阻礙此頻率信號通過的濾波效果的濾波器。陷波濾波器屬于帶阻濾波器的一種,它的阻帶非常狹窄,起階數必須是二階(含二階)以上。

零相移濾波器必須給予原點(頻率矩形中心)對稱,因此中心為 (u0,v0)(u_0,v_0)(u0?,v0?) 的陷波濾波器傳遞函數在 (?u0,?v0)(-u_0, -v_0)(?u0?,?v0?) 位置必須有一個對應的陷波。

陷波帶阻濾波器的傳遞函數可以用中心已被平移到陷波濾波器中心的高通濾波器的乘積來構造 :
HNR(u,v)=∏k=1QHk(u,v)H?k(u,v)H_{NR}(u,v) = \prod_{k=1}^Q H_k(u,v) H_{-k}(u,v) HNR?(u,v)=k=1Q?Hk?(u,v)H?k?(u,v)

其中,濾波器的距離計算公式為:
Dk(u,v)=(u?M/2?uk)2+(v?N/2?vk)2D?k(u,v)=(u?M/2+uk)2+(v?N/2+vk)2D_k(u,v) = \sqrt{(u-M/2-u_k)^2 + (v-N/2-v_k)^2} \\ D_{-k}(u,v) = \sqrt{(u-M/2+u_k)^2 + (v-N/2+v_k)^2} Dk?(u,v)=(u?M/2?uk?)2+(v?N/2?vk?)2?D?k?(u,v)=(u?M/2+uk?)2+(v?N/2+vk?)2?
于是,3 階巴特沃斯陷波帶阻濾波器為:
HNR(u,v)=∏k=13[11+[D0k/Dk(u,v)]n][11+[D?k/Dk(u,v)]n]H_{NR}(u,v) = \prod_{k=1}^3 [\frac{1}{1+[D_{0k}/D_k(u,v)]^n}] [\frac{1}{1+[D_{-k}/D_k(u,v)]^n}] HNR?(u,v)=k=13?[1+[D0k?/Dk?(u,v)]n1?][1+[D?k?/Dk?(u,v)]n1?]
陷波帶通濾波器的傳遞函數可用陷波帶阻濾波器得到:
HNP(u,v)=1?HNR(u,v)H_{NP}(u,v) = 1 - H_{NR}(u,v) HNP?(u,v)=1?HNR?(u,v)


例程 8.29 使用陷波濾波刪除數字化印刷圖像中的莫爾模式

本例使用陷波濾波降低數字化印刷圖像中的莫爾波紋。

摩爾紋是差拍原理的表現(xiàn)。兩個頻率接近的等幅正弦波疊加后,信號幅度將按照兩個頻率之差變化。如果感光元件像素的空間頻率與影像中條紋的空間頻率接近,就會產生摩爾紋。

陷波濾波是選擇性的修改DFT的局部區(qū)域。典型的處理方法是交互式操作,直接用鼠標在傅里葉頻譜中選擇矩形區(qū)域,找出最大值點作為 (uk,vk)。為了簡化程序,本例程刪除了鼠標交互部分,只保留了給出 (uk,vk) 后的濾波處理過程。

# OpenCVdemo08.py # Demo08 of OpenCV # 8. 圖像的頻率域濾波 # Copyright 2021 Youcans, XUPT # Crated:2021-12-30 # 例程 8.29 使用陷波濾波刪除數字化印刷圖像中的莫爾模式def gaussLowPassFilter(shape, radius=10): # 高斯低通濾波器u, v = np.mgrid[-1:1:2.0 / shape[0], -1:1:2.0 / shape[1]]D = np.sqrt(u ** 2 + v ** 2)D0 = radius / shape[0]kernel = np.exp(- (D ** 2) / (2 * D0 ** 2))return kerneldef butterworthNRFilter(shape, radius=9, uk=60, vk=80, n=2): # 巴特沃斯陷波帶阻濾波器M, N = shape[1], shape[0]u, v = np.meshgrid(np.arange(M), np.arange(N))Dm = np.sqrt((u - M // 2 - uk) ** 2 + (v - N // 2 - vk) ** 2)Dp = np.sqrt((u - M // 2 + uk) ** 2 + (v - N // 2 + vk) ** 2)D0 = radiusn2 = n * 2kernel = (1 / (1 + (D0 / (Dm + 1e-6)) ** n2)) * (1 / (1 + (D0 / (Dp + 1e-6)) ** n2))return kerneldef imgFrequencyFilter(img, lpTyper="GaussLP", radius=10):normalize = lambda x: (x - x.min()) / (x.max() - x.min() + 1e-8)# (1) 邊緣填充imgPad = np.pad(img, ((0, img.shape[0]), (0, img.shape[1])), mode="reflect")# (2) 中心化: f(x,y) * (-1)^(x+y)mask = np.ones(imgPad.shape)mask[1::2, ::2] = -1mask[::2, 1::2] = -1imgPadCen = imgPad * mask# (3) 傅里葉變換fft = np.fft.fft2(imgPadCen)# (4) 構建 頻域濾波器傳遞函數:if lpTyper == "GaussLP":print(lpTyper)freFilter = gaussLowPassFilter(imgPad.shape, radius=60)elif lpTyper == "GaussHP":freFilter = gaussLowPassFilter(imgPad.shape, radius=60)elif lpTyper == "ButterworthNR":print(lpTyper)freFilter = butterworthNRFilter(imgPad.shape, radius=9, uk=60, vk=80, n=2) # 巴特沃斯陷波帶阻濾波器elif lpTyper == "MButterworthNR":print(lpTyper)BNRF1 = butterworthNRFilter(imgPad.shape, radius=9, uk=60, vk=80, n=2) # 巴特沃斯陷波帶阻濾波器BNRF2 = butterworthNRFilter(imgPad.shape, radius=9, uk=-60, vk=80, n=2)BNRF3 = butterworthNRFilter(imgPad.shape, radius=9, uk=60, vk=160, n=2)BNRF4 = butterworthNRFilter(imgPad.shape, radius=9, uk=-60, vk=160, n=2)freFilter = BNRF1 * BNRF2 * BNRF3 * BNRF4else:print("Error of unknown filter")return -1# (5) 在頻率域修改傅里葉變換: 傅里葉變換 點乘 濾波器傳遞函數freTrans = fft * freFilter# (6) 傅里葉反變換ifft = np.fft.ifft2(freTrans)# (7) 去中心化反變換的圖像M, N = img.shape[:2]mask2 = np.ones(imgPad.shape)mask2[1::2, ::2] = -1mask2[::2, 1::2] = -1ifftCenPad = ifft.real * mask2# (8) 截取左上角,大小和輸入圖像相等imgFilter = ifftCenPad[:M, :N]imgFilter = np.clip(imgFilter, 0, imgFilter.max())imgFilter = np.uint8(normalize(imgFilter) * 255)return imgFilter# 使用陷波濾波刪除數字化印刷圖像中的莫爾模式# (1) 讀取原始圖像img = cv2.imread("../images/Fig0464a.tif", flags=0) # flags=0 讀取為灰度圖像fig = plt.figure(figsize=(10, 5))plt.subplot(141), plt.title("Original"), plt.axis('off'), plt.imshow(img, cmap='gray')# (2) 圖像高斯低通濾波imgGLPF = imgFrequencyFilter(img, lpTyper="GaussLP", radius=30) # 圖像高斯低通濾波plt.subplot(142), plt.title("GaussLP filter"), plt.axis('off'), plt.imshow(imgGLPF, cmap='gray')# (3) 圖像巴特沃斯陷波帶阻濾波imgBNRF = imgFrequencyFilter(img, lpTyper="ButterworthNR", radius=9)plt.subplot(143), plt.title("ButterworthNR filter"), plt.axis('off'), plt.imshow(imgBNRF, cmap='gray')# (4) 疊加巴特沃斯陷波帶阻濾波imgSBNRF = imgFrequencyFilter(img, lpTyper="MButterworthNR", radius=9)plt.subplot(144), plt.title("Superimposed BNRF"), plt.axis('off'), plt.imshow(imgSBNRF, cmap='gray')plt.tight_layout()plt.show()


(本節(jié)完)


版權聲明:

youcans@xupt 原創(chuàng)作品,轉載必須標注原文鏈接

Copyright 2021 youcans, XUPT

Crated:2022-2-1


歡迎關注 『OpenCV 例程200篇』 系列,持續(xù)更新中
歡迎關注 『Python小白的OpenCV學習課』 系列,持續(xù)更新中

【OpenCV 例程200篇】01. 圖像的讀取(cv2.imread)
【OpenCV 例程200篇】02. 圖像的保存(cv2.imwrite)
【OpenCV 例程200篇】03. 圖像的顯示(cv2.imshow)
【OpenCV 例程200篇】04. 用 matplotlib 顯示圖像(plt.imshow)
【OpenCV 例程200篇】05. 圖像的屬性(np.shape)
【OpenCV 例程200篇】06. 像素的編輯(img.itemset)
【OpenCV 例程200篇】07. 圖像的創(chuàng)建(np.zeros)
【OpenCV 例程200篇】08. 圖像的復制(np.copy)
【OpenCV 例程200篇】09. 圖像的裁剪(cv2.selectROI)
【OpenCV 例程200篇】10. 圖像的拼接(np.hstack)
【OpenCV 例程200篇】11. 圖像通道的拆分(cv2.split)
【OpenCV 例程200篇】12. 圖像通道的合并(cv2.merge)
【OpenCV 例程200篇】13. 圖像的加法運算(cv2.add)
【OpenCV 例程200篇】14. 圖像與標量相加(cv2.add)
【OpenCV 例程200篇】15. 圖像的加權加法(cv2.addWeight)
【OpenCV 例程200篇】16. 不同尺寸的圖像加法
【OpenCV 例程200篇】17. 兩張圖像的漸變切換
【OpenCV 例程200篇】18. 圖像的掩模加法
【OpenCV 例程200篇】19. 圖像的圓形遮罩
【OpenCV 例程200篇】20. 圖像的按位運算
【OpenCV 例程200篇】21. 圖像的疊加
【OpenCV 例程200篇】22. 圖像添加非中文文字
【OpenCV 例程200篇】23. 圖像添加中文文字
【OpenCV 例程200篇】23. 圖像添加中文文字
【OpenCV 例程200篇】24. 圖像的仿射變換
【OpenCV 例程200篇】25. 圖像的平移
【OpenCV 例程200篇】26. 圖像的旋轉(以原點為中心)
【OpenCV 例程200篇】27. 圖像的旋轉(以任意點為中心)
【OpenCV 例程200篇】28. 圖像的旋轉(直角旋轉)
【OpenCV 例程200篇】29. 圖像的翻轉(cv2.flip)
【OpenCV 例程200篇】30. 圖像的縮放(cv2.resize)
【OpenCV 例程200篇】31. 圖像金字塔(cv2.pyrDown)
【OpenCV 例程200篇】32. 圖像的扭變(錯切)
【OpenCV 例程200篇】33. 圖像的復合變換
【OpenCV 例程200篇】34. 圖像的投影變換
【OpenCV 例程200篇】35. 圖像的投影變換(邊界填充)
【OpenCV 例程200篇】36. 直角坐標與極坐標的轉換
【OpenCV 例程200篇】37. 圖像的灰度化處理和二值化處理
【OpenCV 例程200篇】38. 圖像的反色變換(圖像反轉)
【OpenCV 例程200篇】39. 圖像灰度的線性變換
【OpenCV 例程200篇】40. 圖像分段線性灰度變換
【OpenCV 例程200篇】41. 圖像的灰度變換(灰度級分層)
【OpenCV 例程200篇】42. 圖像的灰度變換(比特平面分層)
【OpenCV 例程200篇】43. 圖像的灰度變換(對數變換)
【OpenCV 例程200篇】44. 圖像的灰度變換(伽馬變換)
【OpenCV 例程200篇】45. 圖像的灰度直方圖
【OpenCV 例程200篇】46. 直方圖均衡化
【OpenCV 例程200篇】47. 圖像增強—直方圖匹配
【OpenCV 例程200篇】48. 圖像增強—彩色直方圖匹配
【OpenCV 例程200篇】49. 圖像增強—局部直方圖處理
【OpenCV 例程200篇】50. 圖像增強—直方圖統(tǒng)計量圖像增強
【OpenCV 例程200篇】51. 圖像增強—直方圖反向追蹤
【OpenCV 例程200篇】52. 圖像的相關與卷積運算
【OpenCV 例程200篇】53. Scipy 實現(xiàn)圖像二維卷積
【OpenCV 例程200篇】54. OpenCV 實現(xiàn)圖像二維卷積
【OpenCV 例程200篇】55. 可分離卷積核
【OpenCV 例程200篇】56. 低通盒式濾波器
【OpenCV 例程200篇】57. 低通高斯濾波器
【OpenCV 例程200篇】58. 非線性濾波—中值濾波
【OpenCV 例程200篇】59. 非線性濾波—雙邊濾波
【OpenCV 例程200篇】60. 非線性濾波—聯(lián)合雙邊濾波
【OpenCV 例程200篇】61. 導向濾波(Guided filter)
【OpenCV 例程200篇】62. 圖像銳化——鈍化掩蔽
【OpenCV 例程200篇】63. 圖像銳化——Laplacian 算子
【OpenCV 例程200篇】64. 圖像銳化——Sobel 算子
【OpenCV 例程200篇】65. 圖像銳化——Scharr 算子
【OpenCV 例程200篇】66. 圖像濾波之低通/高通/帶阻/帶通
【OpenCV 例程200篇】67. 空間域圖像增強的綜合應用
【OpenCV 例程200篇】68. 空間域圖像增強的綜合應用
【OpenCV 例程200篇】69. 連續(xù)非周期信號的傅立葉系數
【OpenCV 例程200篇】70. 一維連續(xù)函數的傅里葉變換
【OpenCV 例程200篇】71. 連續(xù)函數的取樣
【OpenCV 例程200篇】72. 一維離散傅里葉變換
【OpenCV 例程200篇】73. 二維連續(xù)傅里葉變換
【OpenCV 例程200篇】74. 圖像的抗混疊
【OpenCV 例程200篇】75. Numpy 實現(xiàn)圖像傅里葉變換
【OpenCV 例程200篇】76. OpenCV 實現(xiàn)圖像傅里葉變換
【OpenCV 例程200篇】77. OpenCV 實現(xiàn)快速傅里葉變換
【OpenCV 例程200篇】78. 頻率域圖像濾波基礎
【OpenCV 例程200篇】79. 頻率域圖像濾波的基本步驟
【OpenCV 例程200篇】80. 頻率域圖像濾波詳細步驟
【OpenCV 例程200篇】81. 頻率域高斯低通濾波器
【OpenCV 例程200篇】82. 頻率域巴特沃斯低通濾波器
【OpenCV 例程200篇】83. 頻率域低通濾波:印刷文本字符修復
【OpenCV 例程200篇】84. 由低通濾波器得到高通濾波器
【OpenCV 例程200篇】85. 頻率域高通濾波器的應用
【OpenCV 例程200篇】86. 頻率域濾波應用:指紋圖像處理
【OpenCV 例程200篇】87. 頻率域鈍化掩蔽
【OpenCV 例程200篇】88. 頻率域拉普拉斯高通濾波
【OpenCV 例程200篇】89. 帶阻濾波器的傳遞函數
【OpenCV 例程200篇】90. 頻率域陷波濾波器
【OpenCV 例程200篇】91. 高斯噪聲、瑞利噪聲、愛爾蘭噪聲
【OpenCV 例程200篇】92. 指數噪聲、均勻噪聲、椒鹽噪聲
【OpenCV 例程200篇】93. 噪聲模型的直方圖
【OpenCV 例程200篇】94. 算術平均濾波器
【OpenCV 例程200篇】95. 幾何均值濾波器
【OpenCV 例程200篇】96. 諧波平均濾波器
【OpenCV 例程200篇】97. 反諧波平均濾波器
【OpenCV 例程200篇】98. 統(tǒng)計排序濾波器
【OpenCV 例程200篇】99. 修正阿爾法均值濾波器
【OpenCV 例程200篇】100. 自適應局部降噪濾波器

總結

以上是生活随笔為你收集整理的【OpenCV 例程200篇】90. 频率域陷波滤波器的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。