Я ищу, как превратить частотную ось в fft (полученную через scipy.fftpack.fftfreq) в частоту в Hertz, а не в бины или дробные ячейки.
Я попытался выполнить код ниже, чтобы проверить FFT:
t = scipy.linspace(0,120,4000)
acc = lambda t: 10*scipy.sin(2*pi*2.0*t) + 5*scipy.sin(2*pi*8.0*t) + 2*scipy.random.random(len(t))
signal = acc(t)
FFT = abs(scipy.fft(signal))
FFT = scipy.fftpack.fftshift(FFT)
freqs = scipy.fftpack.fftfreq(signal.size)
pylab.plot(freqs,FFT,'x')
pylab.show()
Частота дискретизации должна составлять 4000 отсчетов /120 секунд = 33,34 выборок в секунду.
Сигнал имеет сигнал 2,0 Гц, сигнал 8,0 Гц и некоторый случайный шум.
Я беру БПФ, хватаю частоты и рисую. Цифры довольно бессмысленны. Если я умножу частоты на 33,34 (частота дискретизации), то получаю пики около 8 Гц и 15 Гц, что кажется неправильным (также частоты должны быть в 4 раз, а не 2!).
Любые мысли о том, что я делаю неправильно здесь?