巴特沃斯低通滤波器
创始人
2024-11-26 09:30:34
0

以下是一个使用Python实现巴特沃斯低通滤波器的示例代码:

import numpy as np
import matplotlib.pyplot as plt
from scipy.signal import butter, filtfilt

def butter_lowpass(cutoff, fs, order=5):
    nyquist = 0.5 * fs
    normal_cutoff = cutoff / nyquist
    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 = 100.0  # 采样频率
t = np.arange(0, 1, 1/fs)  # 时间向量
f1 = 5  # 信号频率
f2 = 20  # 干扰频率
data = np.sin(2*np.pi*f1*t) + 0.5*np.sin(2*np.pi*f2*t)

# 设计低通滤波器
cutoff = 10  # 截止频率
order = 6  # 滤波器阶数
filtered_data = butter_lowpass_filter(data, cutoff, fs, order)

# 绘制结果
plt.figure(figsize=(10, 4))
plt.plot(t, data, 'b-', label='Original Data')
plt.plot(t, filtered_data, 'r-', linewidth=2, label='Filtered Data')
plt.xlabel('Time [sec]')
plt.ylabel('Amplitude')
plt.legend()
plt.grid(True)
plt.show()

以上代码中,butter_lowpass函数用于设计巴特沃斯低通滤波器,返回滤波器的系数。butter_lowpass_filter函数则使用这些系数对输入数据进行滤波处理。在示例中,我们生成了一个包含两个频率成分的示例数据,然后使用低通滤波器对其进行滤波,截止频率为10Hz,滤波器阶数为6。最后,我们使用Matplotlib库绘制了原始数据和滤波后的数据的图形。

相关内容

热门资讯

六分钟了解!雀神辅助器免费下载... 六分钟了解!雀神辅助器免费下载(辅助挂)竟然真的有挂(有挂神器)-哔哩哔哩;人气非常高,ai更新快且...
玩家必用!wepoke防外挂!... 玩家必用!wepoke防外挂!确实是真的有挂((2021已更新))(哔哩哔哩)1、这是跨平台的wep...
九分钟普及!wpk德州透视辅助... 1、九分钟普及!wpk德州透视辅助(透视)软件透明挂((2025已更新))(哔哩哔哩);详细教程。2...
重大发现!广东雀神免费智能辅助... 重大发现!广东雀神免费智能辅助下载(辅助挂)果真真的有挂(真实有挂)-哔哩哔哩;是一款可以让一直输的...
研究成果!aapoker辅助软... 研究成果!aapoker辅助软件!竟然真的有挂((2020已更新))(哔哩哔哩)是一款可以让一直输的...
十分钟普及!扑克王辅助工具(辅... 十分钟普及!扑克王辅助工具(辅助挂)辅助透视((2022已更新))(哔哩哔哩)是一款可以让一直输的玩...
透明教学!雀神广东麻雀正规(辅... 透明教学!雀神广东麻雀正规(辅助挂)原来是真的有挂(有挂技术)-哔哩哔哩;一、雀神广东麻雀正规AI软...
盘点一款!德州之星辅助透视!其... 盘点一款!德州之星辅助透视!其实真的有挂((2022已更新))(哔哩哔哩)是一款可以让一直输的玩家,...
7分钟普及!EV扑克辅助软件(... 您好,EV扑克这款游戏可以开挂的,确实是有挂的,需要了解加微【439369440】很多玩家在这款游戏...
玩家攻略推荐!雀神麻将辅牌器购... 玩家攻略推荐!雀神麻将辅牌器购买(辅助挂)果真真的有挂(有挂详细)-哔哩哔哩1、完成雀神麻将辅牌器购...