从 FFT 中获取幅度最高的频率

2023-12-25

我有 x、y、z 轴形式的原始加速度计数据,这些数据经过平滑处理,并应用了带通滤波器。现在我想将其转换为频域信号并使用scipy.fftpack.fft应用 FFT。

sampling_frequency = 32
def fft(acc_data):
  N = len(acc_data)

  fft_data = sp.fftpack.fft(acc_data)
  freqs = sp.fftpack.fftfreq(N)

  plt.bar(freqs, np.abs(fft_data)) 
  plt.xlabel('Frequency in Hertz [Hz]')
  plt.ylabel('Magnitude')
  plt.title('FFT')
  plt.show()

该图没有绘制点并且是空的。 fft 的返回值是一个复数数组。我在用着fftfreq以获得最高振幅的频率。

有人能指出哪里错了,或者举例说明如何通过应用 FFT 获得最高振幅的频率值吗?

完整代码可用here https://github.com/apoorvam/smart-sensing/blob/master/bio_watch.py


我建议您远离代码,首先掌握执行 fft 调用的能力,并理解该调用返回的结果……要么读取已知频率的正弦曲线,要么只编写一个函数来填充数组浮点正弦曲线(这是您的时域信号)...然后将该数组输入到 fft 调用中,该调用通常会返回给您一个新的复数数组...这个新数组的每个元素现在位于频域表示一个频率值...频率仓...该频率的幅度可以使用以下公式计算

nyquist_limit_index := int(number_of_samples / 2)

curr_freq := 0.0
incr_freq := flow_data_spec.sample_rate / number_of_samples

for index, curr_complex := range complex_fft { 

    if index <= nyquist_limit_index  {

        curr_real = real(curr_complex) // pluck out real portion of imaginary number
        curr_imag = imag(curr_complex) // ditto for im

        curr_mag = 2.0 * math.Sqrt(curr_real*curr_real+curr_imag*curr_imag) / number_of_samples

        curr_theta = math.Atan2(curr_imag, curr_real) // phase shift of this freq

        curr_dftt := discrete_fft { // populate a struct of current array element

            real:      2.0 * curr_real,
            imaginary: 2.0 * curr_imag,
            magnitude: curr_mag,
            theta:     curr_theta,
        }

        //  optionally stow curr_dftt for later
    }

    curr_freq += incr_freq
}

其中 number_of_samples 只是您输入 fft 调用的时域数组的长度

上面的代码向您展示了如何迭代从早期的 fft 调用返回给您的复数频域数组...上面是伪代码而不是 python,但您的过程可能会非常相似

要识别具有最大幅度的频率( curr_freq ),只需跟踪上面循环中的 curr_freq 具有最大幅度...在我们的玩具设置中,您可能很清楚源输入正弦曲线的频率,因此应弹出相同的频率上面的 curr_freq 具有最大的量级......在您完成此工作并理解其概念后,然后将您所学到的知识应用到您手头的任务中 - 祝您好运

傅立叶分析及其各种咒语非常强大,可以打开许多扇门。这是一个需要思考的话题,但如果我们允许自己简单地将一些 api 调用插入在一起来让某些东西正常工作,我们确实错过了一些非常神奇的东西

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

从 FFT 中获取幅度最高的频率 的相关文章

随机推荐