我正在尝试编写一个简单的 FFTW 例程(第 2 版),我想我已经把骨头搞定了,但是当我调用 fftwnd_one 函数时,我遇到了持久的段错误(我正在做一个维变换,但我使用 n 维代码是为了模块化)。但是,我认为我的问题出在计划创建中;谁能提供一些关于这段代码有什么问题的见解?如果是这样,我将不胜感激 - 谢谢!
作为参考,我在这里使用的函数是 sin(x)。我意识到并非所有的数学运算都已实现,我只是想让 FFTW2 库首先工作,然后我才能使数据变得有用。
#include <stdio.h>
#include <fftw.h>
#include <math.h>
#include <complex.h>
int main(){
int i;
fftw_complex in[8];
fftwnd_plan p;
const int *n;
int temp = (int)pow(2, 2)*pow(3,2)*pow(5,1)*pow(7,1)*pow(11,1)*pow(13,0);
n = &temp;
in[0].re = 0;
in[1].re = (sqrt(2)/2);
in[2].re = 1;
in[3].re = (sqrt(2)/2);
in[4].re = 0;
in[5].re = -(sqrt(2)/2);
in[6].re = -1;
in[7].re = -(sqrt(2)/2);
for(i = 0; i < 8; i++){
(in[i]).im = 0;
}
p = fftwnd_create_plan(8, n, FFTW_FORWARD, FFTW_ESIMATE | FFTW_IN_PLACE);
fftwnd_one(p, &in[0], NULL);
fftwnd_destroy_plan(p);
printf("Sin\n");
for(i = 0; i < 8; i++){
printf("%d\n", n[i]);
}
return 0;
}