北理工自动控制理论实验报告.docx
本科实验报告实验名称: 控制理论基础(实验) 课程名称:控制理论基础实验时间:2016.4.25-5.19任课教师:王卫江实验地点:10-906 实验教师:闫宇松实验类型: 原理验证 综合设计 自主创新学生姓名:王雅珊学号/班级:1120131319/05111361组 号:学 院:信息与电子学院同组搭档:专 业:信息工程菁英班成 绩:实验一:控制系统的模型建立一、 实验目的1. 掌握利用MATLAB 建立控制系统模型的方法。2. 掌握系统的各种模型表述及相互之间的转换关系。 3. 学习和掌握系统模型连接的等效变换。二、实验原理1、系统模型的 MATLAB描述 系统的模型描述了系统的输入、输出变量以及内部各变量之间的关系,表征一个系统的模型有很多种,如微分方程、传递函数模型、状态空间模型等。这里主要介绍系统传递函数(TF)模型、零极点增益(ZPK)模型和状态空间(SS)模型的MATLAB 描述方法。 1) 传递函数(TF)模型 传递函数是描述线性定常系统输入-输出关系的一种最常用的数学模型,其表达式一般为 在MATLAB 中,直接使用分子分母多项式的行向量表示系统,即 num = bm, bm-1, b1, b0 den = an, an-1, a1, a0 调用tf 函数可以建立传递函数TF对象模型,调用格式如下: Gtf = tf(num,den) Tfdata 函数可以从TF对象模型中提取分子分母多项式,调用格式如下: num,den = tfdata(Gtf) 返回cell 类型的分子分母多项式系数 num,den = tfdata(Gtf,'v') 返回向量形式的分子分母多项式系数2) 零极点增益(ZPK)模型 传递函数因式分解后可以写成 式中, z1 , z2 , ,zm 称为传递函数的零点, p1,p2,pn称为传递函数的极点,k 为传递系数(系统增益)。 在MATLAB 中,直接用z,p,k矢量组表示系统,其中z,p,k 分别表示系统的零极点及其增益,即: z=z1,z2,zm; p=p1,p2,pn; k=k; 调用zpk 函数可以创建ZPK 对象模型,调用格式如下: Gzpk = zpk(z,p,k) 同样,MATLAB 提供了zpkdata 命令用来提取系统的零极点及其增益,调用格式如下: z,p,k = zpkdata(Gzpk) 返回cell 类型的零极点及增益 z,p,k = zpkdata (Gzpk,v) 返回向量形式的零极点及增益 函数pzmap 可用于求取系统的零极点或绘制系统得零极点图,调用格式如下: pzmap(G) 在复平面内绘出系统模型的零极点图。 p,z = pzmap(G) 返回的系统零极点,不作图。 3) 状态空间(SS)模型 由状态变量描述的系统模型称为状态空间模型,由状态方程和输出方程组成: 其中:x 为n 维状态向量;u 为r 维输入向量; y 为m 维输出向量; A 为n×n 方阵,称为系统矩阵; B 为n×r 矩阵,称为输入矩阵或控制矩阵;C 为m×n 矩阵,称为输出矩阵; D为m×r 矩阵,称为直接传输矩阵。 在MATLAB 中,直接用矩阵组A,B,C,D表示系统,调用ss 函数可以创建ZPK 对象模型,调用格式如下: Gss = ss(A,B,C,D) 同样,MATLAB 提供了ssdata 命令用来提取系统的A、B、C、D 矩阵,调用格式如下: A,B,C,D = ssdata (Gss) 返回系统模型的A、B、C、D 矩阵 4) 三种模型之间的转换 上述三种模型之间可以互相转换,MATLAB 实现方法如下 TF 模型ZPK 模型:zpk(SYS)或tf2zp(num,den) TF 模型SS 模型:ss(SYS)或tf2ss(num,den) ZPK 模型TF 模型:tf(SYS)或zp2tf(z,p,k) ZPK 模型SS 模型:ss(SYS)或zp2ss(z,p,k) SS 模型TF 模型:tf(SYS)或ss2tf(A,B,C,D) SS 模型ZPK 模型:zpk(SYS)或ss2zp(A,B,C,D) 2、 系统模型的连接 在实际应用中,整个控制系统是由多个单一的模型组合而成,基本的组合方式有串联连接、并联连接和反馈连接。下图分别为串联连接、并联连接和反馈连接的结构框图和等效总传递函数。 在MATLAB 中可以直接使用“*”运算符实现串联连接,使用“”运算符实现并联连接。反馈系统传递函数求解可以通过命令feedback 实现,调用格式如下: T = feedback(G,H) T = feedback(G,H,sign) 其中,G 为前向传递函数,H 为反馈传递函数;当sign = +1 时,GH 为正反馈系统传递函数;当sign = -1 时,GH 为负反馈系统传递函数;默认值是负反馈系统。 三、 实验内容1、 已知控制系统的传递函数如下 试用MATLAB 建立系统的传递函数模型、零极点增益模型及系统的状态空间方程模型,并绘制系统零极点图。 实验代码:num=2 18 40; den=1 5 8 6; %描述系统的传递函数模型的分子分母多项式系数向量Gtf=tf(num,den) ;%调用tf函数建立系统模型Gzpk=zpk(Gtf) ; %调用zpk函数,实现从函数模型到零极点增益模型的转换Gss=ss(Gtf) ; %调用ss函数建立系统模型pzmap(Gzpk); grid on; 实验结果: (1) 首先建立系统的传递函数模型描述,上述程序的运行结果为: Gtf = 2 s2 + 18 s + 40 s3 + 5 s2 + 8 s + 6(2) 零极点增益模型为:Gzpk = 2 (s+5) (s+4) (s+3) (s2 + 2s + 2)(3) 系统的状态空间方程模型Gss = a = x1 x2 x3 x1 -5 -2 -1.5 x2 4 0 0 x3 0 1 0 b = u1 x1 4 x2 0 x3 0 c = x1 x2 x3 y1 0.5 1.125 2.5 d = u1 y1 0(4)系统零极点图2、 已知控制系统的状态空间方程如下 试用MATLAB 建立系统的传递函数模型、零极点增益模型及系统的状态空间方程模型,并绘制系统零极点图。 实验代码: a=0 1 0 0;0 0 1 0;0 0 0 1;-1 -2 -3 -4; b=0;0;0;1; c=10 2 0 0; d=0; %写出系统的A、B、C、D矩阵Gss=ss(a,b,c,d); %调用ss函数建立系统模型Gtf=tf(Gss) ; %调用tf函数建立系统模型Gzpk=(Gss); %调用zpk函数,实现从函数模型到零极点增益模型的转换pzmap(Gzpk); grid on;实验结果: (1) 系统矩阵 >> aa = 0 1 0 0 0 0 1 0 0 0 0 1 -1 -2 -3 -4>> bb = 0 0 0 1>> cc = 10 2 0 0>> dd = 0(2) 再创建ZPK对象模型:Gzpk = a = x1 x2 x3 x4 x1 0 1 0 0 x2 0 0 1 0 x3 0 0 0 1 x4 -1 -2 -3 -4 b = u1 x1 0 x2 0 x3 0 x4 1 c = x1 x2 x3 x4 y1 10 2 0 0 d = u1 y1 0(3) 传递函数:Gtf = 2 s + 10 s4 + 4 s3 + 3 s2 + 2 s + 1(4) 零极点图:3、 已知三个系统的传递函数分别为 试用MATLAB 求上述三个系统串联后的总传递函数。 实验代码:num1=2 6 5;den1=1 4 5 2; %描述系统的传递函数模型的分子分母多项式系数向量G1=tf(num1,den1) ; %调用tf函数建立系统模型num2=1 4 1; den2=1 9 8 0; %同上G2=tf(num2,den2) ; %同上z=-3 -7; p=-1 -4 -6; k=5; %用z,p,k矢量组表示系统G3=zpk(z,p,k) ; %调用zpk函数,实现从函数模型到零极点增益模型的转换G=G1*G2*G3实验结果: G1 = 2 s2 + 6 s + 5 s3 + 4 s2 + 5 s + 2Continuous-time transfer function.>> G2G2 = s2 + 4 s + 1 s3 + 9 s2 + 8 sContinuous-time transfer function.>> G3G3 = 5 (s+3) (s+7) (s+1) (s+4) (s+6)Continuous-time zero/pole/gain model.>> GG = 10 (s+3.732) (s+3) (s+7) (s+0.2679) (s2 + 3s + 2.5) s (s+8) (s+6) (s+4) (s+2) (s+1)44、 已知如下图所示的系统框图 试用MATLAB 求该系统的闭环传递函数。 实验代码:num1=1; den1=1 1; %描述系统的传递函数模型的分子分母多项式系数向量G1=tf(num1,den1) ; %调用tf函数建立系统模型num2=1; den2=0.5 1; %同上G2=tf(num2,den2); %同上num3=3; den3=1 0; G3=tf(num3,den3);H=G2; G=(G1+G2)*G3; Gtf=feedback(G,H,-1) 实验结果Gtf = 2.25 s2 + 7.5 s + 6 0.25 s4 + 1.25 s3 + 2 s2 + 5.5 s + 65、 已知如下图所示的系统框图实验代码:num1=10; den1=1 1; %描述系统的传递函数模型的分子分母多项式系数向量G1=tf(num1,den1) ; %调用tf函数建立系统模型num2=2; den2=1 1 0; G2=tf(num2,den2); num3=1 3; den3=1 2; H2=tf(num3,den3); num4=5 0; den4=1 6 8; H1=tf(num4,den4); G=G1*feedback(G2,H2,+1); Gtf=feedback(G,H1,-1) 实验结果:Gtf = 20 s3 + 160 s2 + 400 s + 320 s6 + 10 s5 + 35 s4 + 44 s3 + 82 s2 + 116 s - 48四、 实验体会本次实验比较基础,学习如何用matlab创建传递函数模型,并得到对应的零极点模型和状态空间方程。在理论课上学习的内容,通过软件matlab让我更直观的感受传函的几种描述方式,还有各个模式之间的转换关系。 实验2 控制系统的暂态特性分析一、实验目的1. 学习和掌握利用 MATLAB 进行系统时域响应求解和仿真的方法。2. 考察二阶系统的时间响应,研究二阶系统参数对系统暂态特性的影响。二、实验原理 系统的暂态性能指标控制系统的暂态性能指标常以一组时域量值的形式给出,这些指标通常由系统的单位阶跃响应定义出来,这些指标分别为:(1)延迟时间:响应曲线首次到达稳态值的 50%所需的时间。(2)上升时间:响应曲线从稳态值的 10%上升到 90%所需要的时间长,对于欠阻尼系统,通常指响应曲线首次到达稳态值所需的时间。(3)峰值时间:响应曲线第一次到达最大值的时间。(4)调整时间:响应曲线开始进入并保持在允许的误差(±2%或±5%)范围内所需要的时间。(5)超调量:响应曲线的最大值和稳态值之差,通常用百分比表示其中y(t)为响应曲线。在 MATLAB 中求取单位阶跃响应的函数为 step,其使用方法如下:step(sys) 在默认的时间范围内绘出系统响应的时域波形step(sys,T) 绘出系统在0T范围内响应的时域波形step(sys,ts:tp:te) 绘出系统在tste范围内,以tp为时间间隔取样的响应波形y,t = step() 该调用格式不绘出响应波形,而是返回响应的数值向量及其对应的时间向量。系统的暂态性能指标可以根据上述定义, 在响应曲线上用鼠标读取关键点或通过搜索曲线对应的数值向量中关键点来确定。三、实验内容1. 已知单位负反馈系统前向通道的传递函数为试用MATLAB 绘制系统的单位阶跃响应曲线。实验代码:num=80;den=1 2 0;G=tf(num,den)T=feedback(G,1);step(T)实验结果:实验分析:根据开环传递函数(前向通路)及反馈类型找到系统闭环传递函数,绘制阶跃响应曲线。由响应曲线可以看出,二阶单位负反馈系统单位阶跃响应的稳态值为1,系统震荡逐渐衰减。2. 已知二阶系统(1) = 0.6,n=5,试用MATLAB 绘制系统单位阶跃响应曲线,并求取系统的暂态性能指标。(2)n=1,从0变化到2,求此系统的单位阶跃响应。(3) = 0.5,n从0变化到1(n0),求此系统的单位阶跃响应。(4)观察上述实验结果,分析这两个特征参数对系统暂态特性的影响。(1)实验代码:v=5; e=0.6; t=0:0.1:10; num=v2; den=1,2*e*v,v2;G=tf(num,den); step(G,8)系统的单位阶跃响应曲线:Tp=0.753s Td=0.272sTr=0.554sTs=1.19s(2)实验代码:for a=0:0.5:2num=1;den=1 2*1*a 1;G=tf(num,den);step(G,20)hold onendlegend('=0','=0.5','=1','=1.5','=2');实验结果:系统的单位阶跃响应曲线:实验分析:随着从0增加到2,频响逐步减弱,在=0时候,是无阻尼振荡,表现为等幅振荡,不稳定;随着增大,进入欠阻尼状态,振荡减小。=1的时候为临界阻尼振荡,>1的时候是过阻尼状态,此时已经没有振荡产生。(3)实验代码:for a=0.2:0.2:1num=a2;den=1 2*0.5*a a2;G=tf(num,den);step(G,20)hold onendlegend('=0.2','=0.4','=0.6','=0.8','=1');此系统的单位阶跃响应曲线:(4)由(2)中实验结果可知,在频率n不变的情况下,阻尼比越大, 上升时间和峰值时间就越长;超调量越小,响应的振荡倾向越弱,平衡性越好;由(3)中实验结果可知,在阻尼比不变的情况下,n越大,延迟时间、上升时间和峰值时间就越短;调节时间越短,快速性越好。四、实验心得体会在本次实验中,我们对于一个系统的动态性能有了一个较好的认识和理解。通过实验中对于频率和阻尼比的改变,观察到这两个参数会影响系统的哪些动态指标。通过matlab实验我能够将课堂上学习到的东西在实验中得到验证,对课堂上的知识有了更深的认识。同时通过这次实验,我深化认识了系统的开环、闭环区别。实验4 系统的频率特性分析一、实验目的1. 学习和掌握利用MATLAB 绘制系统Nyquist 图和Bode 图的方法。2. 学习和掌握利用系统的频率特性分析系统的性能。二、实验原理系统的频率特性是一种图解方法,分析运用系统的开环频率特性曲线,分析闭环系统的性能,如系统的稳态性能、暂态性能常用的频率特性曲线有Nyquist 图和Bode 图。在MATLAB中,提供了绘制Nyquist 图和Bode 图的专门函数。1. Nyquist图nyquist 函数可以用于计算或绘制连续时间LTI系统的Nyquist 频率曲线,其使用方法如下:nyquist(sys) 绘制系统的Nyquist 曲线。nyquist(sys,w) 利用给定的频率向量w 来绘制系统的Nyquist 曲线。re,im=nyquist(sys,w) 返回Nyquist 曲线的实部re 和虚部im,不绘图。2. Bode图bode函数可以用于计算或绘制连续时间LTI系统的Bode图,其方法如下:bode(sys) 绘制系统的Bode图。bode(sys,w)利用给定的频率向量w 来绘制系统的Bode 图。mag,phase=bode(sys,w)返回Bode图数据的幅度mag 和相位phase,不绘图。3. 幅度和相位裕度计算margin 函数可以用于从频率响应数据中计算出幅度裕度、相位裕度及其对应的角频率,其使用方法如下:margin(sys)margin(mag,phase,w)Gm,Pm,Wcg,Wcp = margin(sys)Gm,Pm,Wcg,Wcp = margin(mag,phase,w)其中不带输出参数时,可绘制出标有幅度裕度和相位裕度值的Bode 图,带输出参数时,返回幅度裕度Gm、相位裕度Pm及其对应的角频率Wcg和Wcp。三、实验内容1. 已知系统开环传递函数为绘制系统的Nyquist 图,并讨论其稳定性。实验代码:num1=1000;den1=1 3 2;G1=tf(num1,den1);num2=1;den2=1 5;G2=tf(num2,den2);G=G1*G2;nyquist(G);实验结果:在(-1,j0)左侧正穿越0次,负穿越2次,所以正负穿越之差为-2,不满足稳定判据,所以是闭环不稳定的。2. 已知系统的开环传递函数为(1)绘制系统的零极点图,根据零极点分布判断系统的稳定性。(2)绘制系统Bode 图,求出幅度裕度和相位裕度,判断闭环系统的稳定性。(1)实验代码:num1=10*25/16 5/4 1;den1=conv(1,0,0,conv(10/3,1,conv(0.2/3,1,1/40,1);G1=tf(num1,den1);pzmap(G1);实验结果:极点全部在左半平面,所以系统是稳定的。(2)bode(G1);margin(G1);相位裕度是,幅值裕度为-18.4dB。在Bode图中,相位裕度是,大于,所以系统是稳定的。3. 已知系统的开环传递函数为分别判断当开环放大系数K = 5和K = 20时闭环系统的稳定性,并求出幅度裕度和相位裕度。实验代码:k=input('k=');num1=k;den1=conv(1,0,conv(1,1,0.1,1);G1=tf(num1,den1)bode(G1) ;margin(G1);当k=5时的实验结果:由图可知: 相位裕度:13.6度 幅值裕度:6.85db 闭环稳定 当k=20时的实验结果相位裕度:-9.66度 幅值裕度:-5.19db 闭环不稳定四、实验心得这次实验是画出开环的系统的Nyquist图和Bode图并作出对于系统的分析。实际中闭环函数往往不好求得,但是只要通过系统的开环传递函数的耐奎斯特图和波特图就通过开环函数的特性便可以简便地判定闭环稳定性。这也是我们课堂上的主要内容。本次实验使我对课堂上的内容有了更深的了解。实验6极点配置与全维状态观测器的设计一、 实验目的1.加深对状态反馈作用的理解。2.学习和掌握状态观测器的设计方法。二、实验原理在 MATLAB中,可以使用 acker和 place函数来进行极点配置,函数的使用方法如下:K=acker(A,B,P) A, B为系统系数矩阵, P为配置极点, K为反馈增益矩阵。K=place(A,B,P) A, B为系统系数矩阵, P为配置极点, K为反馈增益矩阵。 K,PREC,MESSAGE=place(A,B,P) A, B为系统系数矩阵, P为配置极点, K为反馈增益矩阵, PREC为特征值, MESSAGE为配置中的出错信息。三、 实验内容1.已知系统(1)判断系统稳定性,说明原因。(2)若不稳定,进行极点配置,期望极点: -1, -2, -3,求出状态反馈矩阵k。 (3)讨论状态反馈与输出反馈的关系, 说明状态反馈为何能进行极点配置? (4)使用状态反馈的前提条件是什么?(1)(2) 代码:a=-2 -1 1;1 0 1;-1 0 1;b=1,1,1'p=-1,-2,-3'K=acker(a,b,p)结果:K =-1 2 4(3)在经典控制理论中,一般只考虑由系统的输出变量来构成反馈律,即输出反馈。在现代控制理论的状态空间分析方法中,多考虑采用状态变量来构成反馈律,即状态反馈。从状态空间模型输出方程可以看出,输出反馈可视为状态反馈的一个特例。状态反馈可以提供更多的补偿信息,只要状态进行简单的计算再反馈,就可以获得优良的控制性能。给定线性定常连续系统确定反馈控制律 使得状态反馈闭环系统的闭环极点配置在指定的n个期望的闭环极点,即(4)使用状态反馈配置极点的前提是系统的状态是完全可控的。2. 已知系统设计全维状态观测器, 使观测器的极点配置在-2±j 。(1)给出原系统的状态曲线。(2)给出观测器的状态曲线并加以对比。实验代码:A=0 1;-3 -4;B=0;1;C=2 0;D=;G=ss(A,B,C,D);step(G); v=-2+j,-2-j;L=(acker(A',C',v)' %求反馈矩阵K=acker(A,B,v) %状反馈矩阵I=eye(2)G(s)=C*(s*I-(A-B*k)-1*B %带观测器的闭环控制系统的传递函数step(g);hold on··step(G) %原系统与带观测器的系统的单位阶跃状态响应曲线实验结果:L=0 1,K=2 0观察实验结果, 思考以下问题:(1) 说明反馈控制闭环期望极点和观测器极点的选取原则。(2) 说明增益矩阵对(k, L)的变化对系统性能的影响关系。(3) 说明观测器的引入对系统性能的影响。(1)答:由于线性定常系统的特征多项式为实系数多项式,因此考虑到问题的可解性,对期望的极点的选择应注意下列问题:1) 对于n阶系统,可以而且必须给出n个期望的极点;2) 期望的极点必须是实数或成对出现的共轭复数;3) 期望的极点必须体现对闭环系统的性能品质指标等的要求。(2)答:K的变化会引起系统极点的变化,进而影响系统的各项动态性能指标和稳定性,L的变化会影响观测器的状态随控制对象的逼近速度。(3)由于状态变量是描述系统内部动态运动和特性的,因此对实际控制系统,它可能不能直接测量,更甚者是抽象的数学变量,实际中不存在物理量与之直接对应。若状态变量不能直接测量,则在状态反馈中需要引入所谓的状态观测器来估计系统的状态变量的值,再用此估计值来构成状态反馈律。四、 实验体会 本次实验加深了我对状态反馈作用的理解。学习了使用matlab进行极点匹配的方法。学习和掌握了状态观测器的设计方法,同时对状态观测器这一方法有了更深的理解,并使我对课堂上的知识有了更深刻的认识。