【发布时间】:2010-06-24 22:44:28
【问题描述】:
我正在使用这个fftw 库。
目前我正在尝试以 e^(-(x^2+y^2)/a^2) 的形式绘制二维高斯曲线。
代码如下:
using namespace std;
int main(int argc, char** argv ){
fftw_complex *in, *out, *data;
fftw_plan p;
int i,j;
int w=16;
int h=16;
double a = 2;
in = (fftw_complex*) fftw_malloc(sizeof(fftw_complex)*w*h);
out = (fftw_complex*) fftw_malloc(sizeof(fftw_complex)*w*h);
for(i=0;i<w;i++){
for(j=0;j<h;j++){
in[i*h+j][0] = exp(- (i*i+j*j)/(a*a));
in[i*h+j][1] = 0;
}
}
p = fftw_plan_dft_2d(w, h, in, out, FFTW_FORWARD, FFTW_ESTIMATE);
fftw_execute(p);
//This is something that print what's in the matrix
print_2d(out,w,h);
fftw_destroy_plan(p);
fftw_free(in);
fftw_free(out);
return 0;
}
原来出现了负数。我认为高斯的傅里叶变换是另一个高斯,它不应该包含任何负数。
另外,当前原点在 [0]
【问题讨论】:
-
两个可能的问题:(i) 你正在做一个 离散 FT,而不是 FT 和 (ii) 你的高斯函数已经有效地乘以一个矩形窗口(因为它被截断),相当于通过窗函数的FT在频域进行卷积。
-
(iii) 浮点数学是出了名的不精确,至少从幼稚的标准来看是这样。
-1E-30将是一个舍入错误,而不是一个真正的负数。 -
我猜这就是原因。我当然不能查,因为我不能在我的电脑上做连续的FT。