matlab中滤波器filter函数与python中lfilter函数

  • Matlab中filter函数的详解

输入数据x为1-D的情况

windowSize = 3;
b = (1/windowSize)*ones(1,windowSize);
a = 1;

x = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6];
y = filter(b, a, x);

# OUT: y = [0.033333, 0.1, 0.2, 0.3, 0.4, 0.5]

计算过程:

x被pad为[0, 0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6],在最前端填充windowSize-1个0

y(1) = (0 + 0 + 0.1) / 3 = 0.033333

y(2) = (0 + 0.1 + 0.2) / 3 = 0.1

y(3) = (0.1 + 0.2 + 0.3) / 3 = 0.2

y(6) = (0.4 + 0.5 + 0.6) / 3 = 0.5

  • python中lfilter函数与上述操作相同
from scipy.signal import lfilter
import numpy as np

windowSize = 3
b = (1/windowSize)*np.ones(windowSize)
a = 1

x = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6]
y = lfilter(b, a, x)

# OUT: y = [0.033333, 0.1, 0.2, 0.3, 0.4, 0.5]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值