Chris@184: #include "kissfft.hh" Chris@184: #include Chris@184: #include Chris@184: #include Chris@184: Chris@184: #include Chris@184: static inline Chris@184: double curtime(void) Chris@184: { Chris@184: struct timeval tv; Chris@184: gettimeofday(&tv, NULL); Chris@184: return (double)tv.tv_sec + (double)tv.tv_usec*.000001; Chris@184: } Chris@184: Chris@184: using namespace std; Chris@184: Chris@184: template Chris@184: void dotest(int nfft) Chris@184: { Chris@184: typedef kissfft FFT; Chris@184: typedef std::complex cpx_type; Chris@184: Chris@184: cout << "type:" << typeid(T).name() << " nfft:" << nfft; Chris@184: Chris@184: FFT fft(nfft,false); Chris@184: Chris@184: vector inbuf(nfft); Chris@184: vector outbuf(nfft); Chris@184: for (int k=0;k acc = 0; Chris@184: long double phinc = 2*k0* M_PIl / nfft; Chris@184: for (int k1=0;k1 x(inbuf[k1].real(),inbuf[k1].imag()); Chris@184: acc += x * exp( complex(0,-k1*phinc) ); Chris@184: } Chris@184: totalpower += norm(acc); Chris@184: complex x(outbuf[k0].real(),outbuf[k0].imag()); Chris@184: complex dif = acc - x; Chris@184: difpower += norm(dif); Chris@184: } Chris@184: cout << " RMSE:" << sqrt(difpower/totalpower) << "\t"; Chris@184: Chris@184: double t0 = curtime(); Chris@184: int nits=20e6/nfft; Chris@184: for (int k=0;k1) { Chris@184: for (int k=1;k(nfft); dotest(nfft); dotest(nfft); Chris@184: } Chris@184: }else{ Chris@184: dotest(32); dotest(32); dotest(32); Chris@184: dotest(1024); dotest(1024); dotest(1024); Chris@184: dotest(840); dotest(840); dotest(840); Chris@184: } Chris@184: return 0; Chris@184: }