0. 完整仓库&教程:
这一章节的完整代码在:Chapter 6. Low Pass Filter and High Pass Filter
如果你喜欢这个系列的文章或者感觉对你有帮助,请给我的仓库一个⭐️。
1. 低通滤波器
-
1.1 理想低通滤波器(Ideal Low Pass Filter)
算法:
首先对图像进行二维离散傅里叶变换(这部分的原理可以参考:离散傅里叶变换和重建),得到每个像素的复数数组。 每个复数的实部和虚部分别乘以 𝐻(𝑢, 𝑣)。 𝐻(𝑢, 𝑣) 的公式为:
其中 代表通带(passband)的半径。𝐷(𝑢, 𝑣)的计算方法是通过以下公式计算两点之间的距离:
其中,𝑃 和𝑄 是图像的长和宽。 最后,使用二维离散傅里叶逆变换(iDFT)恢复处理后的图像。
图像和结果对比(lena):
结果分析:
理想的低通滤波器可以完全抑制所有高于截止频率的频率信号,而低于截止频率的信号可以不受影响地通过。 由于理想低通滤波器的过渡特性过于尖锐,因此会出现振铃现象(ringing)。 它滤除了图像的高频部分,从而使图像变得模糊。 另外, 选择的值越小,图像处理的效果越明显,即越模糊。
代码:
void IDLPF(Image *image, float *real_array, float *imaginary_array) {
unsigned char *temp