簡體   English   中英

FFT:查找並削減信號中有噪聲的50Hz

[英]FFT: find and cut noisy 50Hz in signal

我有嘈雜的數據 (周期為1.8s的峰值,每個周期2048個bin),我想為此計算頻率並刪除50Hz。 我很確定我要尋找的頻率是50Hz,因為我是通過使用originlab找到的。

當我嘗試在python中執行相同操作時,平均峰值為〜47Hz。 我正在尋找教程和示例,但結果仍然相同。

import numpy as np
from scipy.fftpack import fft
from scipy.fftpack import fftfreq
import matplotlib.pyplot as plt
data = np.loadtxt('3.dat', comments="#")
t = data[:, 0]
y = data[:, 2]
len_data = len(data)
bins = 2048
plt.figure(figsize=(7, 9))
plt.subplot(211)
plt.plot(t, y, 'b-')
plt.xlabel("time[sec]")
plt.ylabel("original signal")
plt.subplot(212)
F = fft(y)
freq = fftfreq(len(t), (t[1] - t[0]))
ipos = np.where(freq > 0)
freqs = freq[ipos]
mags = np.abs(F[ipos])
plt.plot(freqs, mags, 'b-')
plt.xlabel("freq")
plt.ylabel("POWER")
plt.savefig('stoc.png')
plt.show()

有人可以幫我解決問題嗎?

我必須恢復關於消除噪音的問題。 當我減去頻率時,信號幅度會大大降低。 這個對嗎?

data = np.loadtxt('3.dat', comments="#")
t = data[:, 0]
phase = data[:, 1]
y = data[:, 2]
pulse_no = data[:, 3]
len_data = len(data)
bins = 2048
ti = np.linspace(t[0], t[-1], len_data)
yi = np.interp(ti, t, y)
t, y = ti, yi

plt.figure(figsize=(10, 10))
plt.subplot(511)
plt.plot(t, y, 'b-')
plt.xlabel("time[sec]")
plt.ylabel("original signal")
plt.subplot(512)
F = fft(y)
N = len(t)
w = fftfreq(N, (t[1] - t[0]))
ipos = np.where(w > 0)
freq = w[ipos]
mags = abs(F[ipos])
plt.plot(freq, mags)
ip = np.where(F > 0)[0]
Fs = np.copy(F)
yf = ifft(Fs)
ip = np.where(F > 0)[0]
Ff = np.copy(F)
Ff[ip > ip[[(181)]]] = 0
Ff[ip < ip[[(175)]]] = 0
magsf = abs(Ff[ipos])
plt.plot(freq, magsf, 'r-')
plt.subplot(513)
Fr = mags - magsf
plt.plot(freq, Fr)
plt.subplot(514)
yf = ifft(Ff)
yr = ifft(Fr)
plt.plot(t, yf)
plt.subplot(515)
flux = y - np.real(yf)
plt.plot(t, flux)
plt.plot(t, y)
plt.show()

您的問題似乎是您的時間網格不是均勻分布的:

In [83]: d = np.diff(data[:,0])

In [84]: d
Out[84]: 
array([ 0.0006144 ,  0.0006144 ,  0.00049152, ...,  0.0006144 ,
        0.0006144 ,  0.00049152])

如果我將值插值到一個恆定的時間間隔:

data = np.loadtxt('3.dat', comments="#")
t = data[:, 0]
y = data[:, 2]
len_data = len(data)

ti = np.linspace(t[0], t[-1], len_data)
yi = np.interp(ti, t, y)
t, y = ti, yi

峰值為50 Hz:

在此處輸入圖片說明

暫無
暫無

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

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