信号与系统MATLAB实验(教师版) 下载本文

实验五 信号抽样与恢复

一、实验目的

学会用MATLAB实现连续信号的采样和重建 二、实验原理 1.抽样定理

若f(t)是带限信号,带宽为?m, f(t)经采样后的频谱Fs(?)就是将f(t)的频谱

F(?)在频率轴上以采样频率?s为间隔进行周期延拓。因此,当?s??m时,不会发生频

率混叠;而当 2.信号重建

经采样后得到信号fs(t)经理想低通h(t)则可得到重建信号f(t),即:

?s

f(t)=fs(t)*h(t)

其中:fs(t)=f(t)??(t?nT)=?f(nT)?(t?nT)

sss???????ch(t)?TsSa(?ct)

?所以:

f(t)=fs(t)*h(t)=?f(nTs)?(t?nTs)*Ts????cSa(?ct) ?? =Tsc??f(nT)Sa[?(t?nT)]

scs???上式表明,连续信号可以展开成抽样函数的无穷级数。

利用MATLAB中的sinc(t)?tsin(?t)来表示Sa(t),有 Sa(t)?sinc(),所以可以?t?得到在MATLAB中信号由f(nTs)重建f(t)的表达式如下:

?f(t)=Tsc?????f(nTs)sinc[?c(t?nTs)] ?我们选取信号f(t)=Sa(t)作为被采样信号,当采样频率?s=2?m时,称为临界采样。我们取理想低通的截止频率?c=?m。下面程序实现对信号f(t)=Sa(t)的采样及由该采样

21

信号恢复重建Sa(t):

例5-1 Sa(t)的临界采样及信号重构;

wm=1; %信号带宽

wc=wm; %滤波器截止频率 Ts=pi/wm; %采样间隔

ws=2*pi/Ts; %采样角频率 n=-100:100; %时域采样电数 nTs=n*Ts %时域采样点 f=sinc(nTs/pi);

Dt=0.005;t=-15:Dt:15;

fa=f*Ts*wc/pi*sinc((wc/pi)*(ones(length(nTs),1)*t-nTs'*ones(1,length(t)))); %信号重构 t1=-15:0.5:15; f1=sinc(t1/pi); subplot(211); stem(t1,f1); xlabel('kTs'); ylabel('f(kTs)');

title('sa(t)=sinc(t/pi)的临界采样信号'); subplot(212); plot(t,fa) xlabel('t'); ylabel('fa(t)');

title('由sa(t)=sinc(t/pi)的临界采样信号重构sa(t)'); grid;

例5-2 Sa(t)的过采样及信号重构和绝对误差分析

程序和例4-1类似,将采样间隔改成Ts=0.7*pi/wm , 滤波器截止频率该成wc=1.1*wm , 添加一个误差函数 wm=1;

wc=1.1*wm; Ts=0.7*pi/wm; ws=2*pi/Ts; n=-100:100; nTs=n*Ts

f=sinc(nTs/pi);

Dt=0.005;t=-15:Dt:15;

fa=f*Ts*wc/pi*sinc((wc/pi)*(ones(length(nTs),1)*t-nTs'*ones(1,length(t)))); error=abs(fa-sinc(t/pi)); %重构信号与原信号误差 t1=-15:0.5:15; f1=sinc(t1/pi); subplot(311); stem(t1,f1); xlabel('kTs');

22

ylabel('f(kTs)');

title('sa(t)=sinc(t/pi)的采样信号'); subplot(312); plot(t,fa) xlabel('t'); ylabel('fa(t)');

title('由sa(t)=sinc(t/pi)的过采样信号重构sa(t)'); grid;

subplot(313); plot(t,error); xlabel('t');

ylabel('error(t)');

title('过采样信号与原信号的误差error(t)');

例5-3 Sa(t)的欠采样及信号重构和绝对误差分析

程序和例4-2类似,将采样间隔改成Ts=1.5*pi/wm , 滤波器截止频率该成wc=wm=1

三、上机实验内容

1.验证实验原理中所述的相关程序;

2.设f(t)=0.5*(1+cost)*(u(t+pi)-u(t-pi)) ,由于不是严格的频带有限信号,但其频谱大部分集中在[0,2]之间,带宽wm可根据一定的精度要求做一些近似。试根据以下两种情况用 MATLAB实现由f(t)的抽样信号fs(t)重建f(t) 并求两者误差,分析两种情况下的结果。 (1) wm=2 , wc=1.2wm , Ts=1; (2) wm=2 , wc=2 , Ts=2.5

23

实验六 信号与系统复频域分析

一、实验目的

1.学会用MATLAB进行部分分式展开; 2.学会用MATLAB分析LTI系统的特性; 3.学会用MATLAB进行Laplace正、反变换。 4.学会用MATLAB画离散系统零极点图; 5.学会用MATLAB分析离散系统的频率特性;

二、实验原理及内容

1.用MATLAB进行部分分式展开

用MATLAB函数residue可以得到复杂有理分式F(s)的部分分式展开式,其调用格式为 ?r,p,k??residue(num,den)

其中,num,den分别为F(s)的分子和分母多项式的系数向量,r为部分分式的系数,p为极点,k为F(s)中整式部分的系数,若F(s)为有理真分式,则k为零。

例6-1 用部分分式展开法求F(s)的反变换 F(s)?s?2

s3?4s2?3s解:其MATLAB程序为 format rat; num=[1,2]; den=[1,4,3,0];

[r,p]=residue(num,den)

程序中format rat是将结果数据以分数形式显示

?1?0.56 ?F(s)可展开为 F(s)?3?ss?1s?3所以,F(s)的反变换为 f(t)???e?e6?322?21?t1?3t?ut( )??2.用MATLAB分析LTI系统的特性

系统函数H(s)通常是一个有理分式,其分子和分母均为多项式。计算H(s)的零极点可以应用MATLAB中的roots函数,求出分子和分母多项式的根,然后用plot命令画图。

在MATLAB中还有一种更简便的方法画系统函数H(s)的零极点分布图,即用pzmap函数画图。其调用格式为

pzmap(sys)

sys表示LTI系统的模型,要借助tf函数获得,其调用格式为

sys=tf(b,a)

24