数字信号处理学习笔记--Chapter 1.3 常系数线性差分方程

1 线性常系数差分方程的表达形式

  • 常系数:是指方程中ak和bm为常数;
  • 阶数:y(n)项中变量序号的最高值与最低值之差;
  • 线性:y(n-k)与x(n-m)项都只有一次幂,且不存在相乘项

2 线性常系数差分方程的求解方法

  • 经典解法:类似于模拟系统求解微分方程的方法,要求齐次解、特解,并由边界条件求待定系数。由于计算复杂,较少使用。
  • 递推(迭代)法:简单、适于用计算机进行求解。但只能得到一系列数值解,不易得到封闭式(公式)解答。
  • 变换域法:将差分方程变换到Z域求解。
  • 卷积法:由差分方程求出系统的h(n),再与已知的x(n)进行卷积,得到y(n)。

例:用迭代法求解差分方程,求单位抽样响应h(n)

设系统差分方程为:y(n) - ay(n-1) = x(n),求h(n)

解1:设x(n) = δ(n),对因果系统,且有当n<0时,y(n)=h(n)=0

h(0) = ah(-1) + δ(0) = 0 + 1 = 1

h(1) = ah(0) + δ(1) = a + 0 = a

h(2) = ah(1) + δ(2) = a^2 + 0 = a^2

......

h(n) = ah(n-1) + δ(n) = a^n + 0 = a^n

因此系统的单位抽样响应为h(n) = a^nu(n),这个系统显然是因果系统,当|a| < 1时,它还是稳定系统。

注意:一个常系数线性差分方程,并不一定代表因果系统。如果边界条件假设不同,可以得到非因果系统

解2: 设x(n) = δ(n),且有当n>0时,y(n)=h(n)=0

往之前时刻进行推导,y(n-1)=a^(-1)[y(n) - x(n)]

h(0) = a^(-1)[h(1) - δ(1)] = 0

h(-1) = a^(-1)[h(0) - δ(0)] = -a^(-1)

h(-2) = a^(-1)[h(-1) - δ(-1)] = -a^(-2)

......

h(-n) = a^(-1)[h(-n+1) - δ(-n+1)] = -a^(-n)

因此系统的单位抽样响应为h(n) = -a^(-n)u(-n-1)。显然这个系统是非因果系统。

差分方程表示法优点:可以直接得到系统的结果。

例:差分方程

该差分方程所表示的结果如下:

消耗2个乘法器、1个加法器、1个延迟单元(存储单元Z^(-1),用于存储上一时刻的值y(n-1))

3 MATLAB中实现差分方程递推解的filter函数

函数形式为y = filter(b, a, x),其中b = [b0, b1, ..., bM],a = [a0, a1, ..., aN],且a0 != 0,x为输入序列,y为输出序列

例:y(n) - 0.5y(n - 1) = 0.5x(n)

Matlab 复制代码
%% 方法1:使用filter函数
% 定义系统系数
% 标准形式: a(1)*y(n) + a(2)*y(n-1) + ... = b(1)*x(n) + b(2)*x(n-1) + ...
% 原方程: y(n) - 0.5y(n-1) = 0.5x(n)
% 所以: a = [1, -0.5], b = [0.5]

a = [1, -0.5];  % 分母系数(y的系数)
b = [0.5];      % 分子系数(x的系数)

% 生成输入信号
N = 50;  % 信号长度
n = 0:N-1;

% 测试不同输入信号
% 1. 单位脉冲信号
x1 = [1, zeros(1, N-1)];

% 2. 单位阶跃信号
x2 = ones(1, N);

% 3. 正弦信号
x3 = sin(2*pi*0.1*n);

%% 计算响应
% filter(b, a, x, ic) - ic是初始条件
% 零初始条件
y1 = filter(b, a, x1);
y2 = filter(b, a, x2);
y3 = filter(b, a, x3);
相关推荐
东北洗浴王子讲AI2 小时前
GPT-5.4英语口语学习全攻略:从开口困难到流利表达的进阶之路
gpt·学习
王的宝库2 小时前
GitLab 常用 Git 命令新手指南
git·学习
ruan1145142 小时前
MySQL -- 个人学习记录
学习
NULL指向我2 小时前
TMS320F28379D笔记1:主控-从核双核架构认识
笔记·单片机
m0_716765232 小时前
数据结构三要素、时间复杂度计算详解
开发语言·数据结构·c++·经验分享·笔记·算法·visual studio
我不是懒洋洋3 小时前
AI的影响7
笔记
red_redemption3 小时前
自由学习记录(161)
学习
南境十里·墨染春水3 小时前
linux学习进展 主函数的参数
linux·运维·学习
淮北4943 小时前
obsidian管理自己的计划
linux·学习·kanban·obsidian