1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
program example;
uses fftw_s;
const s=128;
var i,o:Pcomplex_single;
p:fftw_plan_single;
a:cardinal;
begin
fftw_getmem(i,s*sizeof(complex_single));
fftw_getmem(o,s*sizeof(complex_single));
p:=fftw_plan_dft_1d(128,i,o,fftw_forward,[fftw_estimate]);
for a:=0 to 127 do
begin
i[a].re:=(single(a)-64);
i[a].im:=0;
end;
writeln('input:');
for a:=0 to 127 do
writeln('(',i[a].re:8:4,',',i[a].im:8:4,')');
fftw_execute(p);
writeln('output:');
for a:=0 to 127 do
writeln('(',o[a].re:8:4,',',o[a].im:8:4,')');
fftw_destroy_plan(p);
fftw_freemem(i);
fftw_freemem(o);
end.
|