




已阅读5页,还剩37页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
MATLAB在信号处理中的应用,4.1信号及其表示,4.1.1连续时间信号的表示连续时间信号:时间变化连续。如y=x(t)离散时间信号(序列):时间离散,如x(nT)=x(t)|t=nT.,4.1.2工具箱中的信号产生函数,例:产生f=50Hz的锯齿波、三角波Fs=10000;%采样频率t=0:1/Fs:0.1;%采样间隔1/Fsf=50;%50Hzx1=sawtooth(2*pi*50*t,0);x2=sawtooth(2*pi*50*t,1);x3=sawtooth(2*pi*50*t,0.5);subplot(311);plot(t,x1);subplot(312);plot(t,x2);subplot(313);plot(t,x3),1、sawtooth函数产生锯齿波或三角波,用法:x=sawtooth(t)将产生周期为2的锯齿波。以02这个周期内为例,当t=0时,x=-1,当t=2时,x=1。x=sawtooth(t,width)width是0到1之间的标量。在0到2width区间内,x的值从-1线性变化到1;在2width2区间内,x的值又从1线性变化到-1。sawtooth(t,1)和sawtooth(t)是等价的。,-,4,2、square函数产生矩形波例:产生50Hz占空比分别为20和50的矩形波。Fs=10000;%采样频率t=0:1/Fs:0.1;%采样间隔1/Fsf=50;%50Hzx1=square(2*pi*50*t,20);x2=square(2*pi*50*t,50);subplot(211);plot(t,x1);subplot(212);plot(t,x2);,-,5,3、sinc函数产生sinc波形或sin(t)/(t)波形例:t=linspace(-10,+10,200);x=sinc(t);plot(t,x);,4.1.3离散时间信号的表示,在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);grid;%绘制棒状图line(-3,5,0,0);%画x轴线xlabel(n);ylabel(xn)运行结果如图4.11所示。,图4.11离散时间信号图形,line(起点横坐标,终点横坐标,起点纵坐标,终点纵坐标),4.1.4几种常用离散时间信号的表示,1单位脉冲序列,直接实现:x=zeros(1,N);x(1,n0)=1;,2单位阶跃序列,直接实现:n=ns:nf;x=(n-n0)=0;,x=zeros(1,5);x(1,3)=1;n=-2:2;stem(n,x),n=1:4;x=(n-2)=0;stem(n,x),3实指数序列,直接实现:n=ns:nf;x=a.n;,4复指数序列,直接实现:n=ns:nf;x=exp(sigema+jw)*n);,5正(余)弦序列,直接实现:n=ns:nf;x=cos(w*n+sita);,4.2信号的基本运算,4.2.1信号的相加与相乘y(n)=x1(n)+x2(n)y(n)=x1(n)x2(n)MATLAB实现:y=x1+x2;y=x1.*x2,4.2.2序列移位与周期延拓运算,序列移位: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)+1),4.2.3序列翻褶与序列累加运算,序列翻褶:y(n)=x(-n)。MATLAB可实现:y=fliplr(x),序列累加的数学描述为:,MATLAB实现:y=cumsum(x),4.2.4两序列的卷积运算,两序列卷积运算:,MATLAB实现:y=conv(x1,x2)。序列x1(n)和x2(n)必须长度有限。,4.2.5两序列的相关运算,两序列相关运算:,。MATLAB实现:y=xcorr(x1,x2)。,已知离散信号x(n)和h(n),求y(n)=x(n)*h(n),并用图形表示。,Nh=20;Nx=10;m=5;%设定Nx,Nh和位移值mn=0:Nh-1;h1=(0.9).n;%产生h1(n)h2=h1;nx=0:Nx-1;x1=ones(1,Nx);%产生x1(n)x2=zeros(1,Nx+m);fork=m+1:m+Nx%产生x2(n)=x1(n-m)x2(k)=x1(k-m);end%产生x2(n),-,12,y1=conv(x1,h1);%计算y1(n)=x1(n)*h1(n)y2=conv(x2,h2);%计算y2(n)=x2(n)*h2(n)subplot(3,2,1)stem(nx,x1,.)axis(03001.2),title(x1(n)%绘图(以下省略),4.4线性时不变系统,4.4.1系统的描述,系统传递函数,在Matlab中,传递函数用分子、分母两个多项式的系数表示,系数为降幂排列。,线性时不变(LTI)系统的常用表示方法,1、传递函数表示法在Matlab中,传递函数用分子、分母两个多项式的系数表示,系数为降幂排列。分子(Numerator):B=b(1)b(2)b(m+1)分母(Denominator):A=a(1)a(2)b(n+1)例:num=10.21;den=10.51;,2、零极点模型表示法在Matlab中,增益系数、零点向量、极点向量用三个列向量表示。增益系数(Gain):k零点向量(Zero):z=z1z2zn极点向量(Pole):p=p1p2pnsys=zpk(z,p,k)%获得零-极点模型表达式,k=3;z=234;p=567;sys=zpk(z,p,k,0.1)Zero/pole/gain:3(z-2)(z-3)(z-4)-(z-5)(z-6)(z-7)Samplingtime:0.1,线性系统模型的变换函数,4.4.2系统模型的转换函数,例4-18求离散时间系统,的零、极点向量和增益系数。在命令窗口输入: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.5线性时不变系统的响应,4.5.1线性时不变系统的时域响应,1连续LTI系统的响应,2离散LTI系统的响应,用MATLAB中的卷积函数conv()来实现。,用MATLAB中的卷积函数conv()来实现。,4.5.2LTI系统的单位冲激响应,1.求连续LTI系统的单位冲激响应函数impulse()格式:Y,T=impulse(sys)或impulse(sys)功能:返回系统的响应Y和时间向量T,自动选择仿真的时间范围。其中sys可为系统传递函数、零极增益模型或状态空间模型。,2.求离散系统的单位冲激响应函数dimpulse()格式:y,x=dimpulse(num,den)功能:返回项式传递函数,的单位冲激响应y向量和时间状态历史记录x向量。,1、impulse函数求连续系统的单位冲击响应。,b=23;a=10.41;sys=tf(b,a)Transferfunction:2s+3-s2+0.4s+1yt=impulse(sys);plot(t,y),*2、impz函数求离散系统(数字滤波器)的单位冲击响应。(注:Matlab7.0不再支持dimpulse函数),4.5.3时域响应的其它函数1.求连续LTI系统的零输入响应函数initial()格式:y,t,x=initial(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,自动选择仿真的时间范围。其中sys可为系统传递函数(TF)、零极增益模型(ZPK)或状态空间模型(SS)。4.求离散系统的单位阶跃响应函数dstep()格式:y,x=dstep(num,den)功能:返回多项式传递函数G(z)=num(z)/den(z)表示的系统单位阶跃响应。,4.6线性时不变系统的频率响应,1求模拟滤波器Ha(s)的频率响应函数freqs()格式:Hfreqs(B,A,W)功能:计算由向量W(rad/s)指定的频率点上模拟滤器系统函数Ha(s)的频率响应Ha(j),结果存于H向量中。,例4-31已知某模拟滤波器的系统函数,求该模拟滤波器的频率响应。MATLAB源程序如下。B=1;A=12.61313.41422.61311;W=0:0.1:2*pi*5;freqs(B,A,W),图4.30模拟滤波器的频率响应,例4-32已知某滤波器的系统函数为,求该滤波器的频率响应。MATLAB源程序为:B=100000001;A=1;freqz(B,A),该程序运行所绘出的幅频与相频性曲线如图4.31所示。,图4.31滤波器幅度和相位曲线,2求数字滤波器H(z)的频率响应函数freqz()格式:H=freqz(B,A,W)功能:计算由向量W(rad)指定的数字频率点上(通常指0,范围)在H(z)的频率响应H(ejw)。,3滤波函数filter格式:y=filter(B,A,x)功能:对向量x中的数据进行滤波处理,即差分方程求解,产生输出序列向量y。B和A分别为数字滤波器系统函数H(z)的分子和分母多项式系数向量。,例4-33设系统差分方程为,MATLAB源程序为:B=1;A=1,-0.8;N=0:31;x=0.8.n;y=filter(B,A,x);subplot(2,1,1);stem(x)subplot(2,1,2);stem(y)该程序运行所得结果如图4.32所示。,,求该系统对信号,的响应。,图4.32系统对信号的响应,4.7傅里叶(Fourier)变换,4.7.1连续时间、连续频率傅里叶变换,4.7.2连续时间、离散频率傅里叶级数,正变换:,逆变换:,正变换:,逆变换:,4.7.3时间离散、连续频率序列傅里叶变换,4.7.4离散时间、离散频率离散傅里叶级数,4.7.5离散时间、离散频率离散傅里叶变换(DFT),正变换:,逆变换:,正变换:,逆变换:,正变换:,逆变换:,1一维快速正傅里叶变换函数fft格式:X=fft(x,N)功能:采用FFT算法计算序列向量x的N点DFT变换,当N缺省时,fft函数自动按x的长度计算DFT。当N为2整数次幂时,fft按基-2算法计算,否则用混合算法。2一维快速逆傅里叶变换函数ifft格式:x=ifft(X,N)功能:采用FFT算法计算序列向量X的N点IDFT变换。,例4-36用快速傅里叶变换FFT计算下面两个序列的卷积。,并测试直接卷积和快速卷积的时间。,图4.35快速卷积框图,MATLAB程序(部分):%线性卷积xn=sin(0.4*1:15);%对序列x(n)赋值,M=15hn=0.9.(1:20);%对序列h(n)赋值,N=20yn=conv(xn,hn);%直接调用函数conv计算卷积%园周卷积L=pow2(nextpow2(M+N-1);Xk=fft(xn,L);Hk=fft(hn,L);Yk=Xk.*Hk;yn=ifft(Yk,L);,图4.36x(n),h(n)及其线性卷积波形,4.8IIR数字滤波器的设计方法,1.数字滤波器的频率响应函数,幅度响应:,相位响应:,图4.37理想低通、高通、带通、带阻数字滤波器幅度特性,2.滤波器的技术指标幅度响应指标、相位响应指标,图4.38数字低通滤波器的幅度特性,通带要求:,阻带要求:,通带最大衰减:,阻带最小衰减:,4.8.1冲激响应不变法,2.MATLAB信号处理工箱中的专用函数impinvar():格式:BZ,AZ=impinvar(B,A,Fs)功能:把具有B,A模拟滤波器传递函数模型转换成采样频率为Fs(Hz)的数字滤波器的传递函数模型BZ,AZ。采样频率Fs的默认值为Fs=1。,1.冲激响应不变法设计IIR数字滤波器的基本原理:,例4-37MATLAB源程序如下:num=1;%模拟滤波器系统函数的分子den=1,sqrt(5),2,sqrt(2),1;%模拟滤波器系统函数的分母num1,den1=impinvar(num,den)%求数字低通滤波器的系统函数程序的执行结果如下:num1=-0.00000.09420.21580.0311den1=1.0000-2.00321.9982-0.76120.1069,MATLAB信号处理工具箱中的专用双线性变换函数bilinear()格式:numd,dendbilinear(num,den,Fs)功能:把模拟滤波器的传递函数模型转换成数字滤波器的传递函数模型。,4.8.2双线性变换法,双线性变换利用频率变换关系:,例4-38MATLAB源程序如下:num=1;%模拟滤波器系统函数的分子den=1,sqrt(3),sqrt(2),1;%模拟滤波器系统函数的分母num1,den1=bilinear(num,den,1)%求数字滤波器的传递函数运算的结果如下:num1=0.05330.15990.15990.0533den1=1.0000-1.33820.9193-0.1546,4.8.3IIR数字滤波器的频率变换设计法,1.IIR数字滤波器的频率变换设计法的基本原理根据滤波器设计要求,设计模拟原型低通滤波器,然后进行频率变换,将其转换为相应的模拟滤波器(高通、带通等),最后利用冲激响应不变法或双线性变换法,将模拟滤波器数字化成相应的数字滤波器。,图4.39IIR数字滤波器MATLAB设计步骤流程图,1MATLAB的典型设计,利用在MATLAB设计IIR数字滤波器可分以下几步来实现(1)按一定规则将数字滤波器的技术指标转换为模拟低通滤波器的技术指标;(2)根据转换后的技术指标使用滤波器阶数函数,确定滤波器的最小阶数N和截止频率Wc;(3)利用最小阶数N产生模拟低通滤波原型;(4)利用截止频率Wc把模拟低通滤波器原型转换成模拟低通、高通、带通或带阻滤波器;(5)利用冲激响应不变法或双线性不变法把模拟滤波器转换成数字滤波器。,例4-39设计一个数字信号处理系统,它的采样率为Fs100Hz,希望在该系统中设计一个Butterworth型高通数字滤波器,使其通带中允许的最小衰减为0.5dB,阻带内的最小衰减为40dB,通带上限临界频率为30Hz,阻带下限临界频率为40Hz。,MATLAB源程序设计如下:%把数字滤波器的频率特征转换成模拟滤波器的频率特征wp=30*2*pi;ws=40*2*pi;rp=0.5;rs=40;Fs=100;N,Wc=buttord(wp,ws,rp,rs,s);%选择滤波器的最小阶数Z,P,K=buttap(N);%创建Butterworth低通滤波器原型A,B,C,D=zp2ss(Z,P,K);%零极点增益模型转换为状态空间模型AT,BT,CT,DT=lp2hp(A,B,C,D,Wc);%实现低通向高通的转变num1,den1=ss2tf(AT,BT,CT,DT);%状态空间模型转换为传递函数模型%运用双线性变换法把模拟滤波器转换成数字滤波器num2,den2=bilinear(num1,den1,100);H,W=freqz(num2,den2);%求频率响应plot(W*Fs/(2*pi),abs(H);grid;%绘出频率响应曲线xlabel(频率/Hz);ylabel(幅值)程序运行结果如图4.40所示。,2MATLAB的直接设计,图4.39IIR数字滤波器MATLAB设计步骤流程图,例4-41试设计一个带阻IIR数字滤波器,其具体的要求是:通带的截止频率:wp1650Hz、wp2850Hz;阻带的截止频率:ws1700Hz、ws2800Hz;通带内的最大衰减为rp0.1dB;阻带内的最小衰减为rs50dB;采样频率为Fs2000Hz。MATLAB源程序设计如下:wp1=650;wp2=850;ws1=700;ws2=800;rp=0.1;rs=50;Fs=2000;wp=wp1,wp2/(Fs/2);ws=ws1,ws2/(Fs/2);%利用Nyquist频率频率归一化N,wc=ellipord(wp,ws,rp,rs,z);%求滤波器阶数num,den=ellip(N,rp,rs,wc,stop);%求滤波器传递函数H,W=freqz(num,den);%绘出频率响应曲线plot(W*Fs/(2*pi),abs(H);grid;xlabel(频率/Hz);ylabel(幅值)该程序运行后的幅频响应曲线如图4.42所示。,4.9FIR数字滤波器设计,格式:w=boxcar(M)功能:返回M点矩形窗序列。MATLAB信号处理工具箱中的窗函数法设计FIR数字滤波器的专用命令fir1()。格式:Bfir1(N,wc)功能:设计一个具有线性相位的N阶(N点)的低通FIR数字滤波器,返回的向量B为滤波器的系数(单位冲激响应序列),其长度为N+1。,4.9.1窗函数设计法窗函数设计的基本原理:h(n)=w(n)hd(n)w(n)为窗函数,hd(n)理想数字滤波器的单位冲激响应。在MATLAB信号处理工具箱中为用户提供了Boxcar(矩形)、Bartlet(巴特利特)、Hanning(汉宁)等窗函数,这些窗函数的调用格式相同。,FIR数字滤波器的单位冲激响应h(n)满足偶(奇)对称h(n)=h(N-n-1)或h(n)=-h(N-n-1)FIR数字滤波器具有线性相位:,或,例4-43用矩形窗设计线性相位FIR低通滤波器。该滤波器的通带截止频率wc=pi/4,单位脉冲响h(n)的长度M=21。并绘出h(n)及其幅度响应特性曲线。MATLAB源程序为:M=21;wc=pi/4;%理想低通滤波器参数n=0:M-1;r=(M-1)/2;nr=n-r+eps*(n-r)=0);hdn=sin(wc*nr)/pi./nr;%计算理想低通单位脉冲响应hd(n)ifrem(M,2)=0,hdn(r+1)=wc/pi;end%M为奇数时,处理n=r点的0/0型wn1=boxcar(M);%矩形窗hn1=hdn.*wn1;%加窗subplot(2,1,1);stem(n,hn1,.);line(0,20,0,0);xlabel(n),ylabel(h(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 乙烯-醋酸乙烯共聚乳液(VAE)装置操作工成本预算考核试卷及答案
- 贵金属精炼工操作考核试卷及答案
- 丁二酸装置操作工前沿技术考核试卷及答案
- 特殊气候下预制箱梁桥梁施工措施
- 2025年滚装船航线项目规划申请报告
- 二年级下册道德与法制校本课程计划
- 智慧消防系统下的室外消防管网施工措施
- 2024-2025年数字图书室资源更新计划
- 2025年春季学期小学图书室校园阅读推广计划
- 人教部编版五年级数学下册教学活动优化计划
- 人教版小学数学四年级上册全册教案
- 2025年中国智慧养殖行业市场占有率及投资前景预测分析报告
- 电影院安全生产与安全管理规定制度
- 废气处理合同协议
- 镁铝合金行业前景
- 煤炭工业矿井工程建设项目设计文件编制标准
- 2025-2030中国余热回收行业市场现状供需分析及投资评估规划分析研究报告
- 无人机物流配送服务手册
- 深度学习:从入门到精通(微课版)全套教学课件
- 见证取样送检计划方案
- 二年级上册语文课内阅读理解每日一练(含答案)
评论
0/150
提交评论