簡體   English   中英

如何使用 scipy FFT 限制頻率范圍

[英]How to limit frequency range using scipy FFT

我正在使用 FFT 找到信號的頻率。 我只對 1 到 4 Hz 之間的特定頻率范圍感興趣。

我有這個代碼來計算頻率:

from scipy.fft import rfft, rfftfreq, irfft

plt.plot(d)
plt.show()
N = len(d)
yf = rfft(d)
xf = rfftfreq(N, 1 / sample_rate) # 29
plt.plot(xf, np.abs(yf))
plt.show()

結果是:

在此處輸入圖像描述

如何修改我的代碼,使xfyf僅對應於我想要的 1-4 Hz 范圍內的頻率,而不是 plot 中看到的 0-15?

您可以使用xlimmatplotlib功能來修改x axis

這是您可以參考的示例代碼。

from scipy.fft import fft, fftfreq
import numpy as np
# Number of sample points
N = 600
# sample spacing
T = 1.0 / 800.0
x = np.linspace(0.0, N*T, N, endpoint=False)
y = np.sin(50.0 * 2.0*np.pi*x) + 0.5*np.sin(80.0 * 2.0*np.pi*x)
yf = fft(y)
xf = fftfreq(N, T)[:N//2]
import matplotlib.pyplot as plt
plt.plot(xf, 2.0/N * np.abs(yf[0:N//2]),'b')
plt.plot()
plt.grid()
plt.show()

在此處輸入圖像描述

plt.plot(xf, 2.0/N * np.abs(yf[0:N//2]),'b')
plt.xlim(0,100) # you need this
plt.grid()
plt.show()

在此處輸入圖像描述

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM