C语言数字图像处理(六):低通滤波器和高通滤波器

0. 完整仓库&教程:

这一章节的完整代码在:​​​​​​​​​​Chapter 6. Low Pass Filter and High Pass Filter​​​​​​​

如果你喜欢这个系列的文章或者感觉对你有帮助,请给我的仓库一个⭐️

1. 低通滤波器

  • 1.1 理想低通滤波器(Ideal Low Pass Filter)

算法:

首先对图像进行二维离散傅里叶变换(这部分的原理可以参考:离散傅里叶变换和重建),得到每个像素的复数数组。 每个复数的实部虚部分别乘以 𝐻(𝑢, 𝑣)。 𝐻(𝑢, 𝑣) 的公式为:

其中 D_0 代表通带(passband)的半径。𝐷(𝑢, 𝑣)的计算方法是通过以下公式计算两点之间的距离:

其中,𝑃 和𝑄 是图像的长和宽。 最后,使用二维离散傅里叶逆变换(iDFT)恢复处理后的图像。

图像和结果对比(lena):

结果分析:

理想的低通滤波器可以完全抑制所有高于截止频率的频率信号,而低于截止频率的信号可以不受影响地通过。 由于理想低通滤波器的过渡特性过于尖锐,因此会出现振铃现象(ringing)。 它滤除了图像的高频部分,从而使图像变得模糊。 另外,D_0 选择的值越小,图像处理的效果越明显,即越模糊。

代码:
void IDLPF(Image *image, float *real_array, float *imaginary_array) {
    unsigned char *temp
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值