c++ - 使用 FFTW 在 C 中实现 FFT 低通滤波器

标签 c++ image-processing fft fftw

我正在尝试创建一个非常简单的 C++ 程序,给定 [0-100] 范围内的参数,将低通滤波器应用于灰度图像,该图像应按比例将其“压缩”到给定参数的值。 我正在使用 FFTW 库。

我对我如何定义频率阈值有些疑惑,cut。有没有更有效的方法来定义这样的值(value)?

//fftw_complex *fft
//double[] magnitude
// . . . 

int percent = 100;
    if (percent < 0 || percent > 100) {
        cerr << "Compression rate must be a value between 0 and 100." << endl;
        return -1;
    }

double cut =(double)(w*h) * ((double)percent / (double)100);
    for (i = 0; i < (w * h); i++) {
        magnitude[i] = sqrt(pow(fft[i][0], 2.0) + pow(fft[i][1], 2.0));
        if (magnitude[i] < cut) {
            fft[i][0] = 0.0;
            fft[i][1] = 0.0;
        }
    }

更新1:

我已将我的代码更改为此,但我再次不确定这是过滤频率的正确方法。图像确实被压缩了,但非方形图像被弄乱了,将压缩设置为 100% 并不是真正可用的最大压缩(我可以达到 ~140%)。 Here你可以找到我现在看到的图像。

int cX = w/2;
int cY = h/2;
cout<<"TEST "<<((double)percent/(double)100)*h<<endl;
for(i = 0; i<(w*h);i++){
    int row = i/s;
    int col = i%s;
    int distance = sqrt((col-cX)*(col-cX)+(row-cY)*(row-cY));
    if(distance<((double)percent/(double)100)*min(cX,cY)){
        fft[i][0] = 0.0;
        fft[i][1] = 0.0;
    }
}

最佳答案

这根本不是低通滤波器。低通滤波器通过低频,即它去除精细细节(模糊)。你显然需要一个 2D FFT。

本质上,这段代码只是删除了随机位。

[编辑] 新代码看起来更像是一个低通滤波器。预期设置为 141%:正方形的对角线是其边长的 sqrt(2)=1.41 倍。将索引转换为行/列对应该使用图像宽度,而不是一些随机的无法解释的 s

我不知道你的零频在哪里。这应该很容易发现(最大值),但它可能在 (0,0) 而不是 (w/2,h/2)

关于c++ - 使用 FFTW 在 C 中实现 FFT 低通滤波器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24030721/

相关文章:

c++ - 用右值构造一对

c++ - 将矩形转换为梯形以获得透视效果

c# - 如何在 C# 中从指向 ULONG 数组的指针中检索值

ASP.NET:动态添加 'Watermark' 到图像

python - 如何从时间序列中去除频率成分?

java - 来自 FFT 的有用音频数据

c++ - 终止所有线程或当前正在运行的线程,使进程在 C++ 中保持事件状态

python - 如何使用 opencv 和 Python 获取轮廓数组的索引以选择 N 个最大的轮廓?

python - 逆傅里叶不清楚数据

algorithm - 使用 MATLAB 将 2D 图像转换为 3D