我是傅立叶变换的新手,所以有人可以解释我需要做什么才能在 fftw 中复制这种行为:
double* timeDomain = static_cast< double* >( fftw_malloc( sizeof( double ) * SEGMENTATION_LENGTH ) );
fftw_complex* frequencyDomain = static_cast< fftw_complex* >( fftw_malloc( sizeof( fftw_complex ) * ( ( SEGMENTATION_LENGTH / 2 ) + 1 ) ) );
fftw_plan forward = fftw_plan_dft_r2c_1d( SEGMENTATION_LENGTH, timeDomain, frequencyDomain, FFTW_MEASURE );
我假设我要这样初始化我的 FFT 对象:
//2048 is smallest power of 2 larger than SEGMENTATION_LENGTH
FFT fourier = new FFT(2048,44100);
但我找不到任何与频域相关的方法。我可以fourier.forward(samples)
,但它不需要任何其他参数。有人可以提示我在这里需要做什么吗?