Test FFT to verify operation
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed arrows point from an interface to procedures which implement that interface. This could include the module procedures in a generic interface or the implementation in a submodule of an interface in a parent module.
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed arrows point from an interface to procedures which implement that interface. This could include the module procedures in a generic interface or the implementation in a submodule of an interface in a parent module.
subroutine testIFFT
!! Test FFT to verify operation
logical,dimension(1)::results
integer,parameter::N = 10000
real(wp),parameter::D = 5.0_wp
real(wp),dimension(N)::t,f
complex(wp),dimension(N)::s,fs,ffs
integer::k
forall(k=1:N) t(k) = D*(real(k-1,wp)/real(N-1,wp))
s = cos( (2.0_wp*PI)*t )
f = FFT_freq(t)
fs = FFT(s)
ffs = iFFT(fs)
results(1) = norm2(abs(s-ffs))<1.0E-10_wp
if( .not.all(results) ) error stop "Failed iFFT check"
end subroutine testIFFT