DSP Java FFt Jtransform

Posted

技术标签:

【中文标题】DSP Java FFt Jtransform【英文标题】: 【发布时间】:2015-12-17 09:45:24 【问题描述】:

在我的项目中,我有一个包含 EEG 探针的文件(16338 个探针,256 Hz 采样率)。它看起来像这样:

在我的程序中,我需要从时域切换到频域。我正在使用 Jtransform lib 来做到这一点,但我被困住了。 我已经用double 数组中的探针加载了我的列,并从 Jtransform lib 进行了双复 FFT。代码如下所示:

int N= chanel.length;
int Fs=256;
double re;
double im;
double fft[]=new double[N*2];
double[] magnitude = new double[N/2];

//System.arraycopy(chanel,0,fft,0,chanel.length);

for (int i=0; i<N-1; i++)

  fft[2*i]=chanel[i];
  fft[2*i+1]=0;


DoubleFFT_1D fftDo =new DoubleFFT_1D(N);
fftDo.complexForward(fft);

for(int i=0;i<N/2-1;i++)

  re=fft[2*i];
  im=fft[2*i+1];

  magnitude[i]=Math.sqrt(re*re+im*im);


double max_magnitude =-999999999;
int max_index = -1;
for (int i=0; i<N/2-1;i++)

  if (magnitude[i]>max_magnitude)
  
    max_magnitude=magnitude[i];
    max_index=i;
  


double dominantFreq =  max_index*Fs/N;

这些是该代码不同部分的输出:

我阅读了很多关于 DSP 的文章,并试图从我的教授那里得到一些建议,但他只给了我一些我不太明白的数学公式。我需要绘制频域图,但我仍然不知道如何从那一点获得这些频率(我知道这很愚蠢,因为它非常接近解决方案,但在阅读了一周的 DSP 后我无法弄清楚)。所以我的问题是:

有人可以尝试用我最简单的方式解释它,或者用伪代码或一些例子来展示吗?

【问题讨论】:

【参考方案1】:

因此,您从 256Hz 采样数据开始,并且您有 16388 个 bin,结果应该以每个 bin 0.015621186 Hz 的步长为单位。您可以绘制幅度与频率的关系图,每个 bin 向上计数 0.01562 Hz,最高可达 128 Hz(采样率/2)。一种方法是将幅度数据放入 Excel 中,并将单元格编号乘以 0.01562 以获得频率,然后将其全部选中并创建一个图表。

在这里,我修改了您的一个循环以输出频率。

double step = Fs/N; // 0.015621186;
double freq = 0;
double freqs[] = double[N/2];
for(int i=0;i<N/2-1;i++)

    re=fft[2*i];
    im=fft[2*i+1];

    magnitude[i]=Math.sqrt(re*re+im*im);
    freqs[i] = freq;

    freq = freq + step;

否则您可以使用 Java 图形库。

从概念上讲,这些幅度数字中的每一个都是加在一起的 bin 频率范围之间 bin 中所有正弦波的幅度。

总而言之,您拥有数据,只需绘制图表即可。您还可以显示您在图表上找到的“主要频率”以查看其外观。

【讨论】:

非常感谢!我还有一个问题,您是如何获得此步长值的?我需要从其他所有输入文件中获取它。

以上是关于DSP Java FFt Jtransform的主要内容,如果未能解决你的问题,请参考以下文章

TI DSP FFT库函数

F2833x 调用DSP函数库实现复数的FFT的方法

STM32F4使用DSP库进行FFT运算的测试过程二

DSP FFT基频wav文件

如何使用STM32提供的DSP库进行FFT

DSP5509项目之用FFT识别钢琴音调