已知离散LTI离散系统3y(k)-4y(k-1)+y(k-2)=fk,激励fk=2εk,单位脉冲响应为hk=3的k次方εk,试编写MATLAB程序,求出该系统的零状态响应并作图,区间为0到20
时间: 2024-12-31 17:47:23 浏览: 19
要计算给定离散线性时不变(LTI)系统的零状态响应,我们首先需要了解系统函数H(z)。对于这个特定的差分方程,它是:
\[ 3y(k) - 4y(k-1) + y(k-2) = f_k \]
当激励 \( f_k = 2\delta[k] \),即单位脉冲响应 \( h_k = 3^k\delta[k] \),我们可以推断出系统函数H(z)。单位脉冲响应表示了系统对单位阶跃响应的拉普拉斯变换,而这里\( h_k \)表明系统是一个递归滤波器。
由于\( h_k = 3^k \),这意味着\( H(z) = \frac{3}{1 - 4z^{-1} + 3z^{-2}} \)。这是一个二阶递归滤波器,形式上可以用Z变换的卷积性质来找到零状态响应。但是为了简单起见,我们可以直接用Z变换的方法来解。
首先,我们需要定义系统的系数(a, b, c, d),然后使用`ztrans`函数进行Z变换。接着,计算零状态响应(zn),这可以通过以下步骤完成:
1. 定义系统参数
2. 计算系统函数
3. 找到zn(零输入响应)
4. 求和zn与hk得到零状态响应
5. 绘制结果
下面是MATLAB代码示例:
```matlab
% 参数定义
a = 3; % 常数项
b = -4;
c = 1;
d = 0;
% 单位脉冲响应hk
hk = [1 0 zeros(1, 20)]; % 从k=0到k=20,初始值为单位阶跃响应
hk(1) = 3; % 第1个位置对应于hk(0)=3
% Z变换系数
A = [1 a b];
B = [c d];
% 系统函数H(z)
H_z = tf(A, B);
% 零状态响应zn (因为d=0,所以直接为1)
zn = ztrans([1 zeros(1, length(hk)-1)], 'z');
% 零输入响应 zk = zn * H_z
zk = zn * impulse(H_z);
% 零状态响应ys = zk + hk
ys = zk + hk;
% 绘制零状态响应
t = (0:length(ys)-1)';
plot(t, ys);
xlabel('Time (k)');
ylabel('Response');
title('Zero State Response of the LTI System');
grid on;
```
运行这段代码后,你应该能看到系统的零状态响应曲线。
阅读全文