File: example.pas

package info (click to toggle)
fpc 3.2.2%2Bdfsg-49
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 341,452 kB
  • sloc: pascal: 3,820,194; xml: 194,356; ansic: 9,637; asm: 8,482; java: 5,346; sh: 4,813; yacc: 3,956; makefile: 2,705; lex: 2,661; javascript: 2,454; sql: 929; php: 474; cpp: 145; perl: 136; sed: 132; csh: 34; tcl: 7
file content (31 lines) | stat: -rw-r--r-- 639 bytes parent folder | download | duplicates (14)
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.