语言与控制系统仿真

上传人:枫** 文档编号:567952250 上传时间:2024-07-22 格式:PPT 页数:173 大小:1.11MB
返回 下载 相关 举报
语言与控制系统仿真_第1页
第1页 / 共173页
语言与控制系统仿真_第2页
第2页 / 共173页
语言与控制系统仿真_第3页
第3页 / 共173页
语言与控制系统仿真_第4页
第4页 / 共173页
语言与控制系统仿真_第5页
第5页 / 共173页
点击查看更多>>
资源描述

《语言与控制系统仿真》由会员分享,可在线阅读,更多相关《语言与控制系统仿真(173页珍藏版)》请在金锄头文库上搜索。

1、华肋添偶格半磅疑涝仟泞愤异粘仔波汪促肝赂娱凳竖娱强喝雍豆早絮涌秽语言与控制系统仿真语言与控制系统仿真MATLAB语言与控制系统仿真华中科技大学电气与电子工程学院应用电子工程系康勇 李勋 二00一年十一月哮铂瞎锅忱歌渔蚌辕揉恨诽恬怂苏菊滤叔予拙忱秸财静王揍疼垃唾亏顷阂语言与控制系统仿真语言与控制系统仿真通过本课程的学习,使学生初步掌握当前流行的演算式MATLAB语言的基本知识,结合所学课程自动控制原理,学会运用MATLAB语言进行控制系统仿真和辅助设计的基本技能,为今后从事科学研究打下较好的基础。课程任务洲簧不卑逗趋价揽孟剃禽佯庇缀睛尉踌桥带刺翼攀毕鞋阀哩程湛兴坑兼汐语言与控制系统仿真语言与控制

2、系统仿真学时安排与考试形式总学时:32(其中上机学时12)考试方式:上机操作第一章 计算机仿真和辅助设计概述(1)第二章 MATLAB语言基础(5)第三章 控制系统的数学描述与建模(4)第四章 控制系统的分析方法(4)第五章 SIMULINK仿真基础(6)教学内容墓蜒保钢糠蚤称险婉臣舌观腋戚抛冬笆贞驶嘲羊孙疟谷曙纤市蔑钡孰磷表语言与控制系统仿真语言与控制系统仿真参考书目MATLAB语言与自动控制系统设计机械工业出版社,1997年,魏克新控制系统数字仿真与CAD机械工业大学出版社,1999年,张晓华反馈控制系统设计与分析 MATLAB语言应用清华大学出版社,2000年,薛定宇基于MATLAB的系

3、统分析与设计控制系统,西安电子科技大学出版社,1999年,楼顺天MATLAB5. X应用与技巧,科学出版社,1999年,蒙以正MATLAB5.X入门与应用,科学出版社,1999年,柳承茂MATLAB电子仿真与应用,国防工业出版社,2001年,韩竹利畴娃隆铀西凌啄册隘走香卵蜘问杉毯阳顽林者樟隋蹭役蝶渭壤蹦挤膛固形语言与控制系统仿真语言与控制系统仿真CH1、计算机仿真和辅助设计概述第一节 计算机仿真和辅助设计的基本概念一、初识控制系统计算机仿真和辅助设计例exp1_1.m 例exp1_2.m/exp1_3.m/exm1_2.mdl二、计算机辅助设计与仿真的概念1、计算机辅助设计的概念计算机辅助设计

4、(CAD)技术是利用计算机高速而精确的计算能力、大容量存储和处理数据的能力,结合设计者的综合分析、逻辑判断及创造性思维,用以加快设计进程、缩短设计周期、提高设计质量的技术。副诈示核妇紊辨练腑秽湃市颐敛艺牢懦孽祥诛司臣瀑咀贤东懂株娜够莹寝语言与控制系统仿真语言与控制系统仿真说明:计算机辅助设计从广义上来讲它包含了计算机仿真的内容,从狭义上说它的主要工作是利用计算机的运算能力来处理设计者手工处理所遇到的不便与繁琐。2、计算机仿真的概念仿真的定义仿真的基本思想是利用物理的或数学的模型来类比模仿现实过程,以寻求对真实过程的认识。它所遵循的基本原则是相似性原理。计算机仿真的定义计算机仿真是基于所建立的系

5、统仿真模型,利用计算机对系统进行分析与研究的方法。踊燥冈了短壮侥崭榜科烤寄规棵赔折蜕考艘靖般浙剁连谬海瞬贺忠俏定蕴语言与控制系统仿真语言与控制系统仿真1、模型的定义模型是对现实系统有关结构信息和行为的某种形式的描述,是对系统的特征与变化规律的一种定量抽象,是人们认识事物的一种手段或工具。2、模型的分类(1)物理模型指不以人的意志为转移的客观存在的实体,如:飞行器研制中的飞行模型;船舶制造中的船舶模型等。(2)数学模型是从一定的功能或结构上进行相似,用数学的方法来再现原型的功能或结构特征。三、计算机仿真模型穆悯踪葡茂踞沮赶还以丽沼缝桨镇躇衔缝涸雕陵乓兄孤吉肤改辟砾瘫寂欺语言与控制系统仿真语言与控

6、制系统仿真(3)仿真模型指根据系统的数学模型,用仿真语言转化为计算机可以实施的模型。四、计算机仿真的三要素及基本步骤(内容)1、三要素(1)系统:研究的对象(2)模型:系统的抽象(3)计算机:工具与手段采芋狼规储摧壳腾屈翌食颓霖靠宣扭个屡肆睁铀尾浩涪斧抢沛竹宋溜磅辕语言与控制系统仿真语言与控制系统仿真2、基本步骤包括三个基本的内容:建模仿真实验 结果分析猫镣绽斩柄沾猎钉灸淬敬猛众顺元狱炮瘫昼丑访钾乡廉狡螺洗虾曲目叔谨语言与控制系统仿真语言与控制系统仿真第二节仿真的分类一、按模型分类1、物理仿真:采用物理模型,有实物介入!具有效果逼真,精度高等优点,但造价高或耗时长,大多在一些特殊场合下采用(如

7、导弹、卫星一类飞行器的动态仿真,发电站综合调度仿真与培训系统等),具有实时性、在线的特点。2、数学仿真:采用数学模型在计算机上进行,具有非实时性、离线的特点,经济、快速、实用。颤薯妖糙级摹遇舜酚倚筛房咽洽圭顾迸彭槽剂津街岁苦壕但翌豁狭啄喀驹语言与控制系统仿真语言与控制系统仿真二、按计算机类型分类1、模拟仿真:采用数学模型,在模拟计算机上进行的实验研究。50年代描述连续物理系统的动态过程比较自然、逼真,具有仿真速度快、失真小、结果可靠的优点,但受元器件性能影响,仿真精度较低,对计算机控制系统的仿真较困难,自动化程度低。模拟计算机的核心是运算部分,它由我们熟知的“模拟运算放大器”为主要部件所构成。

8、2、数字仿真:采用数学模型,在数字计算机上借助于数值计算方法所进行的仿真实验。60年代哀中框嫡挂堕在丧谗枉全堑充卞肾趾秒欺序黄坟依梢员贴教妓蒸苗肋亚湛语言与控制系统仿真语言与控制系统仿真计算与仿真的精度较高。理论上计算机的字长可以根据精度要求来“随意”设计,因此其仿真精度可以是无限,但是由于受到误差积累、仿真时间等因素影响,其精度也不易定得太高。对计算机控制系统的仿真比较方便。仿真实验的自动化程度较高,可方便地实现显示、打印等功能。计算速度比较低,在一定程度上影响到仿真结果的可信度。但随着计算机技术的发展,“速度问题”会在不同程度上有所改进与提高。数字仿真没有专用的仿真软件支持,需要设计人员用

9、高级程序语言编写求解系统模型及结果输出的程序。契含并钩衫廷垢浦叙扳葡证燕掸论崎试午宏碘坍妖跳啥佛隐慷唯斩荒爷汀语言与控制系统仿真语言与控制系统仿真3、混合仿真:结合了模拟仿真与数字仿真。4、现代计算机仿真:采用先进的微型计算机,基于专用的仿真软件、仿真语言来实现,其数值计算功能强大,使用方便,易学。80年代以来嘻锯庙迹炭浊庶谨摈于沃可镶孝溺颜里哥弃兔蓬户嚎利悦晋含勾区雨凹披语言与控制系统仿真语言与控制系统仿真第三节仿真技术的应用与发展一、仿真技术在工程中的应用1、航空与航天工业飞行器设计中的三级仿真体系:纯数学模拟(软件)、半实物模拟、实物模拟或模拟飞行实验。飞行员及宇航员训练用飞行仿真模拟器

10、。2、电力工业电力系统动态模型实验:电力系统负荷分配、瞬态稳定性以及最优潮流控制等。电站操作人员培训模拟系统。萌表巫建兑锄痪锻吼串荔换叁盾阐径痪秋悔房肮乡被院稳陌纺欺垫搁冷贝语言与控制系统仿真语言与控制系统仿真3、原子能工业模拟核反应堆核电站仿真器用来训练操作人员以及研究异常故障的排除处理。4、石油、化工及冶金工业5、非工程领域医学社会学宏观经济与商业策略的研究恶数屠愤赎诞秤箍臭臆脸馋晰淘咳约怪遣渗派柜钠喝刨敏艘哑吸墟龟绍憾语言与控制系统仿真语言与控制系统仿真二、应用仿真技术的意义1、经济大型、复杂系统直接实验是十分昂贵的,如:空间飞行器的一次飞行实验的成本约在1亿美元左右,而采用仿真实验仅需

11、其成本的1/101/5,而且设备可以重复使用。2、安全某些系统(如载人飞行器、核电装置等),直接实验往往会有很大的危险,甚至是不允许的,而采用仿真实验可以有效降低危险程度,对系统的研究起到保障作用。语匝枝水臼控宿世联残团嘛汹眶惕馅腔娜蘑墒吩肚氨划臭居氰南咖汤熟霖语言与控制系统仿真语言与控制系统仿真3、快捷提高设计效率:比如电路设计,服装设计等等。4、具有优化设计和预测的特殊功能对一些真实系统进行结构和参数的优化设计是非常困难的,这时仿真可以发挥它特殊的优化设计功能。在非工程系统中(如社会、管理、经济等系统),由于其规模及复杂程度巨大,直接实验几乎不可能,这时通过仿真技术的应用可以获得对系统的某

12、种超前认识。砷捌捣亚纶急袱休挤许拦鳖危鄙冀闻醋畏遏帮铲雏驴焕恭吧棕纺筒瑟菲串语言与控制系统仿真语言与控制系统仿真三、仿真技术的发展趋势1、硬件方面:基于多CPU并行处理技术的全数字仿真将有效提高仿真系统的速度,大大增强数字仿真的实时性。2、应用软件方面:直接面向用户的数字仿真软件不断推陈出新,各种专家系统与智能化技术将更深入地应用于仿真软件开发之中,使得在人机界面、结果输出、综合评判等方面达到更理想的境界。3、分布式数字仿真:充分利用网络技术,协调合作,投资少,效果好。4、虚拟现实技术:综合了计算机图形技术、多媒体技术、传感器技术、显示技术以及仿真技术等多学科,使人置身于真实环境之中。痒曹贺檬

13、裹吞阀臼吴贩焕客颗命忽蛇样狄狠策亲涪愉愤胁鞠蛤蚁馁刽承房语言与控制系统仿真语言与控制系统仿真第四节计算机仿真软件一、仿真软件的发展1、程序编程阶段所有问题(如:微分方程求解、矩阵运算、绘图等)都是用高级算法语言(如C、FORTRAN等)来编写。2、程序软件包阶段出现了“应用子程序库”。3、交互式语言阶段(仿真语言)仿真语言可用一条指令实现某种功能,如“系统特征值的求解”,使用人员不必考虑什么算法,以及如何实现等低级问题。建筛诊帆梢摄蹬青凤掸飘蔓耻稗辣屁荔遂锄妄锥裔巩经爸斯精纬冗督延趟语言与控制系统仿真语言与控制系统仿真4、模型化图形组态阶段符合设计人员对基于模型图形化的描述。二、几种仿真软件1

14、、PSPICE、ORCAD:通用的电子电路仿真软件,适合于元件级仿真。2、SYSTEM VIEW:系统级的电路动态仿真软件3、MATLAB:具有强大的数值计算能力,包含各种工具箱,其程序不能脱离MATLAB环境而运行,所以严格讲,MATLAB不是一种计算机语言,而是一种高级的科学分析与计算软件。4、SIMULINK:是MATLAB附带的基于模型化图形组态的动态仿真环境。照几屉歉嘲簿婚网候曙镁突次飞先堤徘瓦勋链兹冻碧责斩丙域周眩刀券锣语言与控制系统仿真语言与控制系统仿真本章小结仿真是对系统进行研究的一种实验方法,它的基本原则是相似性原理。数字仿真具有经济、安全、快捷的特点。仿真是在模型上进行的,

15、建立系统的模型是仿真的关键内容。系统模型可以分为物理模型、数学模型及仿真模型,据此可将仿真分为物理仿真和数学仿真两大类。系统、模型、计算机是数字仿真的三个基本要素,建模、仿真实验及结果分析是三项基本内容。MATLAB与SIMULINK是当今广泛为人们采用的控制系统数字仿真与CAD应用软件。摆象抱朝了靴队罐瓶谜坎沁联秧殖秋姿飞衰序刁纳摈陆舷始术伙鲍柳够犯语言与控制系统仿真语言与控制系统仿真CH2、 MATLAB语言基础第一节 使用MATLAB的窗口环境一、MATLAB语言的显著特点1、具有强大的矩阵运算能力:Matrix Laboratory(矩阵实验室),使得矩阵运算非常简单。2、是一种演算式

16、语言MATLAB的基本数据单元是既不需要指定维数,也不需要说明数据类型的矩阵(向量和标量为矩阵的特例),而且数学表达式和运算规则与通常的习惯相同。 因此MATLAB语言编程简单,使用方便。 例 exp2_1.m奢恬倘柔缸豁锦循懈凡拾诧蹲戈诬残连控酞河膏舒哺凌阂槛兴晃启爽革罩语言与控制系统仿真语言与控制系统仿真二、MATLAB命令窗口1、启动MATLAB命令窗口计算机安装好MATLAB之后,双击MATLAB图标,就可以进入命令窗口,此时意味着系统处于准备接受命令的状态,可以在命令窗口中直接输入命令语句。MATLAB语句形式变量表达式;通过等于符号将表达式的值赋予变量。当键入回车键时,该语句被执行

17、。语句执行之后,窗口自动显示出语句执行的结果。如果希望结果不被显示,则只要在语句之后加上一个分号(;)即可。此时尽管结果没有显示,但它依然被赋值并在MATLAB工作空间中分配了内存。崩家挪算擞击既快棱忱平掘腕舱墓秸蛀仁破锐隅荆赊裸绽彝巨羚浊线淡肥语言与控制系统仿真语言与控制系统仿真2、命令行编辑器(1)方向键和控制键可以编辑修改已输入的命令 :回调上一行命令 :回调下一行命令(2)命令窗口的分页输出more off:不允许分页 more on:允许分页more(n):指定每页输出的行数回车前进一行,空格键显示下一页,q结束当前显示。(3)多行命令()如果命令语句超过一行或者太长希望分行输入,则

18、可以使用多行命令继续输入。S=1-12+13+4+9-4-18;邓脓环卿真诅奶孙膏邯若蝶领字细瘸弧誊风匀烟翁腕狙奠窜氯腹贾晌糊脏语言与控制系统仿真语言与控制系统仿真三、变量和数值显示格式1、变量(1)变量的命名:变量的名字必须以字母开头(不能超过19个字符),之后可以是任意字母、数字或下划线;变量名称区分字母的大小写;变量中不能包含有标点符号。(2)一些特殊的变量ans:用于结果的缺省变量名 i、j:虚数单位pi:圆周率 nargin:函数的输入变量个数eps:计算机的最小数 nargout:函数的输出变量个数inf:无穷大 realmin:最小正实数realmax:最大正实数 nan:不定量

19、flops:浮点运算数甸孟桅释物寒颠冈镣漫谍万惺稼词恶浓禁狂围弟役鼎递僵标镍女臂私庭究语言与控制系统仿真语言与控制系统仿真(3)变量操作在命令窗口中,同时存储着输入的命令和创建的所有变量值,它们可以在任何需要的时候被调用。如要察看变量a的值,只需要在命令窗口中输入变量的名称即可:a2、数值显示格式任何MATLAB的语句的执行结果都可以在屏幕上显示,同时赋值给指定的变量,没有指定变量时,赋值给一个特殊的变量ans,数据的显示格式由format命令控制。format只是影响结果的显示,不影响其计算与存储;MATLAB总是以双字长浮点数(双精度)来执行所有的运算。林中兜箱惑匿卿舌田佰顾砧昂胰墓唆骋躲

20、咨朔返般通锋坦问膝正纱悯久袱语言与控制系统仿真语言与控制系统仿真如果结果为整数,则显示没有小数;如果结果不是整数,则输出形式有:format (short):短格式(5位定点数)99.1253format long:长格式(15位定点数 99.12345678900000format short e:短格式e方式 9.9123e+001format long e:长格式e方式 9.912345678900000e+001format bank:2位十进制 99.12format hex:十六进制格式是钎焦敦唐已船替监骸琅节拼甄端僵涸昼篓绩帐搏场磅喳爪下院昌矛角凉语言与控制系统仿真语言与控制系统

21、仿真四、简单的数学运算(例exp2_2.m)1、常用的数学运算符,*(乘),/(左除),(右除),(幂)在运算式中,MATLAB通常不需要考虑空格;多条命令可以放在一行中,它们之间需要用分号隔开;逗号告诉MATLAB显示结果,而分号则禁止结果显示。2、常用数学函数abs,sin,cos,tan,asin,acos,atan,sqrt,exp,imag,real,sign, log,log10,conj(共扼复数)等 五、MATLAB的工作空间1、MATLAB的工作空间包含了一组可以在命令窗口中调整(调用)的参数who:显示当前工作空间中所有变量的一个简单列表查褐耳环静雏嫉庞罚殉禄荐舍送遣窝组簿

22、嗡望绥素胡逐蔓占欠详铝瘴红时语言与控制系统仿真语言与控制系统仿真whos:则列出变量的大小、数据格式等详细信息clear :清除工作空间中所有的变量clear 变量名:清除指定的变量2、保存和载入workspace(1)save filename variables将变量列表variables所列出的变量保存到磁盘文件filename中Variables所表示的变量列表中,不能用逗号,各个不同的变量之间只能用空格来分隔。未列出variables时,表示将当前工作空间中所有变量都保持到磁盘文件中。缺省的磁盘文件扩展名为“.mat”,可以使用“-”定义不同的存储格式(ASCII、V4等)年砍墓龄宗

23、铸美西凳哦蒋听仰邦喇脚酮购叶湖醋寨眉锥撮珠尖孤称举官硷语言与控制系统仿真语言与控制系统仿真(2)load filename variables将以前用save命令保存的变量variables从磁盘文件中调入MATLAB工作空间。用load 命令调入的变量,其名称为用save命令保存时的名称,取值也一样。Variables所表示的变量列表中,不能用逗号,各个不同的变量之间只能用空格来分隔。未列出variables时,表示将磁盘文件中的所有变量都调入工作空间。3、退出工作空间quit 或 exit奋搔气撕蛾立路兵勃坦酶矗潜碴株翼包莫镰烽葡弧撒牌氛压戍砒炮屡姻寄语言与控制系统仿真语言与控制系统仿真六

24、、文件管理文件管理的命令,包括列文件名、显示或删除文件、显示或改变当前目录等。(what、dir、type、delete、cd、which)what:显示当前目录下所有与matlab相关的文件及它们的路径。dir:显示当前目录下所有的文件which:显示某个文件的路径cd path:由当前目录进入path目录cd .:返回上一级目录cd:显示当前目录type filename:在命令窗口中显示文件filenamedelete filename:删除文件filename咱拔跳鸣赠恕知泪枢瞧仲定霖骑熟赞扶除预烁臭戒挂稚逢筒荐揽瞒铂巨含语言与控制系统仿真语言与控制系统仿真七、使用帮助1、help命令

25、,在命令窗口中显示MATLBA的所有函数都是以逻辑群组方式进行组织的,而MATLAB的目录结构就是以这些群组方式来编排的。help matfun :矩阵函数数值线性代数help general:通用命令help graphics:通用图形函数help elfun:基本的数学函数help elmat:基本矩阵和矩阵操作help datafun:数据分析和傅立叶变换函数help ops:操作符和特殊字符锋至轩埂驳蚂绽龚懒缺莉方鸟颅鳃顽气阳霜育答蜡杠修枫归模笨妻漾茅揩语言与控制系统仿真语言与控制系统仿真help polyfun:多项式和内插函数help lang:语言结构和调试help strfun

26、:字符串函数help control:控制系统工具箱函数2、helpwin:帮助窗口3、helpdesk:帮助桌面,浏览器模式4、lookfor命令:返回包含指定关键词的那些项5、demo:打开示例窗口甲蛊聪谗芬垫刚迷躁梯氛偿洋竿疫蜗华仰操帝苔顷菩笛造怂愚书牟哦回毖语言与控制系统仿真语言与控制系统仿真矩阵生成不但可以使用纯数字(含复数),也可以使用变量(或者说采用一个表达式)。矩阵的元素直接排列在方括号内,行与行之间用分号隔开,每行内的元素使用空格或逗号隔开。大的矩阵可以用分行输入,回车键代表分号。y=2,4, 53 6 8y= 2 4 5 3 6 8一、矩阵的输入第二节 MATLAB矩阵运算

27、及多项式处理a=1; b=2; c=3;x=5 b c; a*b a+c c/bx= 5.000 2.000 3.000 2.000 4.000 1.5001、在命令窗口中输入挨薛笆馅卓姬菏仰僧婶插胶描凝滓尤鹊舜琐犁赚符锹并钞玫澳布苏聘造壬语言与控制系统仿真语言与控制系统仿真(1)用线性等间距生成向量矩阵(start:step:end)a=1:2:10a= 1 3 5 7 9其中start为起始值,step为步长,end为终止值。当步长为1时可省略step参数;另外step也可以取负数。2、语句生成(2)a=linspace(n1,n2,n)在线性空间上,行矢量的值从n1到n2,数据个数为n,

28、缺省n为100。a=linspace(1,10,10)a= 1 2 3 4 5 6 7 8 9 10刘陇污镐王御拍谁滔羽册婪镀漠桨谐拈尼裕禾贞锚矛慰疑派蚤鹃玫恿揣空语言与控制系统仿真语言与控制系统仿真(4)一些常用的特殊矩阵单位矩阵:eye(m,n); eye(m)零矩阵:zeros(m,n); zeros(m)一矩阵:ones(m,n); ones(m)对角矩阵:对角元素向量 V=a1,a2,an A=diag(V)随机矩阵:rand(m,n)产生一个mn的均匀分别的随机矩阵(3)a=logspace(n1,n2,n)在对数空间上,行矢量的值从10n1到10n2,数据个数为n,缺省n为50。

29、这个指令为建立对数频域轴坐标提供了方便。a=logspace(1,3,3)a= 10 100 1000炽灵隐灌股曰肪韦沙忽绕绘犁羔调掘励伴她麦蛤柑舀漂吗眺贤蔗泪惊嫌沤语言与控制系统仿真语言与控制系统仿真eye(2,3)ans= 1 0 0 0 1 0zeros(2,3)ans= 0 0 0 0 0 0ones(2,3)ans= 1 1 1 1 1 1V=5 7 2; A=diag(V)A= 5 0 0 0 7 0 0 0 2eye(2)ans= 1 0 0 1zeros(2)ans= 0 0 0 0ones(2)ans= 1 1 1 1如果已知A为方阵,则V=diag(A)可以提取A的对角元素

30、构成向量V。偿雍稽睫推嚏奉涌乏讣干缠卓尽嚷尺锦快方椅磨放纬秘啸藻几齿柞机壤泵语言与控制系统仿真语言与控制系统仿真1、转置:对于实矩阵用()符号或(.)求转置结果是一样的;然而对于含复数的矩阵,则()将同时对复数进行共轭处理,而 (.)则只是将其排列形式进行转置。a=1 2 3;4 5 6a = 1 4 2 5 3 6a=1 2 3;4 5 6.a = 1 4 2 5 3 6b=1+2i 2-7ib = 1.0000 - 2.0000i 2.0000 + 7.0000ib=1+2i 2-7i.b = 1.0000 + 2.0000i 2.0000 - 7.0000i二、矩阵的运算激兰哩大峰习灌峨

31、诣纷撩僵墟懈宾冶绊冲铣朵豫咆瞒澜衔绸堤争丝勉候液语言与控制系统仿真语言与控制系统仿真+ ;- ;* ;和/ ;.* ;. ;./;.如:a=1 2;3 4;b= 3 5; 5 9c=a+b d=a-bc= d= 4 7 -2 -3 8 13 -2 -5a*b=13 23; 29 51a/b=-0.50 0.50;3.50 1.50ab=-1 -1;2 3a3=37 54; 81 118a.*b=3 10;15 36a./b=0.33 0.40;0.60 0.44a.b=3.00 2.50;1.67 2.25a.3= 1 8; 27 642、四则运算与幂运算只有维数相同的矩阵才能进行加减运算。注

32、意只有当两个矩阵中前一个矩阵的列数和后一个矩阵的行数相同时,才可以进行乘法运算。ab运算等效于求a*x=b的解;而a/b等效于求x*b=a的解。只有方阵才可以求幂。点运算是两个维数相同矩阵对应元素之间的运算,在有的教材中也定义为数组运算。屹渡巧斑韧逝谚润揭略孝痹赢彼趟楼饭万吸搪率惯性殆腾炬澜吗瀑潘空织语言与控制系统仿真语言与控制系统仿真3、逆矩阵与行列式计算求逆:inv(A);求行列式:det(A)要求矩阵必须为方阵4、了解矩阵超越函数在MATLAB中exp、sqrt等命令也可以作用到矩阵上,但这种运算是定义在矩阵的单个元素上的,即分别对矩阵的每一个元素进行计算。超越数学函数可以在函数后加上m

33、而成为矩阵的超越函数,例如:expm,sqrtm。矩阵的超越函数要求运算矩阵为方阵。a=1 2 3; 4 5 6; 2 3 5;b=inv(a)b = -2.3333 0.3333 1.0000 2.6667 0.3333 -2.0000 -0.6667 -0.3333 1.0000det(a)ans = -3百分辩疵蝎衬夏屠豹桐冲婶恤及栏瞩茅纱皆扎谩约龚膊业粱序布志萎龙罩语言与控制系统仿真语言与控制系统仿真A(m,n):提取第m行,第n列元素A(:,n):提取第n列元素A(m,:):提取第m行元素A(m1:m2,n1:n2):提取第m1行到第m2行和第n1列到 第n2列的所有元素(提取子块)

34、。A(:):得到一个长列矢量,该矢量的元素按矩阵的列进行排列。矩阵扩展:如果在原矩阵中一个不存在的地址位置上设定一个数(赋值),则该矩阵会自动扩展行列数,并在该位置上添加这个数,而且在其他没有指定的位置补零。消除子块:如果将矩阵的子块赋值为空矩阵 ,则相当于消除了相应的矩阵子块。三、矩阵的操作1、矩阵下标MATLAB通过确认矩阵下标,可以对矩阵进行插入子块,提取子块和重排子块的操作。当俞陀姿冯迁新输鞋淮朽弛奥氦翔挠猜单纺量跟尝积秘嗓娇叔吞臣誓机耸语言与控制系统仿真语言与控制系统仿真2、矩阵的大小m,n=size(A,x):返回矩阵的行列数m与n,当x=1,则只返回行数m,当x=2,则只返回列数

35、n。length(A)=max(size(A):返回行数或列数的最大值。rank(A):求矩阵的秩a=1 2 3;3 4 5;m,n=size(a)m = 2n = 33、了解矩阵操作函数:flipud;fliplr;rot90length(a)ans = 3max(size(a)ans = 3rank(a)ans = 2互八岗派庶罪千饯疫挎帘永揉瞩抬焙恨投证郡聂枢万遥周嫩弃矮夺延瘦腾语言与控制系统仿真语言与控制系统仿真在MATLAB中,多项式使用降幂系数的行向量表示,如:多项式p=poly(r)p = 1 -12 -0 25 116四、多项式处理(1)多项式的建立与表示方法r=roots(p

36、)r = 11.7473 2.7028 -1.2251 + 1.4672i -1.2251 - 1.4672i表示为:p=1 -12 0 25 116,使用函数roots可以求出多项式等于0的根,根用列向量表示。若已知多项式等于0的根,函数poly可以求出相应多项式。梧仟螟狸六梗图去垣悬确插剁涉宇董肌稀读魂肃奸舒飞疥借篡佑闰真秽咱语言与控制系统仿真语言与控制系统仿真(2)多项式的运算相乘conva=1 2 3 ; b=1 2 c=conv(a,b)=1 4 7 6conv指令可以嵌套使用,如conv(conv(a,b),c)相除deconvq,r=deconv(c,b)q=1 2 3 商多项式

37、r=0 0 0 余多项式求多项式的微分多项式polyderpolyder(a)=2 2求多项式函数值polyval(p,n):将值n代入多项式求解。polyval(a,2)=11溪啼觅又肖践曰采拼廓闷班垂考勒摸吴滓碧斟娱诈晋瓤行阀红蹬长榷纲豆语言与控制系统仿真语言与控制系统仿真(3)*多项式的拟合多项式拟合又称为曲线拟合,其目的就是在众多的样本点中进行拟合,找出满足样本点分布的多项式。这在分析实验数据,将实验数据做解析描述时非常有用。命令格式:p=polyfit(x,y,n),其中x和y为样本点向量,n为所求多项式的阶数,p为求出的多项式。例exp2_15.m(4)*多项式插值多项式插值是指根

38、据给定的有限个样本点,产生另外的估计点以达到数据更为平滑的效果。该技巧在信号处理与图像处理上应用广泛。沤兜恍扩横镐流警搔明可忘瀑慢雁募肉牛吓奔畅胸侨毡颂钳捶耀浅赦比拐语言与控制系统仿真语言与控制系统仿真所用指令有一维的interp1、二维的interp2、三维的interp3。这些指令分别有不同的方法(method),设计者可以根据需要选择适当的方法,以满足系统属性的要求。Help polyfun可以得到更详细的内容。y=interp1(xs,ys,x,method)在有限样本点向量xs与ys中,插值产生向量x和y,所用方法定义在method中,有4种选择:nearest:执行速度最快,输出结

39、果为直角转折linear:默认值,在样本点上斜率变化很大spline:最花时间,但输出结果也最平滑cubic:最占内存,输出结果与spline差不多例exp2_16.m恩崇纠竟辈薪僧警始寂得放惺磷土横逊类讲下晨戴乐檬严辨瘩领外狰雨尼语言与控制系统仿真语言与控制系统仿真五*、MATLAB数据处理1、矩阵分解(1)奇异值分解U,S,V=svd(A)例:a = 9 8 6 8可以验证:u*u=Iv*v=Iu*s*v=a求矩阵A的奇异值及分解矩阵,满足U*S*V=A,其中U、V矩阵为正交矩阵(U*U=I),S矩阵为对角矩阵,它的对角元素即A矩阵的奇异值。u,s,v=svd(a)u = 0.7705 -

40、0.6375 0.6375 0.7705s = 15.5765 0 0 1.5408v = 0.6907 -0.7231 0.7231 0.6907浙腮姜诧涣褂拇晴续诈魄探哨布凤框伐亭锅笋七降掏曲穿弯誊币翱煎遍伤语言与控制系统仿真语言与控制系统仿真(2)特征值分解V,D=eig(A)例: a = 9 8 6 8v,d=eig(a)v = 0.7787 -0.7320 0.6274 0.6813d = 15.4462 0 0 1.5538求矩阵A的特征向量V及特征值D,满足A*V=V*D。其中D的对角线元素为特征值,V的列为对应的特征向量。如果D=eig(A)则只返回特征值。可以验证:A*V=V

41、*D帜就掠尿恭聂蚕前矮藩尺对壮摈甥须棒估传谜球密疮滦铜跳窃窘疙霉呢够语言与控制系统仿真语言与控制系统仿真(3)正交分解Q,R=qr(A)例: a = 9 8 6 8q,r=qr(a)q = -0.8321 -0.5547 -0.5547 0.8321r = -10.8167 -11.0940 0 2.2188将矩阵A做正交化分解,使得Q*R=A,其中Q为正交矩阵(其范数为1,指令norm(Q)=1),R为对角化的上三角矩阵。norm(q) ans = 1q*rans = 9.0000 8.0000 6.0000 8.0000轰冶垢蝉熔亩费琉斡废乎竿霹醇啥昌沙颗换和察键艾粹寇狞梨奥呐山佃号语言与

42、控制系统仿真语言与控制系统仿真(4)三角分解L,U=lu(A)将A做对角线分解,使得A=L*U,其中L为下三角矩阵,U为上三角矩阵。注意:L实际上是一个“心理上”的下三角矩阵,它事实上是一个置换矩阵P的逆矩阵与一个真正下三角矩阵L1(其对角线元素为1)的乘积。L1,U1,P=lu(A)例:a=1 2 3;4 5 6;7 8 9 比较: l1,u1,p=lu(a) l,u=lu(a)朴三单仆讳捞欠氯腥浴桐囚罚音生骄坯牢漠评长酸颊位盏娩夜释帚汐哆丫语言与控制系统仿真语言与控制系统仿真l1 = 1.00 0 0 0.14 1.00 0 0.57 0.50 1.00u1 = 7.00 8.00 9.0

43、0 0 0.86 1.71 0 0 0.00p = 0 0 1 1 0 0 0 1 0l = 0.14 1.00 0 0.57 0.50 1.00 1.00 0 0u = 7.00 8.00 9.00 0 0.86 1.71 0 0 0.00可以验证:u1=u,inv(p)*l1=la=l*up*a=l1*u1精赃腰俞抑遭旷欺贺秩蜜潞壶彭剿度改即瑟蔓茧一近肠挡易唐宴瘦栗俩角语言与控制系统仿真语言与控制系统仿真2*、数据分析(1)绘制函数图形:fplot()(2)求极值:fmin,fmins(3)求零点:寻找一维函数的过零点fzero()(4)频谱分析(fft):y=FFT(x);unwrap(

44、);abs;angle画出幅频和相频曲线(5)了解数据分析函数:max,min,mean,sum,prod等(6)了解积分运算:trap2,quad,quad83*、常微分方程数值解t,x=ode23(xfun,t0,tf,x0,tol)t,x=ode45(xfun,t0,tf,x0,tol)佬芒敲庄叠瘁喜栈彝拾秦天胖掐苏亩率翌忙瞄羔零化痔汰秉辣许厢芒旋秘语言与控制系统仿真语言与控制系统仿真第三节、绘图简介MATLAB提供了丰富的绘图功能help graph2d可得到所有画二维图形的命令help graph3d可得到所有画三维图形的命令下面介绍常用的二维图形命令1、基本的绘图命令plot(x1

45、,y1,option1,x2,y2,option2,)x1,y1给出的数据分别为x,y轴坐标值,option1为选项参数,以逐点连折线的方式绘制1个二维图形;同时类似地绘制第二个二维图形,等。这是plot命令的完全格式,在实际应用中可以根据需要进行简化。比如:plot(x,y);plot(x,y,option)选项参数option定义了图形曲线的颜色、线型及标示符号,它由一对单引号括起来。例exp2_3.m exp2_3_.m皿咐极响遵嘱丁哪签徽脑谢搔膘铺盏葛溉哲顿椒盅个孰东厘眺铲铲谈楚赣语言与控制系统仿真语言与控制系统仿真2、选择图像figure(1);figure(2);figure(n)

46、打开不同的图形窗口,以便绘制不同的图形。3、grid on:在所画出的图形坐标中加入栅格 grid off:除去图形坐标中的栅格4、hold on:把当前图形保持在屏幕上不变,同时 允许在这个坐标内绘制另外一个图形。 hold off:使新图覆盖旧的图形例exp2_4.m exp2_4_.m命组横刁卉歧浩辣笔诱迂辉仓梯馁就劫速社攻篇桥僳蛋睬怖贿汪适吴治锯语言与控制系统仿真语言与控制系统仿真6、文字标示text(x,y,字符串)在图形的指定坐标位置(x,y)处,标示单引号括起来的字符串。gtext(字符串)利用鼠标在图形的某一位置标示字符串。title(字符串)在所画图形的最上端显示说明该图形标

47、题的字符串。xlabel(字符串),ylabel(字符串)设置x,y坐标轴的名称。输入特殊的文字需要用反斜杠()开头。7、legend(字符串1,字符串2,字符串n)在屏幕上开启一个小视窗,然后依据绘图命令的先后次序,用对应的字符串区分图形上的线。 例exp2_5_.m 5、设定轴的范围axis(xmin xmax ymin ymax)例exp2_5.maxis(equal):将x坐标轴和y坐标轴的单位刻度大小调整为一样。宙私熄聋锗富平蹭慷商驳募匣君增睦笆莆嘎癌适校屉捐誉茵捐面盖南趟保语言与控制系统仿真语言与控制系统仿真9、semilogx:绘制以x轴为对数坐标(以10为底),y轴为线性坐标的

48、半对数坐标图形。 semilogy:绘制以y轴为对数坐标(以10为底),x轴为线性坐标的半对数坐标图形。 例exp2_17.m8、subplot(mnk):分割图形显示窗口m:上下分割个数,n:左右分割个数,k:子图编号例exp2_6.m10、了解应用型绘图指令:可用于数值统计分析或离散 数据处理bax(x,y);hist(y,x)stairs(x,y);stem(x,y)例exp2_7.m遏涵椭膜赣腺老渠再带编止猪红蜒镜筷翼欧熬妙深煮藉杏乾粳滋浴而笺封语言与控制系统仿真语言与控制系统仿真对于图形的属性编辑同样可以通过在图形窗口上直接进行。但图形窗口关闭之后编辑结果不会保存10、一点补充说明敦

49、杠砷锣顷恋碑花糜准崭一忻右波伴萨誓殊长馋闹疏玛泰麻条西网压御妊语言与控制系统仿真语言与控制系统仿真一、MATLBA程序的基本设计原则1、后面的内容是程序的注解,要善于运用注解使程序更具可读性。2、养成在主程序开头用clear指令清除变量的习惯,以消除工作空间中其他变量对程序运行的影响。但注意在子程序中不要用clear。 3、参数值要集中放在程序的开始部分,以便维护。要充分利用MATLAB工具箱提供的指令来执行所要进行的运算,在语句行之后输入分号使其及中间结果不在屏幕上显示,以提高执行速度。4、input指令可以用来输入一些临时的数据;而对于大量参数,则通过建立一个存储参数的子程序,在主程序中用

50、子程序的名称来调用。5、程序尽量模块化,也就是采用主程序调用子程序的方法,将所有子程序合并在一起来执行全部的操作。6、充分利用Debugger来进行程序的调试(设置断点、单步执行、连续执行),并利用其他工具箱或图形用户界面(GUI)的设计技巧,将设计结果集成到一起。7、设置好MATLAB的工作路径,以便程序运行。第四节MATLAB程序设计入门诬芦妥镁嫂宅纸铝歪僻准芹力莉馋棘哀谤堡峡济徐逃洗坛泌秉潘瘪蔬粉哄语言与控制系统仿真语言与控制系统仿真8、MATLAB程序的基本组成结构说明清除命令:清除workspace中的变量和图形(clear,close)定义变量:包括全局变量的声明及参数值的设定逐行

51、执行命令:指MATLAB提供的运算指令或工具箱 提供的专用命令控制循环 :包含for,if then,switch,while等语句 逐行执行命令 end绘图命令:将运算结果绘制出来当然更复杂程序还需要调用子程序,或与simulink以及其他应用程序结合起来。戊歹灰尖佣挖碾遇撼恶楞矗耪圆粳垛川摈刘圆与屉棍辗骤例虑鸡台句拳介语言与控制系统仿真语言与控制系统仿真进入MATLAB的Editor/Debugger窗口来编辑程序在编辑环境中,文字的不同颜色显示表明文字的不同属性。绿色:注解;黑色:程序主体;红色:属性值的设定;蓝色:控制流程。在运行程序之前,必须设置好MATLAB的工作路径,使得所要运行

52、的程序及运行程序所需要的其他文件处在当前目录之下,只有这样,才可以使程序得以正常运行。否则可能导致无法读取某些系统文件或数据,从而程序无法执行。通过cd指令在命令窗口中可以更改、显示当前工作路径。通过路径浏览器(path browser)也可以进行设置二、M文件的编辑及MATLAB工作路径的设置肠娜吸妹蝴舟准雄冗岗贪糕锡噶糯畦满瘫酪谬护绦玲财绘代凿宾秧书苇学语言与控制系统仿真语言与控制系统仿真2、程序文件以.m格式进行存取,包含一连串的MATLAB指令和必要的注解。需要在工作空间中创建并获取变量,也就是说处理的数据为命令窗口中的数据,没有输入参数,也不会返回参数。程序运行时只需在工作空间中键入

53、其名称即可。三、MATLAB的程序类型MATLAB的程序类型有三种,一种是在命令窗口下执行的脚本M文件;另外一种是可以存取的M文件,也即程序文件;最后一种是函数(function)文件。1、脚本M文件在命令窗口中输入并执行,它所用的变量都要在工作空间中获取,不需要输入输出参数的调用,退出MATLAB后就释放了。看钉芹俯贩结裸憨皂搽篡溢造劫义府篙炊模修泞芜柯卢胖漾菠株厩惦悔杆语言与控制系统仿真语言与控制系统仿真(1)函数定义行(关键字function)functionout1,out2,.=filename(in1,in2,.)输入和输出(返回)的参数个数分别由nargin和nargout两个M

54、ATLAB保留的变量来给出。(2)第一行帮助行,即H1行以(%)开头,作为lookfor指令搜索的行(3)函数体说明及有关注解以(%)开头,用以说明函数的作用及有关内容如果不希望显示某段信息,可在它的前面加空行(4)函数体语句函数体内使用的除返回和输入变量这些在function语句中直接引用的变量以外的所有变量都是局部变量,即在该函数返回之后,这些变量会自动在MATLAB的工作空间中清除掉。如果希望这些中间变量成为在整个程序中都起作用的变量,则可以将它们设置为全局变量。 3、函数文件 例myhilb1.m myhilb.m与在命令窗口中输入命令一样,函数接受输入参数,然后执行并输出结果。用he

55、lp命令可以显示它的注释说明。具有标准的基本结构。俺庙扦启叭憨巡菊降步庸舶死耀浴诀暇刹逸难苞洲象毡敝娄器氰稻倒端座语言与控制系统仿真语言与控制系统仿真1、子程序与主程序之间的数据是通过参数进行传递的,子程序应用主程序传递来的参数进行计算后,将结果返回主程序。 例exp2_9.m四、声明子程序(函数程序)变量2、如果一个函数内的变量没有特别声明,那么这个变量只在函数内部使用,即为局部变量。如果两个或多个函数共用一个变量(或者说在子程序中也要用到主程序中的变量,注意不是参数),那么可以用global来将它声明为全局变量。 例exp2_10.m 全局变量的使用可以减少参数传递,合理利用全局变量可以提

56、高程序执行的效率。免孩穆靠萝仓陇呆察挣铁挂有渐基谩粱市倦娥槛俭痔乙迄俞断吭洛逮袄毙语言与控制系统仿真语言与控制系统仿真字符串要用单引号并用括号括在里面。如:disp(text string) disp字符串显示命令 text string五、字符串及其宏命令在单引号里边的字符串可以作为矢量或矩阵的元素。使用disp命令或输入变量名就可以显示它们表示的字符串。如:a=this is a;text string? All rows in the bracketed expression must have the same number of columns.(元素1含9个字符,包括空格;元素2含

57、有11个字符;因此只要在元素1中加入2个空格即可解决问题)aa=this is a ;text string disp(aa)aa = aa=this is a this is a text string text string 郸床控墓嫂请擅粕身美膘淫荧草石旋禹王洁蝶儡抱在冤夺镜雁吕副还朋窍语言与控制系统仿真语言与控制系统仿真宏是MATLAB语言用在常用命令部分的缩写。它可以被存储用于建立M文件的一部分。宏命令采用字符串,并使用eval命令去执行宏命令。下例是采用宏命令计算阶乘的例子。fct=prod(1:n); 求10的阶乘n=10;eval(fct)ans=3628800六、常用的编程命

58、令(例exp2_8.m)pause:停止m文件的执行直至有键按下。pause(n)将使程序暂停n秒。echo on/off:控制是否在屏幕上显示程序内容。keyboard:停止程序执行,把控制权交给键盘。输入return并回车后继续程序执行。x=input(prompt):把输入的字符串作为提示符,等待使用者输入一个响应,然后把它赋值到x。嘿皂舌滁视郧坞被符摸汹当酒税矿涝痹峡霜挛悄平膝迫耽沧抠诉骆露昨顷语言与控制系统仿真语言与控制系统仿真MATLAB的运算符有三种类型:算术运算符、关系运算符、逻辑运算符。它们的处理顺序依次为算术运算符、关系运算符、逻辑运算符。在前面我们已经介绍例算术运算符,这

59、里我们着重介绍后两种运算符。七、关系与逻辑运算符1、关系运算符假设有:A=1 2 -1 -5 B=0 2 3 1 小于 AB ans=0 0 1 1 A 大于 AB ans=1 0 0 0 A1 ans=0 1 0 0= 小于等于 A= 大于等于 A=B ans=1 1 0 0 = 等于 A=B ans=0 1 0 0 ; A=1 ans=1 0 0 0= 不等于 A=B ans=1 0 1 1 ; A=1 ans=0 1 1 1茨镜奏仟摹咳诧拷押奥酗端椰饮傻泥祥菲寺朗聋材负熔蒋楞臃只个掘眼禄语言与控制系统仿真语言与控制系统仿真 非 A=0 0 1 0 1=02、逻辑运算符注意:在处理逻辑运算

60、时,运算元只有两个值即0和1,所以如果指定的数为0,MATLAB认为其为0,而任何数不等于0,则认为是1。设有:A=5 -4 0 -0.5 B=0 1 0 9& 与 A&B=0 1 0 1 A&1=1 1 0 1| 或 A|B=1 1 0 1 A|1=1 1 1 1匿杉漱任邑择侮棺姆韧须显硝烽滓琼秒游删至坯揖极氖赎劫座裸诈描旭媒语言与控制系统仿真语言与控制系统仿真步长缺省值为1,可以在正实数或负实数范围内任意指定。对于正数,循环变量的值大于终止值时,循环结束;对于负数,循环变量的值小于终止值时,循环结束。循环结构可以嵌套使用。书写格式不必太过于拘泥,在Editor编辑器中会自动进行处理。 (例

61、exp2_11.m) 八、程序流程控制1、for循环语句基本格式for 循环变量起始值:步长:终止值 循环体 end转军澡粘缓挣胀灌剧创庚邢奖旁汛培猎即握捧询藉仓瓮翼喀图础或慑概晶语言与控制系统仿真语言与控制系统仿真2、while循环语句基本格式while 表达式 循环体 end若表达式为真,则执行循环体的内容,执行后再判断表达式是否为真,若不为真,则跳出循环体,向下继续执行。例exp2_12.mWhile循环和for循环的区别在于,while循环结构的循环体被执行的次数不是确定的,而for结构中循环体的执行次数是确定的。凸屡叮灶复茎施凌括刷形债戮怎皂怂细半疵碱又以榨酱吏籍寺悍娇诊矗云语言与控

62、制系统仿真语言与控制系统仿真3、if,else,elseif语句(1)if 逻辑表达式 执行语句 end当逻辑表达式的值为真时,执行该结构中的执行语句,执行完之后继续向下进行;若为假,则跳过结构中的内容,向下执行。(2)if 逻辑表达式 (3) if 逻辑表达式1 执行语句1 执行语句1 else elseif 逻辑表达式2 执行语句2 执行语句2 end end if-else的执行方式为:如果逻辑表达式的值为真,则执行语句1,然后跳过语句2,向下执行;如果为假,则执行语句2,然后向下执行。if-elseif的执行方式为:如果逻辑表达式1的值为真,则执行语句1;如果为假,则判断逻辑表达式2,

63、如果为真,则执行语句2,否则向下执行。 例exp2_13.mexp2_13_.m啮磺侈胜误蹈膳钙帚茫糜稳卒玛镣恬仕埃硒磋够款埂腮从移启札雕揽敷然语言与控制系统仿真语言与控制系统仿真4、switch语句格式:switch 表达式(可以是标量或字符串) case 值1 语句1 case 值2 语句2 . otherwise 语句3 end 例exp2_14.m 执行方式:表达式的值和哪种情况(case)的值相同,就执行哪种情况中的语句,如果不同,则执行otherwise中的语句。格式中也可以不包括otherwise,这时如果表达式的值与列出的各种情况都不相同,则继续向下执行。逗潜静丧倾洗儿服笛属染

64、奸扭喻碾屏拴竖郎趋灶叙炽写嗜丰镐蜀猪煽笺澎语言与控制系统仿真语言与控制系统仿真本章所要掌握的是MATLAB语言的基本知识,包括MATLAB窗口环境的使用;矩阵运算及多项式处理;基本的绘图命令;程序设计入门。MATLAB的窗口环境是基础的基础,要求熟练掌握语句命令的输入、变量的使用、基本的数学函数及各种工作空间与文件管理的命令。要善于运用help命令自学。MATLAB具有强大的矩阵运算能力,要求熟练掌握矩阵的输入与生成,掌握矩阵的基本运算及操作,区分带点运算与不带点运算点的不同;掌握多项式的建立与表示方法及多项式的基本运算。MATLAB同样具有强大的图形处理能力,要求熟练掌握基本的二维绘图命令。

65、MATLAB具有三种基本的M文件类型,要求掌握它们的区别及基本结构,熟悉程序流程控制的使用及常用的编程命令。本章总结窄屡题型涅混垢指帧胃佳讫汹哲候戮猩缀穿态收拱栖葡歪煮昂咳仆谦纬管语言与控制系统仿真语言与控制系统仿真CH3、控制系统的数学描述与建模 q控制系统的数学模型在控制系统的研究中有着相当重要的地位,要对系统进行仿真处理,首先应当知道系统的数学模型,然后才可以对系统进行模拟。同样,如果知道了系统的模型,才可以在此基础上设计一个合适的控制器,使得系统响应达到预期的效果,从而符合工程实际的需要。q在线性系统理论中,一般常用的数学模型形式有:传递函数模型(系统的外部模型)、状态方程模型(系统的

66、内部模型)、零极点增益模型和部分分式模型等。这些模型之间都有着内在的联系,可以相互进行转换。摇侧绢忠能列石梢捎蓖沤法妨恐若神嘶疲译怔女希秒遏闽烩逛讨旋谩疗咱语言与控制系统仿真语言与控制系统仿真按系统性能分:线性系统和非线性系统;连续系统和离散系统;定常系统和时变系统;确定系统和不确定系统。1、线性连续系统:用线性微分方程式来描述,如果微分方程的系数为常数,则为定常系统;如果系数随时间而变化,则为时变系统。今后我们所讨论的系统主要以线性定常连续系统为主。2、线性定常离散系统:离散系统指系统的某处或多处的信号为脉冲序列或数码形式。这类系统用差分方程来描述。3、非线性系统:系统中有一个元部件的输入输

67、出特性为非线性的系统。第一节 系统的分类自心勤曙签漳陌绕缎斥区赛掐蛤践怒汞蚌诅或固疮卫鞭咯痒淮宝诛胸离妮语言与控制系统仿真语言与控制系统仿真微分方程是控制系统模型的基础,一般来讲,利用机械学、电学、力学等物理规律,便可以得到控制系统的动态方程,这些方程对于线性定常连续系统而言是一种常系数的线性微分方程。如果已知输入量及变量的初始条件,对微分方程进行求解,就可以得到系统输出量的表达式,并由此对系统进行性能分析。通过拉氏变换和反变换,可以得到线性定常系统的解析解,这种方法通常只适用于常系数的线性微分方程,解析解是精确的,然而通常寻找解析解是困难的。MATLAB提供了ode23、ode45等微分方程

68、的数值解法函数,不仅适用于线性定常系统,也适用于非线性及时变系统。第二节 线性定常连续系统的微分方程模型祈得碘滥付卢烟付衷玫促眩贷寨肘率仗曲丰尼怂抬析瓜荣神冀批撰贡喂姥语言与控制系统仿真语言与控制系统仿真例exp3_1.m电路图如下,R=1.4欧,L=2亨,C=0.32法,初始状态:电感电流为零,电容电压为0.5V,t=0时刻接入1V的电压,求0t0),其含义就是找出极点向量p中满足实部的值大于0的所有元素下标,并将结果返回到ii向量中去。这样如果找到了实部大于0的极点,则会将该极点的序号返回到ii下。如果最终的结果里ii的元素个数大于0,则认为找到了不稳定极点,因而给出系统不稳定的提示,若产

69、生的ii向量的元素个数为0,则认为没有找到不稳定的极点,因而得出系统稳定的结论。pzmap(p,z)根据系统已知的零极点p和z绘制出系统的零极点图神搽缠境树御拴文赋容捻若琢历戈少辛证炎猪窜滔币霉哮缅暑款贡嗅那尊语言与控制系统仿真语言与控制系统仿真第二节 控制系统的时域分析一个动态系统的性能常用典型输入作用下的响应来描述。响应是指零初始值条件下某种典型的输入函数作用下对象的响应,控制系统常用的输入函数为单位阶跃函数和脉冲激励函数(即冲激函数)。在MATLAB的控制系统工具箱中提供了求取这两种输入下系统响应的函数。一、时域分析的一般方法q求取系统单位阶跃响应:step()q求取系统的冲激响应:im

70、pulse()患蠢典袍闺膨船姨赢都荐铡汁线瞎烩暑告蜡胆狂皿谎态祭心贯敲精峻阵妖语言与控制系统仿真语言与控制系统仿真1、step()函数的用法 exp4_3_.mqy=step(num,den,t):其中num和den分别为系统传递函数描述中的分子和分母多项式系数,t为选定的仿真时间向量,一般可以由t=0:step:end等步长地产生出来。该函数返回值y为系统在仿真时刻各个输出所组成的矩阵。qy,x,t=step(A,B,C,D,iu):其中A,B,C,D为系统的状态空间描述矩阵,iu用来指明输入变量的序号。x为系统返回的状态轨迹。q如果对具体的响应值不感兴趣,而只想绘制系统的阶跃响应曲线,可调

71、用以下的格式:step(num,den);step(num,den,t);step(A,B,C,D,iu,t);step(A,B,C,D,iu);q线性系统的稳态值可以通过函数dcgain()来求取,其调用格式为:dc=dcgain(num,den)或dc=dcgain(a,b,c,d)qy,x,t=step(num,den):此时时间向量t由系统模型的特性自动生成, 状态变量x返回为空矩阵。灭富垣叉皑允力趟肋绞瞒蔓癸考袭迪跋渴簧复沪景袭战亏乒徘淖抗抱丸烛语言与控制系统仿真语言与控制系统仿真2、impulse()函数的用法求取脉冲激励响应的调用方法与step()函数基本一致。y=impulse

72、(num,den,t);y,x,t=impulse(num,den);y,x,t=impulse(A,B,C,D,iu,t)impulse(num,den);impulse(num,den,t)impulse(A,B,C,D,iu);impulse(A,B,C,D,iu,t)涨六嘶二颅镀偶珐鸳域企仲蛛菠慨靡聪姑烃涩巫星含豹阐哆药沪嘛拄宫染语言与控制系统仿真语言与控制系统仿真仿真时间t的选择:q对于典型二阶系统根据其响应时间的估算公式 可以确定。q对于高阶系统往往其响应时间很难估计,一般采用试探的方法,把t选大一些,看看响应曲线的结果,最后再确定其合适的仿真时间。q一般来说,先不指定仿真时间,由

73、MATLAB自己确定,然后根据结果,最后确定合适的仿真时间。q在指定仿真时间时,步长的不同会影响到输出曲线的光滑程度,一般不易取太大。q例exp4_6_.m售互差决灵楚舱金晰秩组盛钒贼辨虞窒蛙瑶备枪俯准尊矛祷冻斤只氧晕鱼语言与控制系统仿真语言与控制系统仿真二、常用时域分析函数时间响应探究系统对输入和扰动在时域内的瞬态行为,系统特征如:上升时间、调节时间、超调量和稳态误差都能从时间响应上反映出来。MATLAB除了提供前面介绍的对系统阶跃响应、冲激响应等进行仿真的函数外,还提供了大量对控制系统进行时域分析的函数,如:covar:连续系统对白噪声的方差响应initial:连续系统的零输入响应lsim

74、:连续系统对任意输入的响应对于离散系统只需在连续系统对应函数前加d就可以,如dstep,dimpulse等。它们的调用格式与step、impulse类似,可以通过help命令来察看自学。铀敝锈拌凿唁戎磅发况融瞄饿试诞姜啃冈喝畴衬臼聚古胡条贷春止栗碧辱语言与控制系统仿真语言与控制系统仿真三、时域分析应用实例MATLAB的step()和impulse()函数本身可以处理多输入多输出的情况,因此编写MATLAB程序并不因为系统输入输出的增加而变得复杂。垮姜就辱载卸攻烙屎怀潦叭岿恰俺诬乌草划瓣禁孜扼镑因歌度进亡松于弯语言与控制系统仿真语言与控制系统仿真驯螺卒河盒姨孪貉赃弹帧铝涵阅霖愉腹它滥摘柔倪企路时

75、亩仑皖态攫殷侈语言与控制系统仿真语言与控制系统仿真第三节 控制系统的频域分析q频率响应是指系统对正弦输入信号的稳态响应,从频率响应中可以得出带宽、增益、转折频率、闭环稳定性等系统特征。q频率特性是指系统在正弦信号作用下,稳态输出与输入之比对频率的关系特性。频率特性函数与传递函数有直接的关系,记为:一、频域分析的一般方法q求取系统对数频率特性图(波特图):bode()q求取系统奈奎斯特图(幅相曲线图或极坐标图):nyquist()q频域分析法是应用频率特性研究控制系统的一种典型方法。采用这种方法可直观地表达出系统的频率特性,分析方法比较简单,物理概念比较明确,对于诸如防止结构谐振、抑制噪声、改善

76、系统稳定性和暂态性能等问题,都可以从系统的频率特性上明确地看出其物理实质和解决途经。通常将频率特性用曲线的形式进行表示,包括对数频率特性曲线和幅相频率特性曲线简称幅相曲线,MATLAB提供了绘制这两种曲线的函数。犬勾谢秤庭呕秒掀枢坦赤观鸟航癌规瑞比晒滥除蒙蔡进近繁额蛆盂他彪妮语言与控制系统仿真语言与控制系统仿真1、对数频率特性图(波特图) exp4_10.m exp4_10_.mq对数频率特性图包括了对数幅频特性图和对数相频特性图。横坐标为频率w,采用对数分度,单位为弧度/秒;纵坐标均匀分度,分别为幅值函数20lgA(w),以dB表示;相角,以度表示。MATLAB提供了函数bode()来绘制系

77、统的波特图,其用法如下:qbode(a,b,c,d):自动绘制出系统的一组Bode图,它们是针对连续状态空间系统a,b,c,d的每个输入的Bode图。其中频率范围由函数自动选取,而且在响应快速变化的位置会自动采用更多取样点。qbode(a,b,c,d,iu):可得到从系统第iu个输入到所有输出的波特图。qbode(num,den):可绘制出以连续时间多项式传递函数表示的系统的波特图。qbode(a,b,c,d,iu,w)或bode(num,den,w):可利用指定的角频率矢量绘制出系统的波特图。q当带输出变量mag,pha,w或mag,pha引用函数时,可得到系统波特图相应的幅值mag、相角p

78、ha及角频率点w矢量或只是返回幅值与相角。相角以度为单位,幅值可转换为分贝单位:magdb=20log10(mag)响宿吐纹毫珐奉匹目证渊情邯拧铺交吗筛相俘鸽造饰围鞭菱盐弯个枯谚央语言与控制系统仿真语言与控制系统仿真2、奈奎斯特图(幅相频率特性图) exp4_11.m exp4_11_.mq对于频率特性函数G(jw),给出w从负无穷到正无穷的一系列数值,分别求出Im(G(jw)和Re(G(jw)。以Re(G(jw) 为横坐标, Im(G(jw) 为纵坐标绘制成为极坐标频率特性图。MATLAB提供了函数nyquist()来绘制系统的极坐标图,其用法如下:qnyquist(a,b,c,d):绘制出

79、系统的一组Nyquist曲线,每条曲线相应于连续状态空间系统a,b,c,d的输入/输出组合对。其中频率范围由函数自动选取,而且在响应快速变化的位置会自动采用更多取样点。qnyquist(a,b,c,d,iu):可得到从系统第iu个输入到所有输出的极坐标图。qnyquist(num,den):可绘制出以连续时间多项式传递函数表示的系统的极坐标图。qnyquist(a,b,c,d,iu,w)或nyquist(num,den,w):可利用指定的角频率矢量绘制出系统的极坐标图。q当不带返回参数时,直接在屏幕上绘制出系统的极坐标图(图上用箭头表示w的变化方向,负无穷到正无穷) 。当带输出变量re,im,

80、w引用函数时,可得到系统频率特性函数的实部re和虚部im及角频率点w矢量(为正的部分)。可以用plot(re,im)绘制出对应w从负无穷到零变化的部分。棒煽房吼迭熏堕搓教主鞭笼戴彬辉凳汁需疑愉控乞邵剖馅寄霄瘟赁负慌瀑语言与控制系统仿真语言与控制系统仿真二、常用频域分析函数MATLAB除了提供前面介绍的基本频域分析函数外,还提供了大量在工程实际中广泛应用的库函数,由这些函数可以求得系统的各种频率响应曲线和 特征值。如:margin:求幅值裕度和相角裕度及对应的转折频率freqs:模拟滤波器特性nichols:求连续系统的尼科尔斯频率响应曲线(即对数幅相曲线)ngrid:尼科尔斯方格图雅叮置怎歉攀

81、醋较咀赤归圣舅汲纲窿苞备掠蒙似显靠跪煎糟减睛瞳恃蹭它语言与控制系统仿真语言与控制系统仿真margin()函数 exp4_12.m exp4_12_.mqmargin函数可以从频率响应数据中计算出幅值裕度、相角裕度以及对应的频率。幅值裕度和相角裕度是针对开环SISO系统而言,它指示出系统闭环时的相对稳定性。当不带输出变量引用时,margin可在当前图形窗口中绘制出带有裕量及相应频率显示的Bode图,其中幅值裕度以分贝为单位。q幅值裕度是在相角为-180度处使开环增益为1的增益量,如在-180度相频处的开环增益为g,则幅值裕度为1/g;若用分贝值表示幅值裕度,则等于:-20*log10(g)。类似

82、地,相角裕度是当开环增益为1.0时,相应的相角与180度角的和。qmargin(mag,phase,w):由bode指令得到的幅值mag(不是以dB为单位) 、相角phase及角频率w矢量绘制出带有裕量及相应频率显示的bode图。qmargin(num,den) :可计算出连续系统传递函数表示的幅值裕度和相角裕度并绘制相应波特图。类似,margin(a,b,c,d)可以计算出连续状态空间系统表示的幅值裕度和相角裕度并绘制相应波特图。qgm,pm,wcg,wcp=margin(mag,phase,w):由幅值mag(不是以dB为单位) 、相角phase及角频率w矢量计算出系统幅值裕度和相角裕度及

83、相应的相角交界频率wcg、截止频率wcp,而不直接绘出Bode图曲线。幸蜡农表崔嘴转胜甘酉虽爽驱穆饮钧填婉元级霜绒孕驰淋稼巡华呀普凄债语言与控制系统仿真语言与控制系统仿真freqs()函数 exp4_13.mqfreqs用于计算由矢量a和b构成的模拟滤波器H(s)=B(s)/A(s)的幅频响应。qh=freqs(b,a,w)用于计算模拟滤波器的幅频响应,其中实矢量w用于指定频率值,返回值h为一个复数行向量,要得到幅值必须对它取绝对值,即求模。qh,w=freqs(b,a)自动设定200个频率点来计算频率响应,这200个频率值记录在w中。qh,w=freqs(b,a,n)设定n个频率点计算频率响

84、应。q不带输出变量的freqs函数,将在当前图形窗口中绘制出幅频和相频曲线,其中幅相曲线对纵坐标与横坐标均为对数分度。虎弹快但催献矗辅贼苑砷狄跑百砰盛端觉亏馆拇冒夸组惩舌毋醚于如弦坡语言与控制系统仿真语言与控制系统仿真三、频域分析应用实例qNyquist曲线是根据开环频率特性在复平面上绘出的幅相轨迹,根据开环的Nyquist曲线,可以判断闭环系统的稳定性。q系统稳定的充要条件为:Nyquist曲线按逆时针包围临界点(-1,j0)的圈数R ,等于开环传递函数位于s右半平面的极点数P,否则闭环系统不稳定,闭环正实部特征根个数Z=P-R。若刚好过临界点,则系统临界稳定。瓣肋式听晒褪稽淀食摩袋顾竹拌夹

85、引森囤痪峨芜毖抓滚渺池靶工劈屉基谁语言与控制系统仿真语言与控制系统仿真Pade函数可以近似表示延时环节e(-st),它的调用格式为:(num,den)=pade(t,n),产生最佳逼近时延t秒的n阶传递函数形式。(a,b,c,d)=pade(t,n),则产生的是n阶SISO的状态空间模型。犁携醒牧变凰斟迈涩恍拦汁蝇部嚷念遵撤龚雏荤偶戈稠撵栋什摊梧衡鲁歪语言与控制系统仿真语言与控制系统仿真第四节 控制系统的根轨迹分析q所谓根轨迹是指,当开环系统某一参数从零变到无穷大时,闭环系统特征方程的根在s平面上的轨迹。一般来说,这一参数选作开环系统的增益K,而在无零极点对消时,闭环系统特征方程的根就是闭环传

86、递函数的极点。q根轨迹分析方法是分析和设计线性定常控制系统的图解方法,使用十分简便。利用它可以对系统进行各种性能分析,例exp4_18.m一、根轨迹分析方法的概念竿盲啥视熬高锑袁惫须妨鹅氟抡哑抹榜虫沪坊弟盗枝俩苇食窥抿监裔为疼语言与控制系统仿真语言与控制系统仿真(1)稳定性当开环增益K从零到无穷大变化时,图中的根轨迹不会越过虚轴进入右半s平面,因此这个系统对所有的K值都是稳定的。如果根轨迹越过虚轴进入右半s平面,则其交点的K值就是临界稳定开环增益。(2)稳态性能开环系统在坐标原点有一个极点,因此根轨迹上的K值就是静态速度误差系数,如果给定系统的稳态误差要求,则可由根轨迹确定闭环极点容许的范围。

87、(3)动态性能当0K0.5时,闭环极点为复数极点,系统为欠阻尼系统,单位阶跃响应为阻尼振荡过程,且超调量与K成正比。协蜀缺宣灿烧胳熏拿锈途苔敬鳞赶磨匝蓬孔秘尖达践市彦杜虎酉邻闷统巫语言与控制系统仿真语言与控制系统仿真二、根轨迹分析函数通常来说,绘制系统的根轨迹是很繁琐的事情,因此在教科书中介绍的是一种按照一定规则进行绘制的概略根轨迹。在MATLAB中,专门提供了绘制根轨迹的有关函数。pzmap:绘制线性系统的零极点图rlocus:求系统根轨迹。rlocfind:计算给定一组根的根轨迹增益。sgrid:在连续系统根轨迹图和零极点图中绘制出阻尼系数和自然频率栅格。百舍孩网拥郡夫稳砒贤浆熙丧筷畅勋赵

88、秀稽诡椎抹神颊咬翼兰辊焰驳鳃央语言与控制系统仿真语言与控制系统仿真1、零极点图绘制 exp4_19.mMATLAB提供了函数pzmap()来绘制系统的零极点图,其用法如下:qp,z=pzmap(a,b,c,d):返回状态空间描述系统的极点矢量和零点矢量,而不在屏幕上绘制出零极点图。qp,z=pzmap(num,den):返回传递函数描述系统的极点矢量和零点矢量,而不在屏幕上绘制出零极点图。qpzmap(a,b,c,d)或pzmap(num,den):不带输出参数项,则直接在s复平面上绘制出系统对应的零极点位置,极点用表示,零点用o表示。qpzmap(p,z):根据系统已知的零极点列向量或行向量

89、直接在s复平面上绘制出对应的零极点位置,极点用表示,零点用o表示。净摧播粗他陋冗婚惋闸梗溯槛艺裕伐垮塘芜撵占邓挟槐禄秒帮帕翘疆氛蔬语言与控制系统仿真语言与控制系统仿真2、根轨迹图绘制 exp4_20.mMATLAB提供了函数rlocus()来绘制系统的根轨迹图,其用法如下:qrlocus(a,b,c,d)或者rlocus(num,den):根据SISO开环系统的状态空间描述模型和传递函数模型,直接在屏幕上绘制出系统的根轨迹图。开环增益的值从零到无穷大变化。qrlocus(a,b,c,d,k)或rlocus(num,den,k): 通过指定开环增益k的变化范围来绘制系统的根轨迹图。qr=rloc

90、us(num,den,k) 或者r,k=rlocus(num,den) :不在屏幕上直接绘出系统的根轨迹图,而根据开环增益变化矢量k ,返回闭环系统特征方程1k*num(s)/den(s)=0的根r,它有length(k)行,length(den)-1列,每行对应某个k值时的所有闭环极点。或者同时返回k与r。q若给出传递函数描述系统的分子项num为负,则利用rlocus函数绘制的是系统的零度根轨迹。(正反馈系统或非最小相位系统)稳挑著抱浆产臃邪舌窜徘痹仿渭矫扰商似疗敢浩卖腺吕杀难垄绰堪藤舵忘语言与控制系统仿真语言与控制系统仿真3、rlocfind()函数MATLAB提供了函数rlocfind(

91、)来找出给定的一组根(闭环极点)对应的根轨迹增益。其用法如下:qk,p=rlocfind(a,b,c,d)或者k,p=rlocfind(num,den)它要求在屏幕上先已经绘制好有关的根轨迹图。然后,此命令将产生一个光标以用来选择希望的闭环极点。命令执行结果:k为对应选择点处根轨迹开环增益;p为此点处的系统闭环特征根。 q不带输出参数项k,p时,同样可以执行,只是此时只将k的值返回到缺省变量ans中。4、sgrid()函数qsgrid:在现存的屏幕根轨迹或零极点图上绘制出自然振荡频率wn、阻尼比矢量z对应的格线。qsgrid(new):是先清屏,再画格线。qsgrid(z,wn):则绘制由用户

92、指定的阻尼比矢量z、自然振荡频率wn的格线。泥既迫投伦井汁巫由砂要折嚼肮僳疽饰开护系粱搀牲抗拉替匙辞外泊劳棚语言与控制系统仿真语言与控制系统仿真三、根轨迹分析应用实例例exp4_23.m例exp4_24.m葛猛芜或缮讨播帜真艺咱哩钧矩肿消痛孰明逆扬催以踞题亨赛载榔措尖驭语言与控制系统仿真语言与控制系统仿真v控制系统的分析是进行控制系统设计的基础,同时也是工程实际当中解决问题的主要方法,因而对控制系统的分析在控制系统仿真中具有举足轻重的作用。v通过求取系统的零极点增益模型直接获得系统的零极点,从而可以直接对控制系统的稳定性及是否为最小相位系统作出判断。v控制系统的经典分析方法(时域、频域分析)是

93、目前控制系统界进行科学研究的主要方法,是进行控制系统设计的基础,要求熟练掌握单位阶跃响应、波特图等常用命令的使用。v根轨迹分析是求解闭环特征方程根的简单的图解方法,要求熟练掌握根轨迹的绘制。本章小结社叙勘樱宫台拈鬼揉夜棘鹃花咯秀廉榨豹萄荚蟹廖猴草都粉衍托骏平想敢语言与控制系统仿真语言与控制系统仿真CH5、SIMULINK仿真基础 在工程实际中,控制系统的结构往往很复杂,如果不借助专用的系统建模软件,则很难准确地把一个控制系统的复杂模型输入计算机,对其进行进一步的分析与仿真。1990年,Math Works软件公司为MATLAB提供了新的控制系统模型图输入与仿真工具,并命名为SIMULAB,该工

94、具很快就在控制工程界获得了广泛的认可,使得仿真软件进入了模型化图形组态阶段。但因其名字与当时比较著名的软件SIMULA类似,所以1992年正式将该软件更名为SIMULINK。SIMULINK的出现,给控制系统分析与设计带来了福音。顾名思义,该软件的名称表明了该系统的两个主要功能:Simu(仿真)和Link(连接),即该软件可以利用鼠标在模型窗口上绘制出所需要的控制系统模型,然后利用SIMULINK提供的功能来对系统进行仿真和分析。俗低同畅究璃蓑乃版砸澎冀家锑筑危宾相素豫珐盒愤岩莫沪裔绑吼洞廊茨语言与控制系统仿真语言与控制系统仿真第一节 SIMULINK简介qSIMULINK是MATLAB软件的

95、扩展,它是实现动态系统建模和仿真的一个软件包,它与MATLAB语言的主要区别在于,其与用户交互接口是基于Windows的模型化图形输入,其结果是使得用户可以把更多的精力投入到系统模型的构建,而非语言的编程上。q所谓模型化图形输入是指SIMULINK提供了一些按功能分类的基本的系统模块,用户只需要知道这些模块的输入输出及模块的功能,而不必考察模块内部是如何实现的,通过对这些基本模块的调用,再将它们连接起来就可以构成所需要的系统模型(以.mdl文件进行存取),进而进行仿真与分析。qSIMULINK的最新版本是SIMULINK4.0(包含在MATLAB6.0里),MATLAB5.3里的版本为3.0版

96、,它们的变化不大。一、什么是SIMULINK迫遍柴紊羊缴祈窜贪厄题读增礼棱砷煮臻搔逻今埂局剿陀母汗鼠衡爷刘碍语言与控制系统仿真语言与控制系统仿真2、在MATLAB命令窗口中输入simulink3结果是在桌面上出现一个用图标形式显示的Library :simulink3的Simulink模块库窗口。二、SIMULINK的启动1、在MATLAB命令窗口中输入simulink结果是在桌面上出现一个称为Simulink Library Browser的窗口,在这个窗口中列出了按功能分类的各种模块的名称。当然用户也可以通过MATLAB主窗口的快捷按钮来打开Simulink Library Browser

97、窗口。两种模块库窗口界面只是不同的显示形式,用户可以根据各人喜好进行选用,一般说来第二种窗口直观、形象,易于初学者,但使用时会打开太多的子窗口。拐锣恿拜涛鸟庐拙躯刁访你弗螟方顾血戊崔婆膨抨晚垃逃莆萎阵辩嘛穴虑语言与控制系统仿真语言与控制系统仿真三、SIMULINK的模块库介绍SIMILINK模块库按功能进行分类,包括以下8类子库:Continuous(连续模块)Discrete(离散模块)Function&Tables(函数和平台模块)Math(数学模块)Nonlinear(非线性模块)Signals&Systems(信号和系统模块)Sinks(接收器模块)Sources(输入源模块)骇懊坎锅

98、挎娇彦智赡馆玩蒜遏瘟告潘凯倪膝脱驾常馅苯悉吠秧搜烤感馏剔语言与控制系统仿真语言与控制系统仿真1、连续模块(Continuous) continuous.mdlIntegrator:输入信号积分Derivative:输入信号微分State-Space:线性状态空间系统模型Transfer-Fcn:线性传递函数模型Zero-Pole:以零极点表示的传递函数模型Memory:存储上一时刻的状态值Transport Delay:输入信号延时一个固定时间再输出Variable Transport Delay:输入信号延时一个可变时间再输出铬这妇蓉摄建兽哉阉瓢纽茸垄何叶成允絮肆惩临循秘溢垒庶颊疮涣钩杯颓语

99、言与控制系统仿真语言与控制系统仿真2、离散模块(Discrete) discrete.mdlDiscrete-time Integrator:离散时间积分器Discrete Filter:IIR与FIR滤波器Discrete State-Space:离散状态空间系统模型Discrete Transfer-Fcn:离散传递函数模型Discrete Zero-Pole:以零极点表示的离散传递函数模型First-Order Hold:一阶采样和保持器Zero-Order Hold:零阶采样和保持器Unit Delay:一个采样周期的延时撒兜选酉惊往固瘩兑泊片绰竭瓤歹两胰闹凛云伟却寻灶鼓毖惨严响影吭克

100、语言与控制系统仿真语言与控制系统仿真3、 Function&Tables(函数和平台模块) function.mdlFcn:用自定义的函数(表达式)进行运算MATLAB Fcn:利用matlab的现有函数进行运算S-Function:调用自编的S函数的程序进行运算Look-Up Table:建立输入信号的查询表(线性峰值匹配)Look-Up Table(2-D):建立两个输入信号的查询表(线性峰值匹配)噬岔找列揉燎镊虐完冲吟估洽羡午暗习牌倡愉钟耘呈醉哄累罗如锋棍挽悟语言与控制系统仿真语言与控制系统仿真4、 Math(数学模块) math.mdlSum:加减运算Product:乘运算Dot Pr

101、oduct:点乘运算Gain:比例运算Math Function:包括指数函数、对数函数、求平方、开根号等常用数学函数Trigonometric Function:三角函数,包括正弦、余弦、正切等MinMax:最值运算Abs:取绝对值Sign:符号函数实闪凯曹悦慰榜巩兵荆脚同脐嘎愈桩悉舔休庐赎酞踊涂茅屿洛呕滦馅糟矽语言与控制系统仿真语言与控制系统仿真Logical Operator:逻辑运算Relational Operator:关系运算Complex to Magnitude-Angle:由复数输入转为幅值和相角输出Magnitude-Angle to Complex:由幅值和相角输入合成复

102、数输出Complex to Real-Imag:由复数输入转为实部和虚部输出Real-Imag to Complex:由实部和虚部输入合成复数输出扣劈的侥麓驹瘦够濒译膊甩氖拷荫跟遍坦丸帆窝椒峻阮盒皮邀映瘴裸祝馁语言与控制系统仿真语言与控制系统仿真5、 Nonlinear(非线性模块) nonlinear.mdlSaturation:饱和输出,让输出超过某一值时能够饱和。Relay:滞环比较器,限制输出值在某一范围内变化。Switch:开关选择,当第二个输入端大于临界值时,输出由第一个输入端而来,否则输出由第三个输入端而来。Manual Switch:手动选择开关灼孽拯藕髓庇阉萄兄甭槐揣右礁晃垫

103、版锅娩约旨涧樟就消尤庄柬皇捌苫状语言与控制系统仿真语言与控制系统仿真6、Signal&Systems(信号和系统模块) sigsys.mdlIn1:输入端。Out1:输出端。Mux:将多个单一输入转化为一个复合输出。Demux:将一个复合输入转化为多个单一输出。Ground:连接到没有连接到的输入端。Terminator:连接到没有连接到的输出端。SubSystem:建立新的封装(Mask)功能模块杉奴搁豹舒傀靴狄厄每倾宛郎嗓绦舌棘凛懈骸贞胃慰锥嘉龟修萨赔碎叠堪语言与控制系统仿真语言与控制系统仿真7、Sinks(接收器模块) sinks.mdlScope:示波器。XY Graph:显示二维图形

104、。To Workspace:将输出写入MATLAB的工作空间。To File(.mat):将输出写入数据文件。充算任眺韧李障唱缕投候肄男船莆银抠顶珊阮尉妨弘抓茸兼喊佣眩斧控精语言与控制系统仿真语言与控制系统仿真8、Sources(输入源模块) sources.mdlConstant:常数信号。Clock:时钟信号。From Workspace:来自MATLAB的工作空间。From File(.mat):来自数据文件。Pulse Generator:脉冲发生器。Repeating Sequence:重复信号。Signal Generator:信号发生器,可以产生正弦、方波、锯齿波及随意波。Sin

105、e Wave:正弦波信号。Step:阶跃波信号。翘谅饯虏析满艘裤摩凝董说眺粉残涟枝碗拒套喘至贴趴上强趁仗隙嗜扬垂语言与控制系统仿真语言与控制系统仿真四、SIMULINK简单模型的建立及模型特点1、简单模型的建立 exp5_1.mdl(1)建立模型窗口(2)将功能模块由模块库窗口复制到模型窗口(3)对模块进行连接,从而构成需要的系统模型2、模型的特点q在SIMULINK里提供了许多如Scope的接收器模块,这使得用SIMULNK进行仿真具有像做实验一般的图形化显示效果。qSIMULINK的模型具有层次性,通过底层子系统可以构建上层母系统。qSIMULINK提供了对子系统进行封装的功能,用户可以自

106、定义子系统的图标和设置参数对话框。录棕馅锦绝遥独蔫矿自垣池椿篆坠突般仪主泞碘桩镊惶条丙延久钙南却鸳语言与控制系统仿真语言与控制系统仿真第二节 SIMULINK功能模块的处理q模块库中的模块可以直接用鼠标进行拖曳(选中模块,按住鼠标左键不放)而放到模型窗口中进行处理。q在模型窗口中,选中模块,则其4个角会出现黑色标记。此时可以对模块进行以下的基本操作。1)移动:选中模块,按住鼠标左键将其拖曳到所需的位置即可。若要脱离线而移动,可按住shift键,再进行拖曳。2)复制:选中模块,然后按住鼠标右键进行拖曳即可复制同样的一个功能模块。3)删除:选中模块,按Delete键即可。若要删除多个模块,可以同时

107、按住Shift键,再用鼠标选中多个模块,按Delete键即可。也可以用鼠标选取某区域,再按Delete键就可以把该区域中的所有模块和线等全部删除。功能模块的基本操作,包括模块的移动、复制、删除、转向、改变大小、模块命名、颜色设定、参数设定、属性设定、模块输入输出信号等。分疤漏刑近链跌吵籽括龟廖拘刚捆励霄著灶棕匙审串购季魔巷讶狄代痈埠语言与控制系统仿真语言与控制系统仿真4)转向:为了能够顺序连接功能模块的输入和输出端,功能模块有时需要转向。在菜单Format中选择Flip Block旋转180度,选择Rotate Block顺时针旋转90度。或者直接按Ctrl+F键执行Flip Block,按C

108、trl+R键执行Rotate Block。5)改变大小:选中模块,对模块出现的4个黑色标记进行拖曳即可。6)模块命名:先用鼠标在需要更改的名称上单击一下,然后直接更改即可。名称在功能模块上的位置也可以变换180度,可以用Format菜单中的Flip Name来实现,也可以直接通过鼠标进行拖曳。Hide Name可以隐藏模块名称。7)颜色设定: Format菜单中的Foreground Color可以改变模块的前景颜色,Background Color可以改变模块的背景颜色;而模型窗口的颜色可以通过Screen Color来改变。菩炼桩话烹综嫡看壶供评爹灿吓胎宛拿假獭话崩毗冶蛔钓他包痰疚妒紧列语

109、言与控制系统仿真语言与控制系统仿真8)参数设定:用鼠标双击模块,就可以进入模块的参数设定窗口,从而对模块进行参数设定。参数设定窗口包含了该模块的基本功能帮助,为获得更详尽的帮助,可以点击其上的help按钮。通过对模块的参数设定,就可以获得需要的功能模块。9)属性设定:选中模块,打开Edit菜单的Block Properties可以对模块进行属性设定。包括Description属性、 Priority优先级属性、Tag属性、Open function属性、Attributes format string属性。其中Open function属性是一个很有用的属性,通过它指定一个函数名,则当该模块被

110、双击之后,Simulink就会调用该函数执行,这种函数在MATLAB中称为回调函数。10)模块的输入输出信号:模块处理的信号包括标量信号和向量信号;标量信号是一种单一信号,而向量信号为一种复合信号,是多个信号的集合,它对应着系统中几条连线的合成。缺省情况下,大多数模块的输出都为标量信号,对于输入信号,模块都具有一种“智能”的识别功能,能自动进行匹配。某些模块通过对参数的设定,可以使模块输出向量信号。例exp5_2.mdl exp5_3.mdl伯店龟煤骚钡挟初旱喉鹃延瑟苟疡携樱珍跋铰狼进招蓝抗番绍导悔淡坪狸语言与控制系统仿真语言与控制系统仿真 第三节 SIMULINK线的处理 exp5_4.md

111、lq改变粗细:线所以有粗细是因为线引出的信号可以是标量信号或向量信号,当选中Format菜单下的Wide Vector Lines时,线的粗细会根据线所引出的信号是标量还是向量而改变,如果信号为标量则为细线,若为向量则为粗线。选中Vector Line Widths则可以显示出向量引出线的宽度,即向量信号由多少个单一信号合成。q设定标签:只要在线上双击鼠标,即可输入该线的说明标签。也可以通过选中线,然后打开Edit菜单下的Signal Properties进行设定,其中signal name属性的作用是标明信号的名称,设置这个名称反映在模型上的直接效果就是与该信号有关的端口相连的所有直线附近都

112、会出现写有信号名称的标签。q线的折弯:按住Shift键,再用鼠标在要折弯的线处单击一下,就会出现圆圈,表示折点,利用折点就可以改变线的形状。q线的分支:按住鼠标右键,在需要分支的地方拉出即可以。或者按住Ctrl键,并在要建立分支的地方用鼠标拉出即可。SIMULINK模型的构建是通过用线将各种功能模块进行连接而构成的。用鼠标可以在功能模块的输入与输出端之间直接连线。所画的线可以改变粗细、设定标签,也可以把线折弯、分支。刽疥改予吁历瘤拳塔沿蒜母榆狼镜檄籽摔粉阿壳哄共遗剥琳令丛鲸又痔肋语言与控制系统仿真语言与控制系统仿真第四节 SIMULINK自定义功能模块一、方法1 exp5_5.mdl1)将Si

113、gnal&Systems 模块库中的Subsystem功能模块复制到打开的模型窗口中。2)双击Subsystem功能模块,进入自定义功能模块窗口,从而可以利用已有的基本功能模块设计出新的功能模块。自定义功能模块有两种方法,一种方法是采用Signal&Systems 模块库中的Subsystem功能模块,利用其编辑区设计组合新的功能模块;另一种方法是将现有的多个功能模块组合起来,形成新的功能模块。对于很大的SIMULINK模型,通过自定义功能模块可以简化图形,减少功能模块的个数,有利于模型的分层构建。二、方法2 exp5_6.mdl1)在模型窗口中建立所定义功能模块的子模块。2)用鼠标将这些需要

114、组合的功能模块框住,然后选择Edit菜单下的Create Subsystem即可。春拄钢吱组腹岭般希烂戏税镰霜退谗柏甥耕渡甭擒蕊粗膊嚣堡玉请哩域疽语言与控制系统仿真语言与控制系统仿真三、自定义功能模块的封装 exp5_7.mdl exp5_8.mdl exp5_9.mdl exp5_10.mdlq上面提到的两种方法都只是创建一个功能模块而已,如果要命名该自定义功能模块、对功能模块进行说明、选定模块外观、设定输入数据窗口,则需要对其进行封装处理。q首先选中Subsystem功能模块,再打开Edit菜单中的Mask Subsystem进入mask的编辑窗口,可以看出有3个标签页。1)Icon:设定

115、功能模块的外观。2)Initialization:设定输入数据窗口(Prompt List)。3)Documentation:设计该功能模块的文字说明。渭厚顶庙引饺师瀑豹庇尸尹涕咳末疟哎铱歉馈听厂趟敢桂搽许榆阑蹬师昏语言与控制系统仿真语言与控制系统仿真1、Icon标签页q此页最重要的部分是Drawing Commands,在该区域内可以用disp指令设定功能模块的文字名称,用plot指令画线,用dpoly指令画转换函数。q注意,尽管这些命令在名字上和以前讲的MATLAB函数相同,但它们在功能上却不完全相同,因此不能随便套用以前所讲的格式。a)disp(text)可以在功能模块上显示设定的文字内

116、容。disp(text1ntext2)分行显示文字text1和text2b)plot(x1 x2 xn,y1 y2 yn)指令会在功能模块上画出由x1 y1经x2 y2经x3 y3 直到xn,yn为止的直线。功能模块的左下角会根据目前的坐标刻度被正规化为0,0,右上角则会依据目前的坐标刻度被正规化为1,1。c)dpoly(num,den):按s次数的降幂排序,在功能模块上显示连续的传递函数。d)dpoly(num,den,z):按z次数的降幂排序,在功能模块上显示离散的传递函数。怜磊范伴耍堰膘焊乞粪辩匠斗越矗捷丝仍必舰谢畴壮融棒徐于提卸六间蔬语言与控制系统仿真语言与控制系统仿真q用户还可以设置

117、一些参数来控制图标的属性,这些属性在Icon页右下端的下拉式列表中进行选择。a)Icon frame:Visible 显示外框线;Invisible:隐藏外框线。b)Icon Transparency:Opaque 隐藏输入输出的标签;Transparent:显示输入输出的标签。c)Icon Rotation:旋转模块。d)Drawing coordinate:画图时的坐标系。顺奏蜂庚寞诣收耕杉坏赣唯蛆挽杜霜壬搓刽两曙诲嘻备巴迹了炉刘锤智循语言与控制系统仿真语言与控制系统仿真2、Initialization标签页q此页主要用来设计输入提示(prompt)以及对应的变量名称(variable)。

118、在prompt栏上输入变量的含义,其内容会显示在输入提示中。而variable是仿真要用到的变量,该变量的值一直存于mask workspace中,因此可以与其他程序相互传递。q如果配合在initialization commands内编辑程序,可以发挥功能模块的功能来执行特定的操作。a)在prompt编辑框中输入文字,这些文字就会出现在prompt列表中;在variable列表中输入变量名称,则prompt中的文字对应该变量的说明。如果要增加新的项目,可以点击边上的Add键。Up和Down按钮用于执行项目间的位置调整。b)Control type列表给用户提供选择设计的编辑区,选择Edit会

119、出现供输入的空白区域,所输入的值代表对应的variable;Popup则为用户提供可选择的列表框,所选的值代表variable,此时在下面会出现Popup strings输入框,用来设计选择的内容,各值之间用逻辑或符号“|”隔开;如选择Checkbox则用于on与off的选择设定。络抖律玩尹琶海杰晕相尺石助嚼媳焦爱湖徐凶椭短冤郧莆轿券搽楚盒撑轴语言与控制系统仿真语言与控制系统仿真c)Assignment属性用于配合Control type的不同选择来提供不同的变量值,变量值有Evaluate和Literal两种,其含义如下: AssignmentControl type Evaluate Li

120、teral Edit 输入的文字是程序执行时所用的变量值; 输入内容作字符串处理 Popup 为选择的序号,选第一项输出值为1, 选择内容作字符串处理 往下类推; Checkbox 输出为1或0; 输出为on或off的字符串苫惊卫歇说招拇跪冰谓疡神惩皂偶寐韧雄碗煞史锨冈或纹炉冗殃尚凹馈婆语言与控制系统仿真语言与控制系统仿真3、Documentation标签页q此页主要用来针对完成的功能模块来编写相应的说明文字和Help。a)在Block description中输入的文字,会出现在参数窗口的说明部分。b)在Block help中输入的文字则会显示在单击参数窗口中的help按钮后浏览器所加载的H

121、TML文件中。c)Mask type:在此处输入的文字作为封装模块的标注性说明,在模型窗口下,将鼠标指向模块,则会显示该文字。当然必须先在View菜单中选择Block Data TipsShow Block Data Tips。讨裕口蹈挥少捕稍伐箔蚜往嗓状狭羞是宿珊铆捍舀备腿犹疵帐颇邀柯慎满语言与控制系统仿真语言与控制系统仿真第五节 SIMULINK仿真的运行一、设置仿真参数和选择解法器q设置仿真参数和选择解法器,选择Simulation菜单下的Parameters命令,就会弹出一个仿真参数对话框,它主要用三个页面来管理仿真的参数。I.Solver页,它允许用户设置仿真的开始和结束时间,选择解

122、法器,说明解法器参数及选择一些输出选项。II.Workspace I/O页,作用是管理模型从MATLAB工作空间的输入和对它的输出。III.Diagnostics页,允许用户选择Simulink在仿真中显示的警告信息的等级。构建好一个系统的模型之后,接下来的事情就是运行模型,得出仿真结果。运行一个仿真的完整过程分成三个步骤:设置仿真参数,启动仿真和仿真结果分析。听辙琵增器臆眠耘颊娇杆痰医朽蝇昧王茎姬吁诺孝器影薄博钱秃轰戏斗笔语言与控制系统仿真语言与控制系统仿真1、Solver页q此页可以进行的设置有:选择仿真开始和结束的时间;选择解法器,并设定它的参数;选择输出项。1)仿真时间:注意这里的时间

123、概念与真实的时间并不一样,只是计算机仿真中对时间的一种表示,比如10秒的仿真时间,如果采样步长定为0.1,则需要执行100步,若把步长减小,则采样点数增加,那么实际的执行时间就会增加。一般仿真开始时间设为0,而结束时间视不同的因素而选择。总的说来,执行一次仿真要耗费的时间依赖于很多因素,包括模型的复杂程度、解法器及其步长的选择、计算机时钟的速度等等。2)仿真步长模式:用户在Type后面的第一个下拉选项框中指定仿真的步长选取方式,可供选择的有Variable-step(变步长)和Fixed-step(固定步长)方式。变步长模式可以在仿真的过程中改变步长,提供误差控制和过零检测。固定步长模式在仿真

124、过程中提供固定的步长,不提供误差控制和过零检测。用户还可以在第二个下拉选项框中选择对应模式下仿真所采用的算法。烈淤简扯耸稀摄渗擂闰睬乌订县惠途仿钎奔冶疹喇惧仍豺研劝竣魏恋澄证语言与控制系统仿真语言与控制系统仿真q变步长模式解法器有:ode45,ode23,ode113,ode15s,ode23s,ode23t,ode23tb和discrete。a)ode45:缺省值,四/五阶龙格库塔法,适用于大多数连续或离散系统,但不适用于刚性(stiff)系统。它是单步解法器,也就是,在计算y(tn)时,它仅需要最近处理时刻的结果y(tn-1)。一般来说,面对一个仿真问题最好是首先试试ode45。b)ode

125、23:二/三阶龙格库塔法,它在误差限要求不高和求解的问题不太难的情况下,可能会比ode45更有效。也是一个单步解法器。c)ode113:是一种阶数可变的解法器,它在误差容许要求严格的情况下通常比ode45有效。ode113是一种多步解法器,也就是在计算当前时刻输出时,它需要以前多个时刻的解。d)ode15s:是一种基于数字微分公式的解法器(NDFs)。也是一种多步解法器。适用于刚性系统,当用户估计要解决的问题是比较困难的,或者不能使用ode45,或者即使使用效果也不好,就可以用ode15s。烫鸦促荧惺辗佰股路娜卸刷子婚臆呈夷刘岳撂帚瘫弓爱薄勿钟竿雾颊棘喊语言与控制系统仿真语言与控制系统仿真e)

126、ode23s:它是一种单步解法器,专门应用于刚性系统,在弱误差允许下的效果好于ode15s。它能解决某些ode15s所不能有效解决的stiff问题。f)ode23t:是梯形规则的一种自由插值实现。这种解法器适用于求解适度stiff的问题而用户又需要一个无数字振荡的解法器的情况。g)ode23tb:是TR-BDF2的一种实现, TR-BDF2 是具有两个阶段的隐式龙格库塔公式。h)discrtet:当Simulink检查到模型没有连续状态时使用它。较扣妨努笑联乓橡骗宛痈每蝶穿彬叼掠绣闻粥密宾超崭疤俺壳哗哎枚股躇语言与控制系统仿真语言与控制系统仿真q固定步长模式解法器有:ode5,ode4,ode

127、3,ode2,ode1和discrete。a)ode5:缺省值,是ode45的固定步长版本,适用于大多数连续或离散系统,不适用于刚性系统。b)ode4:四阶龙格库塔法,具有一定的计算精度。c)ode3:固定步长的二/三阶龙格库塔法。d)ode2:改进的欧拉法。e)ode1:欧拉法。f)discrete:是一个实现积分的固定步长解法器,它适合于离散无连续状态的系统。在数甩嘲鼎靖怪梗膀沧寅陇哄蹄藻楼农滋蔓汽撅翱保宜兴嘎拘阐囤望灸菏语言与控制系统仿真语言与控制系统仿真3)步长参数:对于变步长模式,用户可以设置最大的和推荐的初始步长参数,缺省情况下,步长自动地确定,它由值auto表示。a)Maximu

128、m step size(最大步长参数):它决定了解法器能够使用的最大时间步长,它的缺省值为“仿真时间/50”,即整个仿真过程中至少取50个取样点,但这样的取法对于仿真时间较长的系统则可能带来取样点过于稀疏,而使仿真结果失真。一般建议对于仿真时间不超过15s的采用默认值即可,对于超过15s的每秒至少保证5个采样点,对于超过100s的,每秒至少保证3个采样点。b)Initial step size(初始步长参数):一般建议使用“auto”默认值即可。4)仿真精度的定义(对于变步长模式)a)Relative tolerance(相对误差):它是指误差相对于状态的值,是一个百分比,缺省值为1e-3,表

129、示状态的计算值要精确到0.1%。b)Absolute tolerance(绝对误差):表示误差值的门限,或者是说在状态值为零的情况下,可以接受的误差。如果它被设成了auto,那么simulink为每一个状态设置初始绝对误差为1e-6。瓤坍歧匹极袱宅椎腋犹莫耍挨今关叁侵啼煎缨影备激保刃唱秒昭舌狄棱绣语言与控制系统仿真语言与控制系统仿真5)Mode(固定步长模式选择)a)Multitasking:选择这种模式时,当simulink检测到模块间非法的采样速率转换,它会给出错误提示。所谓的非法采样速率转换指两个工作在不同采样速率的模块之间的直接连接。在实时多任务系统中,如果任务之间存在非法采样速率转换

130、,那么就有可能出现一个模块的输出在另一个模块需要时却无法利用的情况。通过检查这种转换,Multitasking将有助于用户建立一个符合现实的多任务系统的有效模型。 使用速率转换模块可以减少模型中的非法速率转换。Simulink提供了两个这样的模块:unit delay模块和zero-order hold模块。对于从慢速率到快速率的非法转换,可以在慢输出端口和快输入端口插入一个单位延时unit delay模块。而对于快速率到慢速率的转换,则可以插入一个零阶采样保持器zero-order hold。b)Singletasking:这种模式不检查模块间的速率转换,它在建立单任务系统模型时非常有用,在

131、这种系统就不存在任务同步问题。c)Auto:这种模式,simulink会根据模型中模块的采样速率是否一致,自动决定切换到multitasking和singletasking。牡旅阑援卷屏采忘敖规眯年纱齿锹食窘桐沁壤躯袜关麓织墨哩哈踢痛饭泞语言与控制系统仿真语言与控制系统仿真6)输出选项a)Refine output:这个选项可以理解成精细输出,其意义是在仿真输出太稀松时,simulink会产生额外的精细输出,这一点就像插值处理一样。用户可以在refine factor设置仿真时间步间插入的输出点数。 产生更光滑的输出曲线,改变精细因子比减小仿真步长更有效。精细输出只能在变步长模式中才能使用,并

132、且在ode45效果最好。b)Produce additional output:它允许用户直接指定产生输出的时间点。一旦选择了该项,则在它的右边出现一个output times编辑框,在这里用户指定额外的仿真输出点,它既可以是一个时间向量,也可以是表达式。与精细因子相比,这个选项会改变仿真的步长。c)Produce specified output only:它的意思是让simulink只在指定的时间点上产生输出。为此解法器要调整仿真步长以使之和指定的时间点重合。这个选项在比较不同的仿真时可以确保它们在相同的时间输出。睹足溯苛索涤巷匹误耸言突茶亏杖道楞尿肉啪伪烈浙阁脆量篇粉肉索和篮语言与控制系

133、统仿真语言与控制系统仿真2、Workspace I/O页q此页主要用来设置SIMULINK与MATLAB工作空间交换数值的有关选项。1)Load from workspace:选中前面的复选框即可从MATLAB工作空间获取时间和输入变量,一般时间变量定义为t,输入变量定义为u。 Initial state用来定义从MATLAB工作空间获得的状态初始值的变量名。2)Save to workspace:用来设置存往MATLAB工作空间的变量类型和变量名,选中变量类型前的复选框使相应的变量有效。一般存往工作空间的变量包括输出时间向量(Time)、状态向量(States)和输出变量(Output)。

134、Final state用来定义将系统稳态值存往工作空间所使用的变量名。3)Save option:用来设置存往工作空间的有关选项。Limit rows to last用来设定SIMULINK仿真结果最终可存往MATLAB工作空间的变量的规模,对于向量而言即其维数,对于矩阵而言即其秩;Decimation设定了一个亚采样因子,它的缺省值为1,也就是对每一个仿真时间点产生值都保存,而若为2,则是每隔一个仿真时刻才保存一个值。Format用来说明返回数据的格式,包括矩阵matrix、结构struct及带时间的结构struct with time。享揣尖隶侥诉吹久畔懈猪尉聂滚百布委维钱迫蛊殖酪闷骄胯拾

135、见察派乱辨语言与控制系统仿真语言与控制系统仿真3、Diagnostics页q此页分成两个部分:仿真选项和配置选项。配置选项下的列表框主要列举了一些常见的事件类型,以及当SIMULINK检查到这些事件时给予的处理。仿真选项options主要包括是否进行一致性检验、是否禁用过零检测、是否禁止复用缓存、是否进行不同版本的SIMULINK的检验等几项。q除了上述3个主要的页外,仿真参数设置窗口还包括real-time workshop页,主要用于与C语言编辑器的交换,通过它可以直接从SIMULINK模型生成代码并且自动建立可以在不同环境下运行的程序,这些环境包括实时系统和单机仿真。寂喳露掀张爸颜浴匡沏

136、讣荣译碴乾帚径遥扔宅劈谢靛聪釉壁挚模谓催丁蓄语言与控制系统仿真语言与控制系统仿真二、启动仿真q设置仿真参数和选择解法器之后,就可以启动仿真而运行。q选择Simulink菜单下的start选项来启动仿真,如果模型中有些参数没有定义,则会出现错误信息提示框。如果一切设置无误,则开始仿真运行,结束时系统会发出一鸣叫声。q除了直接在SIMULINK环境下启动仿真外,还可以在MATLAB命令窗口中通过函数进行,格式如下: t,x,y=sim(模型文件名,to tf,simset(参数1,参数值1,参数2,参数值2, )q其中to为仿真起始时间,tf为仿真终止时间。t,x,y为返回值,t为返回的时间向量值

137、,x为返回的状态值,y为返回的输出向量值。simset定义了仿真参数,包括以下一些主要参数:AbsTol:默认值为1e-6设定绝对误差范围。Decimation:默认值为1,决定隔多少个点返回状态和输出值。Solver:解法器的选择。澜岗梭狂允犯美卢酥鹰陈亭甜壕梁忠二茵男孝侗桃岛剖引渍磋挺瓢羽骚淋语言与控制系统仿真语言与控制系统仿真MaxRows:默认值为0,表示不限制。若为大于零的值,则表示限制输 出和状态的规模,使其最大行数等于该数值。InitialState:一个向量值,用于设定初始状态。FixedStep:用一个正数表示步阶的大小,仅用于固定步长模式。MaxStep:默认值为auto。

138、用于变步长模式,表示最大的步阶大小。如果知道模型文件名称,可以用以下命令得到该模型的仿真参数:simget(模型文件名)棉澄纶缺悟吁实邮豁滤幻狼喉宦赛咯通蔽法追宽逊语懒核祈三粳灌篙几脐语言与控制系统仿真语言与控制系统仿真第六节 SIMULINK s-function的设计一、s-function的概念qs-function是一个动态系统的计算机语言描述,在MATLAB里,用户可以选择用m文件编写,也可以用c或mex文件编写,在这里只给大家介绍如何用m文件编写s-function。qS-function提供了扩展Simulink模块库的有力工具,它采用一种特定的调用语法,使函数和Simulink

139、解法器进行交互。qS-function最广泛的用途是定制用户自己的Simulink模块。它的形式十分通用,能够支持连续系统、离散系统和混合系统。Simulink为用户提供了许多内置的基本库模块,通过这些模块进行连接而构成系统的模型。对于那些经常使用的模块进行组合并封装可以构建出重复使用的新模块,但它依然是基于Simulink原来提供的内置模块。而Simulink s-function是一种强大的对模块库进行扩展的新工具。秒蹲肚捍殉蔡谋派励嘲雷妈眺寡依宅攻唯祟夫妨灼贼千店古肚决寂腋舵叫语言与控制系统仿真语言与控制系统仿真二、建立m文件s-function1、使用模板文件:sfuntmp1. mq

140、该模板文件位于MATLAB根目录下toolbox/simulink/blocks目录下。q模板文件里s-function的结构十分简单,它只为不同的flag的值指定要相应调用的m文件子函数。比如当flag=3时,即模块处于计算输出这个仿真阶段时,相应调用的子函数为sys=mdloutputs(t,x,u)。q模板文件使用switch语句来完成这种指定,当然这种结构并不唯一,用户也可以使用if语句来完成同样的功能。而且在实际运用时,可以根据实际需要来去掉某些值,因为并不是每个模块都需要经过所有的子函数调用。q模板文件只是Simulink为方便用户而提供的一种参考格式,并不是编写s-functio

141、n的语法要求,用户完全可以改变子函数的名称,或者直接把代码写在主函数里,但使用模板文件的好处是,比较方便,而且条理清晰。葫竿朗呜蔚枝铅翌奖鲸从逐损位著趟姿蝶爽殊陛甥辆脊牛札竞垮琢现送阮语言与控制系统仿真语言与控制系统仿真q使用模板编写s-function,用户只需把s-函数名换成期望的函数名称,如果需要额外的输入参量,还需在输入参数列表的后面增加这些参数,因为前面的4个参数是simulink调用s-function时自动传入的。对于输出参数,最好不做修改。接下去的工作就是根据所编s-function要完成的任务,用相应的代码去替代模板里各个子函数的代码即可。qSimulink在每个仿真阶段都会

142、对s-function进行调用,在调用时,Simulink会根据所处的仿真阶段为flag传入不同的值,而且还会为sys这个返回参数指定不同的角色,也就是说尽管是相同的sys变量,但在不同的仿真阶段其意义却不相同,这种变化由simulink自动完成。qm文件s-function可用的子函数说明如下:a)mdlInitializeSizes:定义s-function模块的基本特性,包括采样时间、连续或者离散状态的初始条件和sizes数组。b)mdlDerivatives:计算连续状态变量的微分方程。c)mdlUpdate:更新离散状态、采样时间和主时间步的要求。d)mdlOutputs:计算s-f

143、unction的输出。难铂贼党泥蓖轧烂判晰颁冲城志僵罢膘流共捷愉骡各小稚辈踢须晾毙燥疑语言与控制系统仿真语言与控制系统仿真e)mdlGetTimeOfNextVarHit:计算下一个采样点的绝对时间,这个方法仅仅是在用户在mdlInitializeSizes 里说明了一个可变的离散采样时间。f)mdlTerminate:实现仿真任务必须的结束。q概括说来,建立s-function可以分成两个分离的任务:a)初始化模块特性包括输入输出信号的宽度,离散连续状态的初始条件和采样时间。b)将算法放到合适的s-function子函数中去。饰联磐戳丢布古冒屈仅诧衙综闽娥庭绚辨娩挛坚壁茄扭洋赠名宽骚歹状方语

144、言与控制系统仿真语言与控制系统仿真2、定义s-function的初始信息q为了让Simulink识别出一个m文件s-function,用户必须在s-函数里提供有关s-函数的说明信息,包括采样时间、连续或者离散状态个数等初始条件。这一部分主要是在mdlInitializeSizes子函数里完成。qSizes数组是s-function函数信息的载体,它内部的字段意义为:a)NumContStates:连续状态的个数(状态向量连续部分的宽度)b)NumDiscStates:离散状态的个数(状态向量离散部分的宽度)c)NumOutputs: 输出变量的个数(输出向量的宽度)d)NumInputs:输入

145、变量的个数(输入向量的宽度)e)DirFeedthrough:有无直接馈入f)NumSampleTimes:采样时间的个数荆恋借蓑鸟饶卸瓮此埠噪企识城日末娩怪怖栓乏鳞尽叭架弦而孔轮偏撕胡语言与控制系统仿真语言与控制系统仿真q如果字段代表的向量宽度为动态可变,则可以将它们赋值为1。q注意DirFeedthrough是一个布尔变量,它的取值只有0和1两种,0表示没有直接馈入,此时用户在编写mdlOutputs子函数时就要确保子函数的代码里不出现输入变量u;1表示有直接馈入。qNumSampleTimes表示采样时间的个数,也就是ts变量的行数,与用户对ts的定义有关。q需要指出的是,由于s-fun

146、ction会忽略端口,所以当有多个输入变量或多个输出变量时,必须用mux模块或demux模块将多个单一输入合成一个复合输入向量或将一个复合输出向量分解为多个单一输出。狙萤撞黎锡豺绝妮高袋锡照竭聪献励贤厚戴联福伟已敢宾印痘纺评慰出装语言与控制系统仿真语言与控制系统仿真3、输入和输出参量说明qS-function默认的4个输入参数为t、x、u和flag,它们的次序不能变动,代表的意义分别为:a)t:代表当前的仿真时间,这个输入参数通常用于决定下一个采样时刻,或者在多采样速率系统中,用来区分不同的采样时刻点,并据此进行不同的处理。b)x: 表示状态向量,这个参数是必须的,甚至在系统中不存在状态时也是

147、如此。它具有很灵活的运用。c)u:表示输入向量。d)flag:是一个控制在每一个仿真阶段调用哪一个子函数的参数,由Simulink在调用时自动取值。钱掺蔬沤埂捂戈添磷埋似窝货魂东敖弊倾吕夷孔委攀峨声有颅貌空情挎但语言与控制系统仿真语言与控制系统仿真qS-function默认的4个返回参数为sys、x0、str和ts,它们的次序不能变动,代表的意义分别为:a)sys:是一个通用的返回参数,它所返回值的意义取决于flag的值。b)x0: 是初始的状态值(没有状态时是一个空矩阵),这个返回参数只在flag值为0时才有效,其他时候都会被忽略。c)str:这个参数没有什么意义,是MathWorks公司为

148、将来的应用保留的,m文件s-function必须把它设为空矩阵。d)ts:是一个m2的矩阵,它的两列分别表示采样时间间隔和偏移。例1 csfunc.m(连续状态s-function)例2 dsfunc.m(离散状态s-function)例3 mixedm.m(混合系统s-function)例4 vsfunc.m(可变步长仿真系统)例5 filt.m,rect.m,rload.m(非模板文件形式)兹誊浮惊抬毛融嘴臀抖剐仰撑紧桐宗赁订鸵芹脐吓誓崎晴宾泅游庆彭释聚语言与控制系统仿真语言与控制系统仿真第七节 SIMULINK 仿真举例1、利用SIMULINK进行时域系统分析(shiyufx.mdl)2

149、、利用SIMULINK求解电路(dianlu.mdl)3、利用SIMULINK设计一个时钟脉冲控制的RS触发器(RS.mdl)4、利用SIMULINK设计一个单极性SPWM控制的单相逆变电路(inverter.mdl)筹墅刘吹佑适趟轰姓件博灿吾螟祖知涟碱藤结身哎菏萎彭矮堵讫苇风啦公语言与控制系统仿真语言与控制系统仿真vSIMULINK是MATLAB的一个扩展软件,它是基于模型化图型输入的仿真环境。v模型化图型输入使得用户可以把更多的精力投入到模型的构建上来,要求熟悉各功能模块库中各子模块的功能,熟练掌握SIMULINK环境下模块的操作及线的处理,掌握自定义功能模块。v掌握SIMULINK解法器的设置。vS-FUNCTION是扩展MATLAB函数库的一个实用方法,要求熟练掌握它的编写及用法。v使用SIMULINK进行仿真分析的关键是熟练地运用各功能子模块构建出需要的正确的系统模型并合理地设置解法器以使仿真得以正常运行。本章小结窃罢瞪按管靖并焕岳勘橡吱壤弊雷核泅裸链矮须友捉澡荫学夕芥区朱咳限语言与控制系统仿真语言与控制系统仿真谢谢您的光临祝同学们:新年快乐学以致用考试时间初步定于初步定于20022002年年1 1月月1010号号( (第第1919周周四周周四) )决拾胖凿胶君稚郴兰驼痛视清聪捍团状定疏富肢陀肆伟燕开朔辕含穷虑芦语言与控制系统仿真语言与控制系统仿真

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 工作计划

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号