Chris@184: #include Chris@184: #include Chris@184: #include Chris@184: #include "kiss_fft.h" Chris@184: #include "kiss_fftr.h" Chris@184: #include Chris@184: Chris@184: Chris@184: static Chris@184: double two_tone_test( int nfft, int bin1,int bin2) Chris@184: { Chris@184: kiss_fftr_cfg cfg = NULL; Chris@184: kiss_fft_cpx *kout = NULL; Chris@184: kiss_fft_scalar *tbuf = NULL; Chris@184: Chris@184: int i; Chris@184: double f1 = bin1*2*M_PI/nfft; Chris@184: double f2 = bin2*2*M_PI/nfft; Chris@184: double sigpow=0; Chris@184: double noisepow=0; Chris@184: #if FIXED_POINT==32 Chris@184: long maxrange = LONG_MAX; Chris@184: #else Chris@184: long maxrange = SHRT_MAX;/* works fine for float too*/ Chris@184: #endif Chris@184: Chris@184: cfg = kiss_fftr_alloc(nfft , 0, NULL, NULL); Chris@184: tbuf = KISS_FFT_MALLOC(nfft * sizeof(kiss_fft_scalar)); Chris@184: kout = KISS_FFT_MALLOC(nfft * sizeof(kiss_fft_cpx)); Chris@184: Chris@184: /* generate a signal with two tones*/ Chris@184: for (i = 0; i < nfft; i++) { Chris@184: #ifdef USE_SIMD Chris@184: tbuf[i] = _mm_set1_ps( (maxrange>>1)*cos(f1*i) Chris@184: + (maxrange>>1)*cos(f2*i) ); Chris@184: #else Chris@184: tbuf[i] = (maxrange>>1)*cos(f1*i) Chris@184: + (maxrange>>1)*cos(f2*i); Chris@184: #endif Chris@184: } Chris@184: Chris@184: kiss_fftr(cfg, tbuf, kout); Chris@184: Chris@184: for (i=0;i < (nfft/2+1);++i) { Chris@184: #ifdef USE_SIMD Chris@184: double tmpr = (double)*(float*)&kout[i].r / (double)maxrange; Chris@184: double tmpi = (double)*(float*)&kout[i].i / (double)maxrange; Chris@184: #else Chris@184: double tmpr = (double)kout[i].r / (double)maxrange; Chris@184: double tmpi = (double)kout[i].i / (double)maxrange; Chris@184: #endif Chris@184: double mag2 = tmpr*tmpr + tmpi*tmpi; Chris@184: if (i!=0 && i!= nfft/2) Chris@184: mag2 *= 2; /* all bins except DC and Nyquist have symmetric counterparts implied*/ Chris@184: Chris@184: /* if there is power in one of the expected bins, it is signal, otherwise noise*/ Chris@184: if ( i!=bin1 && i != bin2 ) Chris@184: noisepow += mag2; Chris@184: else Chris@184: sigpow += mag2; Chris@184: } Chris@184: kiss_fft_cleanup(); Chris@184: /*printf("TEST %d,%d,%d noise @ %fdB\n",nfft,bin1,bin2,10*log10(noisepow/sigpow +1e-30) );*/ Chris@184: return 10*log10(sigpow/(noisepow+1e-50) ); Chris@184: } Chris@184: Chris@184: int main(int argc,char ** argv) Chris@184: { Chris@184: int nfft = 4*2*2*3*5; Chris@184: if (argc>1) nfft = atoi(argv[1]); Chris@184: Chris@184: int i,j; Chris@184: double minsnr = 500; Chris@184: double maxsnr = -500; Chris@184: double snr; Chris@184: for (i=0;i>4)+1) { Chris@184: for (j=i;j>4)+7) { Chris@184: snr = two_tone_test(nfft,i,j); Chris@184: if (snrmaxsnr) { Chris@184: maxsnr=snr; Chris@184: } Chris@184: } Chris@184: } Chris@184: snr = two_tone_test(nfft,nfft/2,nfft/2); Chris@184: if (snrmaxsnr) maxsnr=snr; Chris@184: Chris@184: printf("TwoToneTest: snr ranges from %ddB to %ddB\n",(int)minsnr,(int)maxsnr); Chris@184: printf("sizeof(kiss_fft_scalar) = %d\n",(int)sizeof(kiss_fft_scalar) ); Chris@184: return 0; Chris@184: }