带通、低通和高通滤波python代码

本文展示了如何使用Python的scipy.signal模块实现带通、低通和高通滤波,通过butter_filt函数对包含噪声的正弦信号进行滤波处理,并用matplotlib展示原始数据和滤波后的结果。
摘要由CSDN通过智能技术生成

import numpy as np
import matplotlib.pyplot as plt
import scipy.signal

def butter_filt(data, fs=100., Wn=[0.5, 1], btype='bandpass', N=5, axis=-1):
    nqy = 0.5 * fs

    if btype not in ['bandpass', 'lowpass', 'highpass']:
        raise ValueError("Invalid filter type. Use 'bandpass', 'lowpass', or 'highpass'.")

    wn = [wn / nqy if btype == 'bandpass' else wn / fs for wn in Wn]

    b, a = scipy.signal.butter(N, wn, btype)
    filt_data = scipy.signal.filtfilt(b, a, data, padtype='odd', axis=axis)

    return filt_data

# 生成示例数据
fs = 200.0  # 采样率
t = np.arange(0, 5, 1/fs)  # 时间数组
data = np.sin(2 * np.pi * 10 * t) + 0.5 * np.random.randn(len(t))  # 包含噪声的正弦信号

# 使用带通滤波器过滤数据
filtered_data = butter_filt(data, fs=fs, Wn=[8, 12], btype='bandpass', N=4)

# 绘制原始数据和滤波后的数据
plt.figure(figsize=(10, 6))
plt.plot(t, data, label='Original Data', alpha=0.7)
plt.plot(t, filtered_data, label='Filtered Data', linewidth=2)
plt.title('Original and Filtered Data')
plt.xlabel('Time (s)')
plt.ylabel('Amplitude')
plt.legend()
plt.grid(True)
plt.show()

# 使用高通滤波器过滤数据
filtered_data = butter_filt(data, fs=fs, Wn=5, btype='highpass', N=4)

# 绘制原始数据和滤波后的数据
plt.figure(figsize=(10, 6))
plt.plot(t, data, label='Original Data', alpha=0.7)
plt.plot(t, filtered_data, label='Filtered Data', linewidth=2)
plt.title('Original and High-pass Filtered Data')
plt.xlabel('Time (s)')
plt.ylabel('Amplitude')
plt.legend()
plt.grid(True)
plt.show()

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值