我是傅立叶变换的新手,所以有人可以解释一下我需要做什么才能在 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 );

使用 libgdx 的 FFT 类

我假设我想要初始化我的 FFT 对象:

//2048 is smallest power of 2 larger than SEGMENTATION_LENGTH
FFT fourier = new FFT(2048,44100); 

但我找不到任何与频域相关的方法。我可以 fourier.forward(samples), ,但它不需要任何其他参数。有人可以给我一个提示,告诉我我需要在这里做什么吗?

有帮助吗?

解决方案

我想我已经找到了解决方案,有一个 backward 的方法 FFT 它采用调用后可以获得的频域实部和虚部值 forward.

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top