数字信号处理学习笔记--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);
相关推荐
lilihuigz8 小时前
Tutor LMS 4.0 Beta版全新上线:以学习者为中心的移动优先学习体验
学习·在线教育·lms
William Dawson8 小时前
2026软考中级系统集成项目管理工程师备考笔记
笔记·系统集成项目管理工程师
love530love11 小时前
精简版|Claude-HUD 插件介绍 + 一键安装教程
人工智能·windows·笔记
kuinnebula11 小时前
RTSP学习
学习
想成为优秀工程师的爸爸11 小时前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
北顾笙98012 小时前
LLM学习-day04
学习
tq108613 小时前
数学:约束表征空间的最小闭包
笔记
lzj_pxxw14 小时前
W25Q64存储芯片 软件设计刚需常识
stm32·单片机·嵌入式硬件·mcu·学习
Slow菜鸟14 小时前
AI学习篇(四) | AI设计类Skills推荐清单(2026年)
人工智能·学习
freexyn14 小时前
Matlab自学笔记七十六:表达式的展开、因式分解、化简、合并同类项
笔记·算法·matlab