【教学课件】第4章MATLAB在信号处理中的应用.ppt
《【教学课件】第4章MATLAB在信号处理中的应用.ppt》由会员分享,可在线阅读,更多相关《【教学课件】第4章MATLAB在信号处理中的应用.ppt(40页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第 4 章 MATLAB在信号处理中的应用 第第4章章 MATLAB在信号处理中的应用在信号处理中的应用 4.1 信号及其表示信号及其表示4.2 信号的基本运算信号的基本运算 4.3 信号的能量和功率信号的能量和功率 4.4 线性时不变系统线性时不变系统4.5 线性时不变系统的响应线性时不变系统的响应4.6 线性时不变系统的频率响应线性时不变系统的频率响应 4.7 傅里叶傅里叶(Fourier)变换变换4.8 IIR数字滤波器的设计方法数字滤波器的设计方法4.9 FIR数字滤波器设计数字滤波器设计第 4 章 MATLAB在信号处理中的应用 4.1 4.1 信号及其表示信号及其表示连续时间信号的
2、表示 连续时间信号:连续时间信号:时间变化连续。如y=x(t)离散时间信号离散时间信号(序列序列):时间离散,如x(nT)=x(t)|t=nT.工具箱中的信号产生函数函数名函数名功能功能函数名函数名功能功能sawtooth产生锯齿波或三角波信号产生锯齿波或三角波信号pulstran产生冲激串产生冲激串square产生方波信号产生方波信号rectpule产生非周期的方波信号产生非周期的方波信号 sinc产生产生sinc函数波形函数波形tripuls产生非周期的三角波信号产生非周期的三角波信号chirp产生调频余弦信号产生调频余弦信号diric产生产生Dirichlet或周期或周期sinc函数函数
3、gauspuls产生高斯正弦脉冲信号产生高斯正弦脉冲信号gmonopuls产生高斯单脉冲信号产生高斯单脉冲信号vco电压控制振荡器电压控制振荡器第 4 章 MATLAB在信号处理中的应用 离散时间信号的表示 在MATLAB中,离散时间信号x(n)的表示:需用一个向量x表示序列幅值,用另一个等长的定位时间变量n,才能完整地表示一个序列。例例4-10 绘制离散时间信号的棒状图。其中x(-1)=-1,x(0)=1,x(1)=2,x(2)=1,x(3)=0,x(4)=-1。MATLAB源程序为:n=-3:5;%定位时间变量定位时间变量x=0,0,-1,1,2,1,-1,0,0;stem(n,x);gr
4、id;%绘制棒状图绘制棒状图line(-3,5,0,0);%画画x轴线轴线xlabel(n);ylabel(xn)运行结果如图4.11所示。图 4.11 离散时间信号图形第 4 章 MATLAB在信号处理中的应用 几种常用离散时间信号的表示几种常用离散时间信号的表示1单位脉冲序列单位脉冲序列直接实现:直接实现:x=zeros(1,N);x(1,n0)=1;2单位阶跃序列单位阶跃序列 直接实现:直接实现:n=ns:nf;x=(n-n0)=0;第 4 章 MATLAB在信号处理中的应用 3实指数序列实指数序列直接实现:直接实现:n=ns:nf;x=a.n;4复指数序列复指数序列直接实现:直接实现:
5、n=ns:nf;x=exp(sigema+jw)*n);5正正(余余)弦序列弦序列直接实现:直接实现:n=ns:nf;x=cos(w*n+sita);第 4 章 MATLAB在信号处理中的应用 4.2 信号的基本运算信号的相加与相乘信号的相加与相乘 y(n)=x1(n)+x2(n)y(n)=x1(n)x2(n)MATLAB实现实现:y=x1+x2;y=x1.*x2序列移位与周期延拓运算序列移位与周期延拓运算序列移位:y(n)=x(n-m)。MATLAB实现:实现:y=x;ny=nx-m序列周期延拓:y(n)=x(n)M,MATLAB实现:实现:ny=nxs:nxf;y=x(mod(ny,M)+
6、1)4.2.3 4.2.3 序列翻褶与序列累加运算序列翻褶与序列累加运算序列翻褶:y(n)=x(-n)。MATLAB可实现:y=fliplr(x)序列累加的数学描述为:MATLAB实现:实现:y=cumsum(x)第 4 章 MATLAB在信号处理中的应用 4.2.4 两序列的卷积运算两序列卷积运算:MATLAB实现:实现:y=conv(x1,x2)。序列。序列x1(n)和和x2(n)必须长度有限。必须长度有限。4.2.5 两序列的相关运算两序列相关运算:。MATLAB实现:实现:y=xcorr(x1,x2)。第 4 章 MATLAB在信号处理中的应用 4.3 信号的能量和功率1.信号能量数字
7、定义:MATLAB实现实现:E=sum(x.*conj(x);或或 E=sum(abs(x).2);数字定义:2.2.信号功率信号功率MATLAB实现:P=sum(x.*conj(x)/N;或 E=sum(abs(x).2)/N;第 4 章 MATLAB在信号处理中的应用 4.4 线性时不变系统4.4.1 4.4.1 系统的描述系统的描述1常系数线性微分常系数线性微分/差分方程差分方程2系统传递函数系统传递函数3零极点增益模型零极点增益模型连续系统:连续系统:离散系统:离散系统:第 4 章 MATLAB在信号处理中的应用 4极点留数模型极点留数模型离散系统:连续系统:5二次分式模型二次分式模型
8、连续系统:离散系统:6状态空间模型状态空间模型连续系统:离散系统:第 4 章 MATLAB在信号处理中的应用 4.4.2 系统模型的转换函数 在MATLAB中,用sos、ss、tf、zp分别表示二二次次分分式式模模型型、状状态态空空间间模模型型、传传递递函函数数模模型型和零零极极点点增增益益模模型型。其中sos表示二次分式,g为比例系数,sos为L6的矩阵,即 (415)1ss2tf函数函数格式:格式:num,den=ss2tf(A,B,C,D,iu)功能:将指定输入量iu的线性系统(A,B,C,D)转换为传递函数模型num,den。2zp2tf函数函数格式:格式:num,den=zp2tf(
9、z,p,k)功能:将给定系统的零极点增益模型转换为传递函数模型,z、p、k分别为零点列向量、极点列向量和增益系数。第 4 章 MATLAB在信号处理中的应用 线性系统模型的变换函数函数名功能说明函数名功能说明ss2tf 状态空间模型转换为传状态空间模型转换为传递函数模型递函数模型zp2tf零极点增益模型转换为传递函零极点增益模型转换为传递函数模型数模型ss2zp状态空间模型转换为零状态空间模型转换为零极点增益模型极点增益模型zp2ss零极点增益模型转换为状态空零极点增益模型转换为状态空间模型间模型ss2sos状态空间模型转换为二状态空间模型转换为二次分式模型次分式模型zp2sos零极点增益模型
10、转换为二次分零极点增益模型转换为二次分式模型式模型tf2ss传递函数模型转换为状传递函数模型转换为状态空间模型态空间模型sos2tf二次分式模型转换为传递函数模二次分式模型转换为传递函数模型型tf2zp传递函数模型转换为零传递函数模型转换为零极点增益模型极点增益模型sos2zp二次分式模型转换为零极点增二次分式模型转换为零极点增益模型益模型tf2sos传递函数模型转换为二传递函数模型转换为二次分式模型次分式模型sos2ss二次分式模型转换为状态空间模二次分式模型转换为状态空间模型型第 4 章 MATLAB在信号处理中的应用 例例4-18 4-18 求离散时间系统的零、极点向量和增益系数。在命令
11、窗口输入:在命令窗口输入:num=2,3;den=1,0.4,1;num,den=eqtflength(num,den);%使长度相等 z,p,k=tf2zp(num,den)屏幕显示为屏幕显示为z=0 -1.5000p=-0.2000+0.9798i -0.2000-0.9798ik=2第 4 章 MATLAB在信号处理中的应用 4.4.3 系统互联与系统结构MATLAB实现函数series()格式:格式:A,B,C,D=series(A1,B1,C1,D1,A2,B2,C2,D2)或或 num,den=series(num1,den1,num2,den2)将系统1、系统2级联,可得到级联连
12、接的传递函数形式为:1.1.系统的级联系统的级联第 4 章 MATLAB在信号处理中的应用 MATLAB实现函数parallel()格式:格式:A,B,C,D=parallel(A1,B1,C1,D1,A2,B2,C2,D2)或或 num,den=parallel(num1,den1,num2,den2)2.系统的并联将系统1、系统2并联,可得到并联连接的传递函数形式为:3.两个系统的反馈连接函数feedback格式:格式:A,B,C,D=feedback(A1,B1,C1,D1,A2,B2,C2,D2,sign)或或 num,den=feedback(num1,den1,num2,den2,
13、sign)将系统1和系统2进行反馈连接,sign表示反馈方式(默认值为-1);当sig=+1时表示正反馈;当sig=-1时表示负反馈。第 4 章 MATLAB在信号处理中的应用 例例4-19 求两个单输入单输出子系统的级联、并联和反馈后系统的传递函数。MATLAB源程序为:num1=1;den1=1,1;%系统1num2=2;den2=1,2;%系统2nums,dens=series(num1,den1,num2,den2)%实现两个系统级联nump,denp=parallel(num1,den1,num2,den2)%实现两个系统并联 numf,denf=feedback(num1,den1
14、,num2,den2)%实现两个系统反馈程序运行结果为程序运行结果为:nums=0 0 2;dens=1 3 2nump=0 3 4;denp=1 3 2numf=0 1 2;denf=1 3 4因此,各系统的传递函数分别为:第 4 章 MATLAB在信号处理中的应用 4.5 线性时不变系统的响应线性时不变系统的时域响应线性时不变系统的时域响应1连续连续LTI系统的响应系统的响应2离散离散LTI系统的响应系统的响应用MATLAB中的卷积函数conv()来实现。用MATLAB中的卷积函数conv()来实现。第 4 章 MATLAB在信号处理中的应用 格式:格式:y,x=lsim(a,b,c,d,
15、u,t)功能:返回连续LTI系统(2)对任意输入的离散对任意输入的离散LTI系统响应函数系统响应函数dlsim()格式:格式:y,x=dlsim(a,b,c,d,u)功能:返回离散LTI系统 对任意输入时系统的输出响应y和状态记录x,其中u给出每个输入的时序列,一般情况下u为一个矩阵;t用于指定仿真的时间轴,它应为等间隔。对输入序列u的响应y和状态记录x。3时域响应函数时域响应函数(1)对任意输入的连续对任意输入的连续LTI系统响应函数系统响应函数lsim()第 4 章 MATLAB在信号处理中的应用 4.5.2 LTI系统的单位冲激响应1.求连续求连续LTI系统的单位冲激响应函数系统的单位冲
16、激响应函数impulse()格式:格式:Y,T=impulse(sys)或或impulse(sys)功能:返回系统的响应Y和时间向量T,自动选择仿真的时间范围。其中sys可为系统传递函数、零极增益模型或状态空间模型。2.求离散系统的单位冲激响应函数求离散系统的单位冲激响应函数dimpulse()格式:格式:y,x=dimpulse(num,den)功能:返回项式传递函数的单位冲激响应y向量和时间状态历史记录x向量。第 4 章 MATLAB在信号处理中的应用 4.5.3 时域响应的其它函数1.求连续求连续LTI系统的零输入响应函数系统的零输入响应函数initial()格式:格式:y,t,x=in
17、itial(a,b,c,d,x0)功能:计算出连续时间LTI系统由于初始状态x0所引起的零输入响应y。其中x为状态记录,t为仿真所用的采样时间向量。2.求离散系统的零输入响应函数求离散系统的零输入响应函数dinitial()格式:格式:y,x,n=dinitial(a,b,c,d,x0)功能:计算离散时间LTI系统由初始状态x0所引起的零输入响应y和状态响应响应x,取样点数由函数自动选取。n为仿真所用的点数。3.求连续系统的单位阶跃响应函数求连续系统的单位阶跃响应函数step()格式:格式:Y,T=step(sys)功能:返回系统的单位阶跃响应Y和仿真所用的时间向量T,自动选择仿真的时间范围。
18、其中sys可为系统传递函数(TF)、零极增益模型(ZPK)或状态空间模型(SS)。4.求离散系统的单位阶跃响应函数求离散系统的单位阶跃响应函数dstep()格式:格式:y,x=dstep(num,den)功能:返回多项式传递函数G(z)=num(z)/den(z)表示的系统单位阶跃响应。第 4 章 MATLAB在信号处理中的应用 4.6线性时不变系统的频率响应1求模拟滤波器求模拟滤波器Ha(s)的频率响应函数的频率响应函数freqs()格式:格式:Hfreqs(B,A,W)功能:计算由向量W(rad/s)指定的频率点上模拟滤器系统函数Ha(s)的频率响应Ha(j),结果存于H向量中。例例4-3
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 教学课件 教学 课件 MATLAB 信号 处理 中的 应用
限制150内