动态系统的Simulink.ppt
3 动态系统的Simulink第第3章章 动态系统的动态系统的Simulink3.1 简单系统的仿真分析简单系统的仿真分析3.2 Scope高级使用技术高级使用技术3.3 离散系统的仿真分析离散系统的仿真分析3.4 连续系统的仿真分析连续系统的仿真分析3.5 线性系统仿真分析线性系统仿真分析3.6 混合系统设计分析混合系统设计分析3.7 Simulink的调试技术的调试技术 3 动态系统的Simulink3.1 简单系统的仿真分析简单系统的仿真分析 3.1.1 建立系统模型首先根据系统的数学描述选择合适的Simulink系统模块,然后按照第2章中的方法建立此简单系统的系统模型。这里所使用的系统模块主要有:(1)Sources模块库中的SineWave模块:用来作为系统的输入信号。(2)Commonlyused模块库中的RelationalOperator模块:用来实现系统中的时间逻辑关系。3 动态系统的Simulink(3)Sources模块库中的Clock模块:用来表示系统运行时间。(4)Nonlinear模块库中的Switch模块:用来实现系统的输出选择。(5)Math模块库中的Gain模块:用来实现系统中的信号增益。图3.1所示为此简单系统的系统模型。3 动态系统的Simulink图3.1简单系统模型3 动态系统的Simulink 3.1.2 系统模块参数设置在完成系统模型的建立之后,需要对系统中各模块的参数进行合理的设置。这里采用的模块参数设置如下所述:(1)SineWave模块:采用Simulink默认的参数设置,即单位幅值、单位频率的正弦信号。(2)RelationalOperator模块:其参数设置为“”,如图3.2所示。(3)Clock模块:采用默认参数设置,如图3.3所示。3 动态系统的Simulink(4)Switch模块:设定Switch模块的Threshold(临界)值为0.5(其实只要大于0小于1即可,因为Switch模块在输入端口2的输入大于或等于给定的阈值Threshold时,模块输出为第一端口的输入,否则为第三端口的输入),从而实现此系统的输出随仿真时间进行正确的切换。如图3.4所示。(5)Gain模块:其参数设置如图3.1系统模型中所示,这里不再赘述。3 动态系统的Simulink图3.2RelationalOperator模块参数设置3 动态系统的Simulink图3.3Clock模块参数设置3 动态系统的Simulink图3.4Switch模块参数设置3 动态系统的Simulink 3.1.3 系统仿真参数设置及仿真分析在对系统模型中各个模块进行正确且合适的参数设置之后,需要对系统仿真参数进行必要的设置以开始仿真。在缺省情况下,Simulink默认的仿真起始时间为0s,仿真结束时间为10s。对于此简单系统,当时间大于25s时系统输出才开始转换,因此需要设置合适的仿真时间。设置仿真时间的方法为:选择菜单Simulation中的SimulationParameters(或使用快捷键Ctrl+E),打开仿真参数设置对话框,在Solver(求解器)选项卡中设置系统仿真时间区间。设置系统仿真起始时间为0s、结束时间为100s,如图3.5所示。3 动态系统的Simulink在系统模块参数与系统仿真参数设置完毕之后,用户便可开始系统仿真了。运行仿真的方法有如下几种:(1)选择菜单Simulation中的StartSimulation。(2)使用系统组合热键Ctrl+T。(3)使用模型编辑器工具栏中的Play按钮(即黑色三角形)。3 动态系统的Simulink图3.5系统仿真时间设置3 动态系统的Simulink当系统仿真结束后,双击系统模型中的Scope模块,显示的系统仿真结果如图3.6所示。从图3.6中可以看出,系统仿真输出曲线非常不平滑;而对此系统的数学描述进行分析可知,系统输出应该为光滑曲线。这是由于在仿真过程中没有设置合适的仿真步长,而是使用Simulink的默认仿真步长设置所造成的。因此,对动态系统的仿真步长需要进行合适的设置。3 动态系统的Simulink图3.6系统仿真结果输出曲线3 动态系统的Simulink 仿真步长设置仿真参数的选择对仿真结果有很大的影响。对于简单系统,由于系统中并不存在状态变量,因此每一次计算都应该是准确的(不考虑数据截断误差)。在使用Simulink对简单系统进行仿真时,影响仿真结果输出的因素有仿真起始时间、结束时间和仿真步长。对于简单系统仿真来说,不管采用何种求解器,Simulink总是在仿真过程中选用最大的仿真步长。3 动态系统的Simulink如果仿真时间区间较长,而且最大步长设置采用默认取值auto,则会导致系统在仿真时使用大的步长,因为Simulink的仿真步长是通过下式得到的:3 动态系统的Simulink图3.7系统最大仿真步长设置3 动态系统的Simulink图3.8系统最大仿真步长为0.1下的仿真输出结果3 动态系统的Simulink3.2 Scope高级使用技术高级使用技术 3.2.1 Scope模块的使用这里以3.1节中简单系统仿真输出结果为例说明Scope模块的使用技术。图3.9所示为默认设置下此简单系统仿真结果输出显示。(3.1节中对Scope显示的动态范围进行了调整,因此与图3.9中显示的不一样。)3 动态系统的Simulink图3.9默认设置下Scope模块的显示3 动态系统的Simulink图3.10Scope模块工具栏按钮命令3 动态系统的Simulink下面分别对各项功能进行详细介绍。1)打印输出(Print)将系统仿真结果的输出信号打印出来。2)视图自动缩放(Autoscale)Simulink自动调整显示范围以匹配系统仿真输出信号的动态范围。在图3.9中采用默认设置,如果自动缩放视图,则可以获得更好的显示效果,如图3.11所示。3 动态系统的Simulink图3.11视图自动缩放3 动态系统的Simulink3)X轴缩放、Y轴缩放以及视图整体缩放对信号的指定范围进行缩放,可以分别对X坐标轴、Y坐标轴或同时对X、Y坐标轴(即整体视图)的信号显示作缩放,以满足用户对信号做局部观察的需要。首先单击缩放按钮,然后选择需要观察的信号范围即可,如图3.12所示。如果用户需要缩小视图,单击鼠标右键,选择弹出菜单的Zoomout即可。3 动态系统的Simulink图3.12视图缩放3 动态系统的Simulink4)保存与恢复坐标轴设置在使用Scope模块观测输出信号时,用户可以保存坐标轴设置。这样,当信号的视图发生改变后,单击恢复坐标轴设置可以恢复以前保存的坐标轴设置,如图3.13所示。3 动态系统的Simulink图3.13保存与恢复视图设置3 动态系统的Simulink5)Scope的参数设置使用Scope模块的参数设置选项卡能够对系统仿真输出结果显示进行更多的控制,而不仅仅是上述的简单控制。图3.14、图3.15所示分别为Scope模块参数设置选项卡中的General选项卡与DataHistory选项卡。3 动态系统的Simulink图3.14Scope模块的General选项卡3 动态系统的Simulink图3.15Scope模块的Datahistory选项卡3 动态系统的Simulink下面简单介绍一下各选项卡的功能与使用。1)坐标系数目(Numberofaxes)功能描述:在一个Scope输出模块中使用多个坐标系窗口同时输出多个信号。在默认设置下,Scope模块仅显示一个坐标系窗口。2)悬浮Scope开关(Floatingscope)功能描述:将Scope模块切换为悬浮Scope模块。悬浮Scope模块将在节中进行介绍。3 动态系统的Simulink3)显示时间范围(Timerange)功能描述:设置信号显示的时间范围。注意:信号显示的时间范围与系统仿真时间范围并不等同,并且坐标系所示的时间范围并非为绝对时间,而是指相对时间范围,坐标系的左下角的时间偏移(Timeoffset)给出了时间的起始偏移量(即显示时间范围的起始时刻)。4)坐标系标签(Ticklabels)功能描述:确定Scope模块中各坐标系是否带有坐标轴标签。此选项提供了三种选择:全部坐标系都使用坐标标签(all)、3 动态系统的Simulink下方坐标系使用标签(bottomaxisonly)以及都不使用标签(none)。用户最好使用标签,这有利于对信号的观察理解.5)信号显示点数限制(Limitdatapointstolast)功能描述:限制信号显示的数据点的数目,Scope模块会自动对信号进行截取以显示信号的最后n个点(这里n为设置的数值)。3 动态系统的Simulink6)保 存 信 号 至 工 作 空 间 变 量(Save data toworkspace)功能描述:将由Scope模块显示的信号保存到Matlab工作空间变量中,以便于对信号进行更多的定量分析。数据保存类型有三种:带时间变量的结构体(structurewith time)、结 构 体(structure)以 及 数 组 变 量(Array)。这与前面所介绍的Sinks模块库中的Toworkspace模块类似。3 动态系统的Simulink此外,在Scope模块中的坐标系中单击鼠标右键,选择弹出菜单中坐标系属性设置命令(axesproperties),将弹出图3.16所示的坐标系属性设置对话框。用户可以对Scope模块的坐标系标题与显示信号范围进行合适的设置,以满足仿真输出结果显示的需要。3 动态系统的Simulink图3.16坐标系属性设置对话框3 动态系统的Simulink 3.2.2 Display模块的使用在某些情况下,用户需要观察或动态显示某个信号的数值结果时,可以选用Display模块,它既可以显示单个信号,也可以显示向量信号或矩阵信号(帧信号)。当信号的显示范围超出了Display模块的边界,会在Display模块的右下角出现一个向下的三角,表示还有信号的值没被显示出来,这时用户只需用鼠标拉大Display模块的显示面板即可。3 动态系统的Simulink 3.2.3 悬浮Scope模块在系统仿真分析中,用户往往需要对多个输出信号进行观察分析。如果将每一个信号都与一个Scope模块相连接,则系统模型中必定会存在多个Scope模块,使得系统模型不够简练,而且难以对不同Scope模块中显示的信号进行直观的比较。Sinks模块库中FloatingScope模块(悬浮Scope模块)可以很好地解决这一问题。3 动态系统的Simulink 1.悬浮Scope模块的使用方法使用悬浮Scope模块的方法有如下两种:(1)直接将Sinks模块库中的FloatingScope模块拖动到指定的系统模型之中。然后选择需要显示的信号并进行适当的设置,最后进行系统仿真并显示系统中指定的信号。(2)设置普通的Scope模块为FloatingScope模块。用户只需选择图3.14中所示的悬浮Scope开关即可。其后的操作与(1)一致。例如,对于图3.17所示的动态系统模型,使用FloatingScope与悬浮Display模块显示指定的信号。3 动态系统的Simulink图3.17使用悬浮Scope模块与悬浮Display模块3 动态系统的Simulink 2.使用悬浮Scope模块显示信号的参数设置对于图3.17所示的系统模型,要使用悬浮Scope模块显示指定的信号,必须进行正确的设置。1)设置需要显示的信号使用悬浮Scope模块的信号选择器选择需要显示的信号:首先打开信号选择器对话框,然后在可显示信号列表中选择需要显示的信号,这里选择显示正弦信号与方波信号。信号选择如图3.18所示。3 动态系统的Simulink2)设置信号存储缓冲区与全局变量在缺省情况下,Simulink重复使用存储信号的缓存区。也就是说,Simulink信号都是局部变量。使用悬浮Scope模块显示指定信号,由于信号与模块之间没有实际的连接,因此局部变量不再适用。故用户应当避免Simulink对变量的缓存区重复使用,需要对其进行正确设置。3 动态系统的Simulink图3.18悬浮Scope模块的信号选择3 动态系统的Simulink图3.19信号存储缓冲区设置3 动态系统的Simulink 3.运行系统仿真在相应的参数设置完成之后,运行系统仿真,系统仿真输出结果如图3.20所示。从图中可以看出,正弦信号与方波信号被正确显示出来。3 动态系统的Simulink图3.20系统仿真结果(悬浮Scope模块输出)3 动态系统的Simulink3.3 离散系统的仿真分析离散系统的仿真分析 3.3.1 人口变化系统的数学模型这是一个简单的人口变化模型。在此模型中,设某一年的人口数目为p(n),其中n表示年份,它与上一年的人口p(n-1)、人口繁殖速率r以及新增资源所能满足的个体数目K之间的动力学方程由如下的差分方程所描述:3 动态系统的Simulink从此差分方程中可以看出,此人口变化系统为一非线性离散系统。如果设人口初始值p(0)=100000、人口繁殖 速 率 r=1.05、新 增 资 源 所 能 满 足 的 个 体 数 目k=1000000,要求建立此人口动态变化系统的系统模型,并分析人口数目在0至100年之间的变化趋势。3 动态系统的Simulink 3.3.2 建立人口变化系统的模型在建立此人口变化的非线性离散系统模型之前,首先对离散系统模块库(Discrete模块库)中比较常用的模块作简单的介绍。(1)UnitDelay模块:其主要功能是将输入信号延迟一个采样时间,它是离散系统的差分方程描述以及离散系统仿真的基础。在仿真时只要设置延迟模块的初始值便可计算系统输出。3 动态系统的Simulink(2)Zero-OrderHold模块:其主要功能是对信号进行零阶保持。使用Simulink对离散系统进行仿真时,单位延迟是由Discrete模块库中的UnitDelay模块来完成的。对于人口变化系统模型而言,需要将p(n)作为UnitDelay模块的输入以得到p(n-1),然后按照系统的差分方程来建立人口变化系统的模型。3 动态系统的Simulink图3.21人口变化系统模型3 动态系统的Simulink 3.3.3 系统模块参数设置系统模型建立之后,首先需要按照系统的要求设置各个模块的参数,如下所述:(1)增益模块Gain表示人口繁殖速率,故取值为1.05。(2)模块Gain1表示新增资源所能满足的个体数目的倒数,故取值为1/1000000。(3)UnitDelay模块参数设置。对于离散系统而言,必须正确设置所有离散模块的初始取值,否则系统仿真结果会出现错误。这是因为在不同的初始值下,系统的稳定性会发生变化。单位延迟模块的参数设置如图3.22所示。3 动态系统的Simulink图3.22单位延迟模块的参数设置3 动态系统的Simulink 系统仿真参数设置及仿真分析在正确设置系统模型中各模块的模块参数之后,需要对系统仿真参数进行设置。下面介绍离散系统的仿真参数设置,在此之前首先介绍系统仿真的基本原理。这可以使用户加深对离散系统仿真的理解,并且更好的掌握离散系统仿真技术。3 动态系统的Simulink图3.23系统的仿真原理3 动态系统的Simulink下面设置人口变化系统的仿真参数:(1)仿真时间设置:按照系统仿真的要求,设置系统仿真时间范围为0100。(2)离散求解器与仿真步长设置:对离散系统进行仿真需要使用离散求解器。对于离散系统的仿真,无论是采用定步长求解器还是采用变步长求解器,都可以对离散系统进行精确的求解。这里选择定步长求解器对此系统进行仿真分析。至于定步长与变步长的区别将在后面专门进行介绍。使用Simulation菜单中的SimulationParameters设置系统仿真参数,如图3.24所示。3 动态系统的Simulink图3.24系统仿真参数设置3 动态系统的Simulink在对系统中各模块参数以及系统仿真参数进行正确设置之后,运行系统仿真,对人口数目在指定的时间范围之内的变化趋势进行分析。图3.25所示为系统仿真输出结果。3 动态系统的Simulink图3.25人口变化系统仿真结果3 动态系统的Simulink 3.3.5 定步长仿真与变步长仿真对于一个单速率离散系统的仿真,选择定步长求解器对仿真来说已经足够了。但是在对多速率离散系统进行仿真时,采用变步长仿真则具有更多的优势。这里所谓的单速率与多速率离散系统,是指离散系统中各系统模块采样时间是否一致,如果所有模块的采用时间均相同,则此系统为单速率离散系统,否则为多速率离散系统。一般而言,使用变步长求解器对离散系统进行仿真,其效率要优于定步长求解器,如图3.26所示。3 动态系统的Simulink图3.26定步长求解器与变步长求解器的仿真时刻对比3 动态系统的Simulink图3.26表示某一离散系统模型中的某两个系统模块具有不同的采样时间,模块1的采样时间为0.4s,而模块2的采样时间为0.6s。图中每个黑色粗实线代表了模块的一次更新,也就是模块的每一次采样。如果使用定步长求解器对此离散系统进行仿真,由于模块之间采样时间不同,所以步长选择要足够小以匹配所有的采样时刻;于是导致在某些时刻系统进行了不必要的计算(图中由椭圆曲线标志)。如果使用变步长求解器,仿真步长自动调整使其恰好匹配两个模块的更新,从而提高了系统仿真的效率。3 动态系统的Simulink3.4 连续系统的仿真分析连续系统的仿真分析 3.4.1 蹦极跳系统的数学模型蹦极跳是一种挑战身体极限的运动,蹦极者系着一根弹力绳从高处的桥梁(或是山崖等)向下跳。在下落的过程中,蹦极者几乎是处于失重状态。按照牛顿运动规律,自由下落的物体的位置由下式确定:3 动态系统的Simulink其中m为物体的质量,g为重力加速度,x为物体的位置,第二项与第三项表示空气的阻力。其中位置x的基准为蹦极者开始跳下的位置(即选择桥梁作为位置的起点x=0),低于桥梁的位置为正值,高于桥梁的位置为负值。如果物体系在一个弹性常数为的弹力绳索上,定义绳索下端的初始位置为0,则其对落体位置的影响为因此整个蹦极跳系统的数学描述为3 动态系统的Simulink 3.4.2 建立蹦极跳系统的Simulink仿真模型与建立离散系统模型类似,在建立蹦极跳系统的模型之前,首先对连续系统模块库Continuous中比较常用的模块简单的回顾。(1)积分器(Integrator):积分器的主要功能在于对输入的连续信号进行积分运算。(2)微分器(Derivative):微分器的主要功能在于对输入的连续信号进行微分运算。3 动态系统的Simulink在蹦极跳系统模型中,主要使用的系统模块有:(1)Continuous模块库中的Integrator模块:用来实现系统中的微分运算。(2)Functions&Tables模块库中的Fcn模块:用来实现系统中空气阻力的函数关系。(3)Nonlinear模块库中的Switch模块:用来实现系统中弹力绳索的函数关系。蹦极跳系统的模型框图如图3.27所示。3 动态系统的Simulink图3.27蹦极跳系统模型3 动态系统的Simulink 3.4.3 系统模块参数设置在建立蹦极跳系统模型之后,需要设置系统模型中各个模块的参数。这里仅给出积分器模块velocity与position的参数设置,如图3.28所示。在具有连续状态的连续系统中,千万不能忘记对积分器模块的初始值进行设置;因为在不同的初始值下,系统的动态规律可能大相径庭。至于其它模块的参数都比较简单,这里不再给出。3 动态系统的Simulink图3.28积分器模块velocity与position的参数设置3 动态系统的Simulink 3.4.4 系统仿真参数设置与仿真分析在对蹦极跳系统模型中各个模块的参数正确设置之后,需要设置系统仿真参数以对此系统进行仿真分析。在系统仿真参数设置之前,首先简单介绍一下Simulink的连续求解器。3.3节中对离散系统的仿真原理做了简单的介绍,Simulink通过离散系统模型与Matlab求解器之间的交互完成离散系统的仿真;其实对于任何的动态系统,Simulink总是通过系统模型与Matlab求解器之间的交互来完成系统仿真。3 动态系统的Simulink微分方程的不同数值求解方法对应着不同的连续求解器。Simulink的连续求解器可以使用不同的数值求解方法对连续系统进行求解:(1)定步长连续求解器。可以使用如下的方法:ode5,ode4,ode3,ode2,ode1。(2)变步长连续求解器。可以使用如下的方法:ode45,ode23,ode113,ode15s,ode23s,ode23t,ode23tb。3 动态系统的Simulink使用Simulation菜单下的SimulationParameters打开仿真参数设置对话框,对蹦极跳系统的仿真参数设置如下:(1)系统仿真时间范围为0100s。(2)其它仿真参数采用系统默认取值(变步长求解器、求解算法ode45、自动选择最大仿真步长、相对误差为1e-3)。然后进行系统仿真。仿真输出结果如图3.29所示(蹦极者相对于地面的距离)。3 动态系统的Simulink图3.29蹦极跳系统的仿真结果3 动态系统的Simulink 3.4.5 仿真精度控制细心的读者一定会发现,在图3.29蹦极跳系统的仿真结果中,仿真曲线的波峰与波谷处曲线很不光滑。而从蹦极跳系统的数学方程中分析可知,系统的输出曲线应该是光滑曲线。造成这一结果的主要原因是:对此系统仿真来说,连续求解器的默认积分误差取值偏大。因此,只有设置合适的积分误差限,才能获得更好的仿真结果。3 动态系统的Simulink变步长连续求解器可以根据积分误差对仿真步长进行自动调整。因此,用户可以设置合适的积分误差上限,以对系统仿真步长进行控制,从而获得更好的仿真结果。积分误差分为如下的两种:(1)绝对误差:积分误差的绝对值。(2)相对误差:绝对误差除以状态的值。3 动态系统的Simulink在仿真参数设置对话框中,用户可以对积分绝对误差与相对误差进行合适的设置。这样,在系统仿真中求解器只有满足给定的误差条件时才能够进行下一步计算。一般说来,当状态值较大时,相对误差小于绝对误差,由相对误差控制求解器的运行;而当状态值接近零时,绝对误差小于相对误差,则由绝对误差来控制求解器。3 动态系统的Simulink图3.30蹦极跳系统的仿真参数设置3 动态系统的Simulink然后再对蹦极跳系统进行仿真,其仿真结果如图3.31所示。从图中可以明显得看出,减小系统仿真积分误差可以有效的提高系统的仿真性能,仿真输出波峰与波谷处的曲线变得比较光滑。3 动态系统的Simulink图3.31新的仿真参数设置下的仿真结果3 动态系统的Simulink3.5线性连续系统仿真分析第四节中对连续系统的仿真技术做了详细的介绍,对于具有连续状态的连续系统而言,往往使用积分器模块Integrator建立系统的模型。虽然实际的动态系统多数都是非线性系统,但是在一定的范围之内,非线性系统可以由线性系统来近似。由于非线性系统的设计、仿真与分析技术都比较复杂,而且还不成熟,尚无通用的理论形成;而线性系统的设计、仿真分析比较简单,故其应用非常广泛。本部分将介绍线性连续系统的仿真技术。3 动态系统的Simulink1.建立线性连续系统的模型建立线性连续系统模型的方法与建立一般线性系统模型的方法没有什么本质的区别。不同之处在于,线性连续系统往往使用传递函数模型、零极点模型以及状态空间模型进行描述,因此在建立线性连续系统模型时经常使用与此相应的模块(即Continuous模块库中的TransferFcn模块、Zero-Pole模块以及State-Space模块)。下面以比例-微分控制器系统模型的建立为例进行说明。3 动态系统的Simulink图3.36比例-微分控制系统模型3 动态系统的Simulink2设置系统模块参数与仿真参数在建立比例微分控制系统模型之后,需要设置各模块参数与系统仿真参数。系统模型中模块参数设置如下:(1)Zero-Pole模块设置:设置零点Zeros为、设置极点Poles为0-0.5、设置增益为1。(2)Step信号模块设置:使用系统的默认取值,即单位阶跃信号。(3)其它各模块的参数设置如图3.36中所示。3 动态系统的Simulink在设置系统模块参数之后,接下来使用SimulationParameters仿真参数对话框中的Solver选项卡设置系统仿真参数,如下所述:(1)仿真时间范围为0至20s。(2)使用变步长连续求解器(variable-step),仿真算法为ode45。(3)最大仿真步长(Maxstepsize)为0.01。(4)绝对误差(Absolutetolerance)为1e-6。(5)其余仿真参数使用默认取值。3 动态系统的Simulink3仿真分析在对模块参数与系统仿真参数进行合适的设置之后,运行系统仿真,结果如图3.37所示。从系统的仿真结果可以明显的看出,比例-微分控制系统为典型的二阶线性系统;在阶跃信号的作用下,系统不断地对位置误差进行控制修正,最终使系统达到稳定的状态。为改善此系统的性能(如降低系统的超调量、减小系统的过渡时间等),可以对比例-微分控制器进行调整(改变Gain、Gain1模块的增益)以获得更好的性能。3 动态系统的Simulink图3.37比例-微分系统仿真结果3 动态系统的Simulink3.6 混合系统设计分析混合系统设计分析 3.6.1混合系统仿真技术的一般知识在对混合系统进行仿真分析时,必须考虑系统中连续信号与离散信号采样时间之间的匹配问题。Simulink中的变步长连续求解器充分考虑到了连续信号与离散信号采样时间的匹配问题。因此在对混合系统进行仿真分析时,应该使用变步长连续求解器。3 动态系统的Simulink由于混合系统中信号类型不一,使用同样的样式表示信号不利于用户对系统模型的理解。Simulink仿真环境提供的Sampletimecolors功能可以很好的将不同类型、不同采样时间的信号用不同的颜色表示出来,从而可以使用户对混合系统中的信号有个清晰的了解。只需选择Format菜单中的Sampletimecolors命令便可实现这一功能。其中黑色信号线表示连续信号,其它颜色的信号表示离散信号;并且不同的颜色表示采样时间的不同,其中红色的信号表示采样速率时间最快的,绿色次之,而黄色表示含多速率的系统或是信号。下面举例说明变步长连续求解器对信号采样时间的匹配问题,如图3.38所示。3 动态系统的Simulink图3.38变步长连续求解器对信号采样时间的匹配3 动态系统的Simulink图中左侧所示为一简单的混合系统模型(使用了Sampletimecolors功能表示不同采样时间的信号,其中UnitDelay模块采样时间为0.7s,UnitDelay1模块采样时间为1.1s),图中右侧所示为系统仿真输出数据点的图形,从中可以明显的看出:变步长连续求解器不时的减小仿真步长以匹配离散信号的采样时刻。3 动态系统的Simulink3.6.2混合系统设计:行驶控制系统汽车行驶控制系统是应用非常广泛的控制系统之一,其主要目的是对汽车速度进行合理的控制。系统的工作原理如下:(1)汽车速度操纵机构的位置发生改变以设置汽车的速度,这是因为操纵机构的不同位置对应着不同的速度。(2)测量汽车的当前速度,并求取它与指定速度的差值。3 动态系统的Simulink(3)由速度差值信号驱动汽车产生相应的牵引力,并由此牵引力改变汽车的速度直到其速度稳定在指定的速度为止。由系统的工作原理来看,汽车行驶控制系统为典型的反馈控制系统。下面建立此系统的Simulink模型并进行仿真分析。3 动态系统的Simulink1汽车行驶控制系统的物理模型与数学描述速度操纵机构的位置变换器位置变换器是汽车行驶控制系统的输入部分,其目的是将速度操纵机构的位置转换为相应的速度,二者之间的数学关系如下所示:3 动态系统的Simulink离散行驶控制器行驶控制器是整个汽车行驶控制系统的核心部分。简单说来,其功能是根据汽车当前速度与指定速度的差值,产生相应的牵引力。行驶控制器为一典型的PID控制器,其数学描述为:积分环节:微分环节:系统输出:3 动态系统的Simulink汽车动力机构汽车动力机构是行驶控制系统的执行机构。其功能是在牵引力的作用下改变汽车速度,使其达到指定的速度。牵引力与速度之间的关系为:其中为v汽车的速度、F为汽车的牵引力、m为汽车的质量、b为阻力因子。3 动态系统的Simulink1建立汽车行驶控制系统的模型按照汽车行驶控制系统的物理模型与数学描述建立系统模型。在进行系统模型之前,首先给出建立系统模型所需的主要系统模块:(1)Math模块库中的SliderGain滑动增益模块:对位置变换器的输入信号的范围进行限制。(2)Discrete模块库中的UnitDelay单位延迟模块:用来实现行驶控制器(即PID控制器)。3 动态系统的Simulink(3)Continuous模块中的Integrator积分器模块:用来实现汽车动力机构。(4)Subsystems模块库中的Subsystem子系统模块:用来对系统不同的部分进行封装。然后建立系统模型,并将速度操纵机构的位置变换器、行驶控制器、汽车动力机构封装到不同的子系统之中,如图3.41所示。3 动态系统的Simulink图3.41A汽车行驶控制系统之位置变换器与汽车动力机构3 动态系统的Simulink图3.41B行驶控制系统之行驶控制器3 动态系统的Simulink3系统模块参数设置与仿真参数设置在建立系统模型之后,接下来按照系统的要求设置系统模块参数与仿真参数。这里仅给出模块参数与相应的仿真参数。速度操纵机构的位置变换器参数(1)SliderGain模块:最小值Low为0、最大值High为1、初始取值0.555。(2)Gain模块:增益取值为50。(3)Constant1模块:常数取值为45。3 动态系统的Simulink行驶控制器参数(1)所有UnitDelay模块:初始状态为0、采样时间为0.02s。(2)P、I、D增益模块:取值分别为1、0.01、0。汽车动力机构参数(1)Gain模块:取值为1/m,即1/1000。(2)Gain1模块:取值为b/m,即20/1000。(3)Integrator模块:初始状态为0,即速度初始值为0。3 动态系统的Simulink系统仿真参数(1)仿真时间范围:从0至1000s。(2)求解器:使用变步长连续求解器。3 动态系统的Simulink4系统仿真与分析在对系统模块参数与系统仿真参数设置之后,接下来对系统进行仿真分析。为了使用户对离散行驶控制器的作用有一个直观的认识,这里使用两组不同的PID控制参数对系统进行仿真,其结果如图3.42所示。3 动态系统的Simulink图3.42不同控制参数下的仿真结果3 动态系统的Simulink汽车行驶控制系统的目的是使汽车的速度在较短的时间内平稳地达到指定的速度。从图3.42的仿真结果中可以看出,在行驶控制器控制参数取值为P=1、I=0.01、D=0时,汽车的速度并非直接达到指定的速度,而是经过一个振荡衰减过程,最后逐渐过渡到指定的速度。此时行驶控制系统为典型的二阶欠阻尼控制系统。3 动态系统的Simulink3.6.3工作空间输入输出WorkspaceI/O设置在对动态系统进行仿真分析时,往往需要对系统的仿真结果进行进一步的定量分析。使用Scope模块可以直接显示系统仿真结果,非常有利于对系统的定性分析,但并不利于系统的定量分析。本书第4章中介绍的Simulink与Matlab的接口设计技术,允许Simulink与Matlab之间进行数据交互,如从Matlab工作空间中获得系统模块参数、输出仿真结果至Matlab工作空间等。3 动态系统的Simulink图3.43WorkspaceI/O选项卡3 动态系统的Simulink1从Matlab工作空间获得系统输入(Loadformworkspace)虽然Simulink提供了多种系统输入信号,但并不能完全满足需要。Simulink允许使用用户自定义的信号作为系统输入信号。在Loadformworkspace框中,用户可以设置Matlab中的变量作为系统输入信号或是系统状态初始值,如下所述:(1)Input:用来设置系统输入信号。其格式为t,u,其中t、u均为列向量,t为输入信号的时间向量,u为相应时刻的信号取值,可以使用多个信号输入,如t,u1,u2。输入信号与Simulink的接口由Inport模块(In1模块)实现。3 动态系统的Simulink(2)xInitialstate:用来设置系统状态变量初始值。初始值xInitial可为行向量。注意,使用xInitialstate所设置状态变量初始值会自动覆盖系统模块中的设置。另外,输入信号与状态变量需要按照系统模型中Inport模块(即In1模块)的顺序进行正确设置。3 动态系统的Simulink2输入数据至Matlab工作空间(Savetoworkspace)使用WorkspaceI/O选项卡可以将系统的仿真结果、系统仿真时刻、系统中的状态或是指定的信号输出到Matlab工作空间之中,以便用户对其进行定量分析,如下所述:(1)Time:输出系统仿真时刻。(2)States:输出系统模型中所有的状态变量。(3)Output:输出系统模型中所有由Outport模块(即Out1模块)表示的信号。(4)Finalstate:输出系统模型中的最终状态变量取值,即最后仿真时刻处的状态值。3 动态系统的Simulink2数据保存设置(Saveoption)(1)Limitdatapointstolast:表示输出数据的长度(从信号的最后数据点记起)。(2)Format:表示输出数据类型。共有三种形式:StructurewithTime(带有仿真时间变量的结构体)、Structure(不带仿真时间变量的结构体)以及Array(信号数组)。3 动态系统的Simulink上面简单介绍了WorkspaceI/O选项卡的设置与功能,下面举例说明。对于图3.44所示的系统,按照图中所示设置系统仿真参数中的WorkspaceI/O选项卡,以从Matlab工作空间获取系统输入信号、系统状态初始值并将系统仿真结果输出至Matlab工作空间之中。3 动态系统的Simulink图3.44WorkspaceI/O设置举例3 动态系统的Simulink在运行仿真之前,首先需要生成系统输入信号与状态初始值,在Matlab命令窗口中键入如下命令:t=1:0.1:10;t=t;u=sin(t);u=u;xInitial=0,1;然后运行系统仿真,为了观察WorkspaceI/O设置的效果,这里使用Scope模块显示仿真结果,如图3.45所示。3 动态系统的Simulink图3.45使用WorkspaceI/O设置的仿真结果3 动态系统的Simulink此时查看Matlab的工作空间,用户可以发现系统仿真结果(仿真时间、系统状态、系统运算结果以及最终状态等)被正确的输出到Matlab工作空间中,这里不再赘述。3 动态系统的Simulink3.7 Simulink的调试技术的调试技术毫无疑问,功能强大、界面友好的调试功能是优秀系统设计开发平台所必备的条件之一。Simulink作为高性能的系统设计、仿真与分析平台,给用户提供了强大的模型调试工具。通过Simulink的调试工具,用户可以对动态系统的系统模型进行调试,以发现其中可能存在的问题,然后进行修改,从而快速完成系统设计、仿真与分析的目的。3 动态系统的Simulink不同领域中的不同的系统模型,其复杂程度往往相差悬殊,对系统模型调试的复杂程度也大不相同。Simulink所提供的图形调试器可以满足多数应用领域中系统模型的调试,而并非针对专门的应