热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【OpenCV例程200篇】89.带阻滤波器的传递函数

【OpenCV例程200篇】89.带阻滤波器的传递函数欢迎关注『OpenCV例程200篇』系列,持续更新中欢迎关注『Python小白的OpenCV学习课』系列

【OpenCV 例程200篇】89. 带阻滤波器的传递函数


欢迎关注 『OpenCV 例程200篇』 系列,持续更新中
欢迎关注 『Python小白的OpenCV学习课』 系列,持续更新中





5.1 带阻与带通

空间域和频率域线性滤波器可以分为四类:低通滤波器、高通滤波器、带通滤波器和带阻滤波器。高通滤波和低通滤波都是在整个频率矩形上操作,带通滤波和带阻滤波则是对特定频带处理,属于选择性滤波。

带阻滤波器(bandstop filters,简称BSF)是指能通过大多数频率分量、但将某些范围的频率分量衰减到极低水平的滤波器。带通滤波器(band-pass filter)是一个允许特定频段的波通过同时屏蔽其他频段的设备。比如RLC振荡回路就是一个模拟带通滤波器。

频率域的高通滤波器可以由低通滤波器推导而来。类似地,频率域中的带通和带阻滤波器的传递函数,可以通过低通滤波器和高通滤波器的组合来构建。

理想带阻滤波器(IBRF) 的传递函数为:
H(u,v)={0,(C0−W/2)≤D(u,v)≤(C0+W/2)1,elseH(u,v)=\begin{cases} 0,\ (C_0-W/2) \leq D(u,v) \leq (C_0+W/2)\\ 1,\ else \end{cases} H(u,v)={0, (C0W/2)D(u,v)(C0+W/2)1, else
高斯带阻滤波器(GBRF) 的传递函数为:
H(u,v)=1−e−[D2(u,v)−C02D(u,v)W]2H(u,v)=1-e^{-[ \frac {D^2(u,v) - C_0^2} {D(u,v)W}]^2} H(u,v)=1e[D(u,v)WD2(u,v)C02]2

巴特沃斯带阻滤波器(BBRF) 的传递函数为:

H(u,v)=11+[D(u,v)WD2(u,v)−C02]2nH(u,v)= \frac {1} {1 +[ \frac {D(u,v)W} {D^2(u,v) - C_0^2}]^{2n}} H(u,v)=1+[D2(u,v)C02D(u,v)W]2n1




例程 8.28 带阻滤波器的传递函数

# OpenCVdemo08.py
# Demo08 of OpenCV
# 8. 图像的频率域滤波
# Copyright 2021 Youcans, XUPT
# Crated&#xff1a;2021-12-30 # 例程 8.28 带阻滤波器的传递函数def ideaBondResistFilter(shape, radius&#61;10, w&#61;5): # 理想带阻滤波器u, v &#61; np.meshgrid(np.arange(shape[1]), np.arange(shape[0]))D &#61; np.sqrt((u - shape[1]//2)**2 &#43; (v - shape[0]//2)**2)D0 &#61; radiushalfW &#61; w/2kernel &#61; np.piecewise(D, [D<&#61;D0&#43;halfW, D<&#61;D0-halfW], [1, 0])kernel &#61; 1 - kernel # 带阻return kerneldef gaussBondResistFilter(shape, radius&#61;10, w&#61;5): # 高斯带阻滤波器# 高斯滤波器&#xff1a;# Gauss &#61; 1/(2*pi*s2) * exp(-(x**2&#43;y**2)/(2*s2))u, v &#61; np.meshgrid(np.arange(shape[1]), np.arange(shape[0]))D &#61; np.sqrt((u - shape[1]//2)**2 &#43; (v - shape[0]//2)**2)C0 &#61; radiuskernel &#61; 1 - np.exp(-(D-C0)**2 / (w**2))return kerneldef butterworthBondResistFilter(shape, radius&#61;10, w&#61;5, n&#61;1): # 巴特沃斯带阻滤波u, v &#61; np.meshgrid(np.arange(shape[1]), np.arange(shape[0]))D &#61; np.sqrt((u - shape[1]//2)**2 &#43; (v - shape[0]//2)**2)C0 &#61; radiusepsilon &#61; 1e-8 # 防止被 0 除kernel &#61; 1.0 / (1.0 &#43; np.power(D*w/(D**2-C0**2&#43;epsilon), 2*n))return kernel# 理想、高斯、巴特沃斯带阻滤波器传递函数shape &#61; [128, 128]radius &#61; 32IBRF &#61; ideaBondResistFilter(shape, radius&#61;radius)GBRF &#61; gaussBondResistFilter(shape, radius&#61;radius)BBRF &#61; butterworthBondResistFilter(shape, radius&#61;radius)filters &#61; ["IBRF", "GBRF", "BBRF"]u, v &#61; np.mgrid[-1:1:2.0/shape[0], -1:1:2.0/shape[1]]fig &#61; plt.figure(figsize&#61;(10, 8))for i in range(3):hpFilter &#61; eval(filters[i]).copy()ax1 &#61; fig.add_subplot(3, 3, 3*i&#43;1)ax1.imshow(hpFilter, &#39;gray&#39;)ax1.set_title(filters[i]), ax1.set_xticks([]), ax1.set_yticks([])ax2 &#61; plt.subplot(3,3,3*i&#43;2, projection&#61;&#39;3d&#39;)ax2.set_title("transfer function")ax2.plot_wireframe(u, v, hpFilter, rstride&#61;2, linewidth&#61;0.5, color&#61;&#39;c&#39;)ax2.set_xticks([]), ax2.set_yticks([]), ax2.set_zticks([])ax3 &#61; plt.subplot(3,3,3*i&#43;3)profile &#61; hpFilter[shape[0]//2:, shape[1]//2]ax3.plot(profile), ax3.set_title("profile"), ax3.set_xticks([]), ax3.set_yticks([])plt.show()

在这里插入图片描述



&#xff08;本节完&#xff09;



版权声明&#xff1a;

youcans&#64;xupt 原创作品&#xff0c;转载必须标注原文链接

Copyright 2021 youcans, XUPT

Crated&#xff1a;2022-2-1




欢迎关注 『OpenCV 例程200篇』 系列&#xff0c;持续更新中
欢迎关注 『Python小白的OpenCV学习课』 系列&#xff0c;持续更新中



【OpenCV 例程200篇】01. 图像的读取&#xff08;cv2.imread&#xff09;
【OpenCV 例程200篇】02. 图像的保存&#xff08;cv2.imwrite&#xff09;
【OpenCV 例程200篇】03. 图像的显示&#xff08;cv2.imshow&#xff09;
【OpenCV 例程200篇】04. 用 matplotlib 显示图像&#xff08;plt.imshow&#xff09;
【OpenCV 例程200篇】05. 图像的属性&#xff08;np.shape&#xff09;
【OpenCV 例程200篇】06. 像素的编辑&#xff08;img.itemset&#xff09;
【OpenCV 例程200篇】07. 图像的创建&#xff08;np.zeros&#xff09;
【OpenCV 例程200篇】08. 图像的复制&#xff08;np.copy&#xff09;
【OpenCV 例程200篇】09. 图像的裁剪&#xff08;cv2.selectROI&#xff09;
【OpenCV 例程200篇】10. 图像的拼接&#xff08;np.hstack&#xff09;
【OpenCV 例程200篇】11. 图像通道的拆分&#xff08;cv2.split&#xff09;
【OpenCV 例程200篇】12. 图像通道的合并&#xff08;cv2.merge&#xff09;
【OpenCV 例程200篇】13. 图像的加法运算&#xff08;cv2.add&#xff09;
【OpenCV 例程200篇】14. 图像与标量相加&#xff08;cv2.add&#xff09;
【OpenCV 例程200篇】15. 图像的加权加法&#xff08;cv2.addWeight&#xff09;
【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. 图像的旋转&#xff08;以原点为中心&#xff09;
【OpenCV 例程200篇】27. 图像的旋转&#xff08;以任意点为中心&#xff09;
【OpenCV 例程200篇】28. 图像的旋转&#xff08;直角旋转&#xff09;
【OpenCV 例程200篇】29. 图像的翻转&#xff08;cv2.flip&#xff09;
【OpenCV 例程200篇】30. 图像的缩放&#xff08;cv2.resize&#xff09;
【OpenCV 例程200篇】31. 图像金字塔&#xff08;cv2.pyrDown&#xff09;
【OpenCV 例程200篇】32. 图像的扭变&#xff08;错切&#xff09;
【OpenCV 例程200篇】33. 图像的复合变换
【OpenCV 例程200篇】34. 图像的投影变换
【OpenCV 例程200篇】35. 图像的投影变换&#xff08;边界填充&#xff09;
【OpenCV 例程200篇】36. 直角坐标与极坐标的转换
【OpenCV 例程200篇】37. 图像的灰度化处理和二值化处理
【OpenCV 例程200篇】38. 图像的反色变换&#xff08;图像反转&#xff09;
【OpenCV 例程200篇】39. 图像灰度的线性变换
【OpenCV 例程200篇】40. 图像分段线性灰度变换
【OpenCV 例程200篇】41. 图像的灰度变换&#xff08;灰度级分层&#xff09;
【OpenCV 例程200篇】42. 图像的灰度变换&#xff08;比特平面分层&#xff09;
【OpenCV 例程200篇】43. 图像的灰度变换&#xff08;对数变换&#xff09;
【OpenCV 例程200篇】44. 图像的灰度变换&#xff08;伽马变换&#xff09;
【OpenCV 例程200篇】45. 图像的灰度直方图
【OpenCV 例程200篇】46. 直方图均衡化
【OpenCV 例程200篇】47. 图像增强—直方图匹配
【OpenCV 例程200篇】48. 图像增强—彩色直方图匹配
【OpenCV 例程200篇】49. 图像增强—局部直方图处理
【OpenCV 例程200篇】50. 图像增强—直方图统计量图像增强
【OpenCV 例程200篇】51. 图像增强—直方图反向追踪
【OpenCV 例程200篇】52. 图像的相关与卷积运算
【OpenCV 例程200篇】53. Scipy 实现图像二维卷积
【OpenCV 例程200篇】54. OpenCV 实现图像二维卷积
【OpenCV 例程200篇】55. 可分离卷积核
【OpenCV 例程200篇】56. 低通盒式滤波器
【OpenCV 例程200篇】57. 低通高斯滤波器
【OpenCV 例程200篇】58. 非线性滤波—中值滤波
【OpenCV 例程200篇】59. 非线性滤波—双边滤波
【OpenCV 例程200篇】60. 非线性滤波—联合双边滤波
【OpenCV 例程200篇】61. 导向滤波&#xff08;Guided filter&#xff09;
【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. 连续非周期信号的傅立叶系数
【OpenCV 例程200篇】70. 一维连续函数的傅里叶变换
【OpenCV 例程200篇】71. 连续函数的取样
【OpenCV 例程200篇】72. 一维离散傅里叶变换
【OpenCV 例程200篇】73. 二维连续傅里叶变换
【OpenCV 例程200篇】74. 图像的抗混叠
【OpenCV 例程200篇】75. Numpy 实现图像傅里叶变换
【OpenCV 例程200篇】76. OpenCV 实现图像傅里叶变换
【OpenCV 例程200篇】77. OpenCV 实现快速傅里叶变换
【OpenCV 例程200篇】78. 频率域图像滤波基础
【OpenCV 例程200篇】79. 频率域图像滤波的基本步骤
【OpenCV 例程200篇】80. 频率域图像滤波详细步骤
【OpenCV 例程200篇】81. 频率域高斯低通滤波器
【OpenCV 例程200篇】82. 频率域巴特沃斯低通滤波器
【OpenCV 例程200篇】83. 频率域低通滤波&#xff1a;印刷文本字符修复
【OpenCV 例程200篇】84. 由低通滤波器得到高通滤波器
【OpenCV 例程200篇】85. 频率域高通滤波器的应用
【OpenCV 例程200篇】86. 频率域滤波应用&#xff1a;指纹图像处理
【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. 统计排序滤波器
【OpenCV 例程200篇】99. 修正阿尔法均值滤波器
【OpenCV 例程200篇】100. 自适应局部降噪滤波器



推荐阅读
  • com.sun.javadoc.PackageDoc.exceptions()方法的使用及代码示例 ... [详细]
  • Ihavetwomethodsofgeneratingmdistinctrandomnumbersintherange[0..n-1]我有两种方法在范围[0.n-1]中生 ... [详细]
  • PHP预处理常量详解:如何定义与使用常量 ... [详细]
  • 本文总结了JavaScript的核心知识点和实用技巧,涵盖了变量声明、DOM操作、事件处理等重要方面。例如,通过`event.srcElement`获取触发事件的元素,并使用`alert`显示其HTML结构;利用`innerText`和`innerHTML`属性分别设置和获取文本内容及HTML内容。此外,还介绍了如何在表单中动态生成和操作``元素,以便更好地处理用户输入。这些技巧对于提升前端开发效率和代码质量具有重要意义。 ... [详细]
  • JavaScript XML操作实用工具类:XmlUtilsJS技巧与应用 ... [详细]
  • 蓝桥杯物联网基础教程:通过GPIO输入控制LED5的点亮与熄灭
    本教程详细介绍了如何利用STM32的GPIO接口通过输入信号控制LED5的点亮与熄灭。内容涵盖GPIO的基本配置、按键检测及LED驱动方法,适合具有STM32基础的读者学习和实践。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统中配置 fstab 文件以实现开机自动挂载 NFS 共享目录的方法,并解决了常见的配置失败问题。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 优化Vite 1.0至2.0升级过程中遇到的某些代码块过大问题解决方案
    本文详细探讨了在将项目从 Vite 1.0 升级到 2.0 的过程中,如何解决某些代码块过大的问题。通过具体的编码示例,文章提供了全面的解决方案,帮助开发者有效优化打包性能。 ... [详细]
  • POJ 2482 星空中的星星:利用线段树与扫描线算法解决
    在《POJ 2482 星空中的星星》问题中,通过运用线段树和扫描线算法,可以高效地解决星星在窗口内的计数问题。该方法不仅能够快速处理大规模数据,还能确保时间复杂度的最优性,适用于各种复杂的星空模拟场景。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • Python内置模块详解:正则表达式re模块的应用与解析
    正则表达式是一种强大的文本处理工具,通过特定的字符序列来定义搜索模式。本文详细介绍了Python内置的`re`模块,探讨了其在字符串匹配、验证和提取中的应用。例如,可以通过正则表达式验证电子邮件地址、电话号码、QQ号、密码、URL和IP地址等。此外,文章还深入解析了`re`模块的各种函数和方法,提供了丰富的示例代码,帮助读者更好地理解和使用这一工具。 ... [详细]
  • 在前文探讨了Spring如何为特定的bean选择合适的通知器后,本文将进一步深入分析Spring AOP框架中代理对象的生成机制。具体而言,我们将详细解析如何通过代理技术将通知器(Advisor)中包含的通知(Advice)应用到目标bean上,以实现切面编程的核心功能。 ... [详细]
author-avatar
YW1232602897663_231
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有