数字信号处理学习笔记--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);
相关推荐
问心无愧05131 天前
ctf show web入门156
笔记
咸甜适中1 天前
rust语言学习笔记Trait(八)Iterator(迭代器)
笔记·学习·rust
华为云开发者联盟1 天前
告别繁琐操作,华为云码道 + Docker重塑远程开发体验
人工智能·学习·docker·华为云·软件开发·华为云码道
Bechamz1 天前
大数据开发学习Day38
大数据·学习
-To be number.wan1 天前
计算机组成原理 | 原码一位乘法运算方法
学习·计算机组成原理
前端若水1 天前
从零开始学习AI Agent的实战路线图
人工智能·学习
ZhiqianXia1 天前
流畅的Python笔记
笔记·python
魔法阵维护师1 天前
从零开发游戏需要学习的c#模块,第十一章(rpg小游戏入门,上篇,地图与移动)
学习·游戏·c#
qq_525513751 天前
# 第七章 指令微调学习(四) 7.6基于指令数据对大语言模型进行微调
深度学习·学习·语言模型
玄米乌龙茶1231 天前
LLM成长笔记(四):大语言模型(LLM)基础认知
人工智能·笔记·语言模型