我遇到FastFourier问题......(FFTW3)
100×100个样品的数据>使用FFTW3转换到复频域 后来我想使用backtransform
前瞻性计划:
fftw_plan fftw_plan_dft_r2c_2d(int n0, int n1,
double *in, fftw_complex *out,
unsigned flags);
反向看起来就像这样
fftw_plan fftw_plan_dft_c2r_2d(int n0, int n1,
fftw_complex *in, double *out,
unsigned flags);
这是我的代码:
int ncols = 100; // a 100x100 picture
int nrows = 100;
int nccols = ncols/2+1;
//复杂必须按照n / 2 + 1分配 // http://www.fftw.org/doc/Multi_002dDimensional-DFTs-of-Real-Data.html
double * Aa = (double*)fftw_malloc(sizeof(double)*ncols*nrows);
fftw_complex * Af = (fftw_complex*)fftw_malloc(sizeof(fftw_complex)*nccols*nrows);
double * Ba = (double*)fftw_malloc(sizeof(double)*ncols*nrows);
fftw_complex * Bf = (fftw_complex*)fftw_malloc(sizeof(fftw_complex)*nccols*nrows);
double * Bc = (double*)fftw_malloc(sizeof(double)*ncols*nrows);
fftw_plan forwardA = fftw_plan_dft_r2c_2d(nrows,ncols,Aa,Af,FFTW_FORWARD | FFTW_ESTIMATE);
fftw_plan backwardA = fftw_plan_dft_c2r_2d(nrows,ncols,Af,Aa,FFTW_BACKWARD | FFTW_ESTIMATE);
fftw_plan forwardB = fftw_plan_dft_r2c_2d(nrows,ncols,Ba,Bf,FFTW_FORWARD | FFTW_ESTIMATE);
fftw_plan backwardB = fftw_plan_dft_c2r_2d(nrows,ncols,Bf,Bc,FFTW_BACKWARD | FFTW_ESTIMATE);
这与此处的代码完全相同:http://werner.yellowcouch.org/Papers/subimg/index.html
我现在的问题是forwardA和forwardB指向0x0,而backwardA和backwardB是有效的。
关于为什么会发生这种情况的任何想法?
答案 0 :(得分:0)
试试这个:
fftw_plan forwardA = fftw_plan_dft_r2c_2d(nrows,ncols,Aa,Af,FFTW_ESTIMATE);
应该有用。