考虑一个简单的线性时不变系统,其形式为:
该系统的脉冲响应可以通过 dimpulse 或通过将 lfilter 应用于由 1 后跟 0 组成的向量来计算:
import scipy.signal as sp_signal
import numpy as np
Ts = 1
c = 0.9
A = [1, -c]
B = [1-c]
time, imp_resp1 = sp_signal.dimpulse((B, A, Ts))
x = np.zeros(100)
x[0] = 1
imp_resp2 = sp_signal.lfilter(B, A, x)
print(imp_resp1[0][:5,0])
print(imp_resp2[:5])
产生:
array([ 0. , 0.1 , 0.09 , 0.081 , 0.0729])
[ 0.1 0.09 0.081 0.0729 0.06561]
为什么dimpulse会在脉冲响应中引入一个样本延迟?