Как сделать пакет FFT в C - PullRequest
       4

Как сделать пакет FFT в C

1 голос
/ 23 сентября 2010

Я пытаюсь сделать пакетное БПФ для 50 изображений, используя следующий фрагмент:

pix3 = n*pix1*pix2;
fftwf_complex *in2, *f2h; //input for FFT2
in2 = (fftwf_complex*)fftwf_malloc(sizeof(fftwf_complex) * pix3);
f2h = (fftwf_complex*)fftwf_malloc(sizeof(fftwf_complex) * pix3);

for (i = 0; i < pix3; i++)
{
in2[i][0] = ref20[i]; //ref20 is an array of real values 
in2[i][1] = 0;
}    

for(i = 0; i < n; ++i)
{
  plan_forward2 = fftwf_plan_dft_2d (pix1, pix2, in2, f2h, FFTW_FORWARD, FFTW_ESTIMATE);
  fftwf_execute (plan_forward2);
  in2 += pix1*pix2;
  f2h += pix1*pix2;
}

Однако я могу получить только БПФ 1-го изображения (т.е. первые элементы pix1 * pix2). Любые предложения о том, как получить это право?

Заранее спасибо

1 Ответ

2 голосов
/ 31 июля 2013

Вы должны прочитать руководство 4.6. Функции выполнения нового массива внимательно

Вам нужно создать план только один раз за пределами цикла, а затем использовать его как:

fftwf_execute_dft(plan_forward2, in2, f2h);
...