Butterworth滤波器在信号开始时产生极端异常值。
创始人
2025-01-10 02:30:51
0

在使用Butterworth滤波器时,需要注意到它会在信号开始部分(尤其是在低通滤波的情况下)产生极端异常值。这是由于Butterworth滤波器本质上是一种时域卷积滤波器,没有考虑到信号的初始条件。因此,需要在信号开始之前添加所需的初始值或进行其他处理。

代码示例:

加载数据

import numpy as np import matplotlib.pyplot as plt

生成原始信号

N = 100 x = np.linspace(0, 10, N) y = np.sin(x) + 0.2 * np.random.randn(N)

应用Butterworth滤波器

from scipy.signal import butter, filtfilt

def butter_lowpass(cutoff, fs, order=5): nyq = 0.5 * fs normal_cutoff = cutoff / nyq b, a = butter(order, normal_cutoff, btype='low', analog=False) return b, a

def butter_lowpass_filter(data, cutoff, fs, order=5): b, a = butter_lowpass(cutoff, fs, order=order) y = filtfilt(b, a, data) return y

定义截止频率和滤波器阶数

fs = 40.0 cutoff = 3.0

应用滤波器前,先添加所需的初始值(这里假设初始值为0)

y_f = np.insert(y, 0, np.zeros(10)) y_f = butter_lowpass_filter(y_f, cutoff, fs) y_f = y_f[10:]

绘图比较

plt.figure(figsize=(10, 6)) plt.plot(x, y, 'b-', label='raw signal') plt.plot(x, y_f, 'r-', label='filtered') plt.xlabel('time') plt.ylabel('amplitude') plt.title('

相关内容

热门资讯

透视讲解!wepoker好友助... 透视讲解!wepoker好友助力码,wepoker底牌透视(都是是真的有挂)1、每一步都需要思考,不...
透视ai代打!wepoker养... 透视ai代打!wepoker养号规律,wepoker有没有挂(果然是真的有挂)1、wepoker有没...
透视科技!wepoker辅助器... 透视科技!wepoker辅助器软件下载,wepoker游戏安装教程(一贯是真的有挂)1、下载好wep...
透视能赢!wepoker透视有... 透视能赢!wepoker透视有没有,wepoker俱乐部辅助器(果然有挂);1)wepoker俱乐部...
透视攻略!wepoker怎么下... 透视攻略!wepoker怎么下载游戏,wepoker怎么破解游戏(本来真的有挂)wepoker怎么破...
透视透视!wepoker轻量版... 透视透视!wepoker轻量版书签,wepoker有透视吗(原来是真的有挂)1、进入游戏-大厅左侧-...
透视中牌率!wepoker免费... 透视中牌率!wepoker免费脚本咨询,wepoker怎么提高运气(一直真的有挂)1、每一步都需要思...
透视辅助!wepoker可以免... 透视辅助!wepoker可以免费玩吗,wepokerplus作弊(一直存在有挂);1)wepoker...
透视最新!wepoker辅助真... 透视最新!wepoker辅助真的假的,wepoker黑侠辅助器(都是真的是有挂)1、打开软件启动之后...
透视了解!wepokerplu... 透视了解!wepokerplus到底是挂了吗,wepoker私人局俱乐部辅助(都是是真的有挂)1、w...