Я сравниваю прямое БПФ, используя FFTW и MATLAB fft
. Входной сигнал является гауссовым. Код:
FFTW с использованием C:
float *signal; /*input signal*/
int nt; /*length of the signal*/
fftw_complex *in, *out;
fftw_plan plan1;
in = fftw_malloc(nt*sizeof(fftw_complex));
out = fftw_malloc(nt*sizeof(fftw_complex));
for (j=0;j<nt;j++){
in[j][0]=(double)signal[j];
in[j][1]=0.0;
}
plan1 = fftw_plan_dft_1d(nt, in, out, -1, FFTW_ESTIMATE);
fftw_execute(plan1);
fftw_destroy_plan(plan1);
for (j=0;j<nt;j++){
real[j]=(float)out[j][0];
imag[j]=(float)out[j][1];
}
fft
функция в MATLAB:
fft(signal);
Я рисую действительную и мнимую части обоих результатов:
Действительная часть имеет почти одно и то же значение, а мнимая часть имеет совсем другие значения. Как решить эту проблему?