不同阶数的巴特沃斯低通滤波器的空间域表示——数字图像处理

news/2024/7/21 4:56:16 标签: 计算机视觉, 人工智能, 图像处理, python, opencv

原理

巴特沃斯低通滤波器(Butterworth Low-Pass Filter)在频率域中的定义是明确的,但它在空间域中的表示不是直观的。这是因为巴特沃斯滤波器的形式是基于频率的,并且其空间域表示涉及到一个复杂的逆傅里叶变换,该变换没有一个封闭形式的解析表达。然而,我们可以通过理解其频率域的特性来间接理解其在空间域的行为。

在频率域,巴特沃斯低通滤波器的函数形式如下:

在这里插入图片描述
不同阶数 n 的巴特沃斯低通滤波器在空间域中的主要影响如下:

阶数 n 对平滑度的影响:

较低阶数(如 n=1)的巴特沃斯滤波器在空间域中提供较为平缓的平滑效果,边缘过渡较为柔和。
较高阶数(如 n>1)的滤波器则提供更加强烈的平滑效果,但过渡可能更为尖锐,接近理想低通滤波器的特性。
频率响应与空间响应的关系:
在频率域中,滤波器的截止频率越低,其在空间域中的作用范围越大,导致图像更加模糊。
在空间域中,滤波器的效果取决于其对图像不同频率成分的衰减方式。
空间域的表示:
理论上,可以通过逆傅里叶变换将巴特沃斯滤波器从频率域转换到空间域,但这通常不会产生一个简单的封闭形式的函数。
在实际应用中,巴特沃斯滤波器通常直接在频率域内操作,并在应用逆傅里叶变换回空间域后观察其效果。
由于巴特沃斯滤波器在空间域中没有简洁的表达式,因此在图像处理中通常在频率域内进行设计和应用,然后将处理后的结果转换回空间域以观察和利用其效果。

python_22">python实现下图

在这里插入图片描述

提示

不同阶数巴特沃斯低通滤波器的空间域表示。参数如下设置:阶数分别为1,2,5,20,滤波器大小均为1000×1000,截止频率均为5。仍然和上一个实验一样,生成频域的巴特沃斯低通滤波器。之后直接做傅里叶反变换得到空间域的图像表示。为了便于显示,还需要进行对数变换等,具体代码可为HSpatial =

代码实现

python">import numpy as np
import pandas as pd
from sklearn.model_selection import KFold
import scipy as sp
import matplotlib.pyplot as plt

img_list=[]
img_name_list=[]

H=np.ones((1000,1000))

for n in [1,2,5,20]:
    for i in range(1000):
        for j in range(1000):
            Duv=np.sqrt(np.power((i-1000/2),2)+np.power((j-1000/2),2))
            H[i,j]=1/(1+np.power((i-1000/2),2)+np.power((j-1000/2),2))
    HSpatital=np.log(0.00005+np.abs(np.fft.fftshift(np.fft.ifft2(H))))
    img_list.append(HSpatital)
    img_name_list.append("n="+str(n))

_,axs=plt.subplots(1,4)

for i in range(4):
    axs[i].imshow(img_list[i],cmap="gray")
    axs[i].set_title(img_name_list[i])
    axs[i].axis('off')

plt.show()

结果展示

在这里插入图片描述

总结

阶数高的时候高频衰减快。高于截止频率以后,n阶butterworth衰减速度是20n分贝/10倍频。但是做数字滤波的时候你会发现阶数越高系统响应越慢,如果采样间隔是t,通过一个n阶的butterworth,结果和原信号相比基本会有nt的延迟,随着阶数增大,振铃现象逐渐明显,频域的butterworth滤波器也更加接近理想滤波器。
Butterworth低通滤波器可以通过改变次数n,对过度特性进行调整。过大的n会造成振铃现象


http://www.niftyadmin.cn/n/5304996.html

相关文章

【React】04-关于React Props的实践

关于React Props的实践 背景分析和state区别 背景 React 组件相互传参时,除了用state,还会经常看到一个Props对象,关于它的面纱及两者区别,将在文本进行实践及分析。 分析 React 中的 props 是用于从父组件向子组件传递数据的…

Android 车联网——电源管理功能扩展(十)

前面两篇文章介绍了 CarPowerManagementService 和 CarPowerManager 相关代码,他们具有对应关系。对于源码中所提供的功能和电源状态等不足以满足实际开发需求,这里我们列举一些实际项目中所遇到的变化。 一、电源状态变化 对于电源状态实际开发中肯定会比源码中提供的要多,…

MySQL中NULL值与空值的坑

1. 表达含义 在mysql中 空值:表示一个空字符或零长度的字符串,可以使用空引号 来表示,是已被定义的值; NULL值:NULL表示缺少一个已知或适当的值,是未被定义的值;。 2. 比较运算 空值&…

DevOps(5)

目录 21.如何在Linux下访问分区? 22.什么是硬链接? 23.Linux下文件名的最大长度是多少? 24.什么是以点开头的文件名? 25.解释虚拟桌面? 21.如何在Linux下访问分区? Linux在驱动器标识符的末尾分配数字…

初识对抗生成网络(GAN)

在研究语义通信的时候,发现解码端很多都是用GAN或基于GAN来完成的。带着对GAN的好奇,对GAN进行了一个初步学习。这篇文章介绍一下和GAN相关的一些常识吧~   本文围绕以下几个内容展开:     1.什么是GAN?     2.为什么要…

c语言-指针进阶

文章目录 前言一、字符指针二、数组指针2.1 数组指针基础2.2 数组指针作函数参数 总结 前言 在c语言基础已经介绍过关于指针的概念和基本使用,本篇文章进一步介绍c语言中关于指针的应用。 一、字符指针 字符指针是指向字符的指针。 结果分析: "ab…

HTTP代理和SOCKS5 代理区别

代理IP是一种常见的网络工具,可以帮助用户隐藏真实IP地址,提高网络安全性,同时也可以用于网络监测、数据采集、网络推广等应用场景。在代理IP市场中,HTTP代理和SOCKS5 代理是两种常见的代理方式,它们有什么区别呢。 1…

ffmpeg推拉流参数汇总-1

参数含义说明 1. 完整命令 1.1. windows系统 """推流命令""" ffmpeg -f dshow -video_size 1920x1080 -i video"device_pnp_\\?\usb#vid_0c45&pid_6366&mi_00#6&183af011&0&0000#{65e8773d-8f56-11d0-a3b9-00a0c92…