1、自动控制原理上机实验指导书王芳、杨志超编写南京工程学院电力工程学院二七年二月目录Simulink 仿真集成 境 介2 一典型 的性能分析11 二二 系 的性能分析14 三自 控制系 的 定性和 差分析17 四自 控制系 根 迹的分析22 五自 控制系 的 域分析27 六控制系 的校正及 32 七非 性系 的 定性分析39Simulink仿真集成环境简介Simulink 是可视化动态系统仿真环境。 1990 年正式由 Mathworks 公司引入到 MATLAB 中,它是 Slmutation 和 Link 的结合。这里主要介绍它的使用方法和它在控制系统仿真分析和设计操作的有关内容。1、进入 S
2、imulink 操作环境双击桌面上的 MATLAB 图标,启动 MATLAB ,进入开发环境,如图0-1 所示:图 0-1 MATLAB 开发环境从 MATLAB 的桌面操作环境画面进入 Simulink 操作环境有多种方法,介绍如下:点击工具栏的Simulink 图标,弹出如图 0-2 的图形库浏览器画面。在命令窗口键入“ simulink ”命令,可自动弹出图形库浏览器。上述两种方法需从该画面 “ File”下拉式菜单中选择 “New/Model”,或点击图标得到图 0-3 的图形仿真操作画面。从“ File”下拉式菜单中选择“ New/Model ”,弹出图 0-3 所示的未命名的图形仿
3、真操作画面。从工具栏中点击图形库浏览器图标,调出图0-2 的图形库浏览器画面。图,0-3 用于仿真操作,图0-2 的图形库用于提取仿真所需的功能模块。图 0-2 Simulink 图形库浏览器画面图 0-3 simulink 仿真操作环境画面2、提取所需的仿真模块在提取所需仿真模块前,应绘制仿真系统框图,并确定仿真所用的参数。图 0-2 中的仿真用图形库,提供了所需的基本功能模块,能满足系统仿真的需要。该图形库有多种图形子库, 用于配合有关的工具箱。 下面将对本书中实验可能用到的功能模块作一个简单介绍。( 1) Sources(信号源模块组)点击图 0-2 图形库浏览器画面中的Sources,
4、界面右侧会出现各种常用的输入信号,如图 0-4 所示。图 0-4 信号源模块组In(输入端口模块)用来反映整个系统的输入端子,这样的设置在模型线性化与命令行仿真时是必需的。Signal Generator(信号源发生器)能够生成若干种常用信号,如方波信号、正弦波信号、锯齿波信号等,允许用户自由调整其幅值、相位及其它信号。From File(读文件模块)和 From Workspace(读工作空间模块)两个模块允许从文件或 MATLAB 工作空间中读取信号作为输入信号。 Clock(时间信号模块)生成当前仿真时钟,在于事件有关的指标求取中是很有意义的。 Constant(常数输入模块)此模块以常
5、数作为输入,可以在很多模型中使用该模块。 Step(阶跃输入模块)以阶跃信号作为输入,其幅值可以自由调整。 Ramp(斜坡输入模块)以斜坡信号作为输入,其斜率可以自由调整。 Sine Wave(正弦信号输入模块)以正弦信号作为输入,其幅值、频率和初相位可以自由调整。 Pulse Genetator(脉冲输入模块)以脉冲信号作为输入,其幅值和脉宽可以自由调整。( 2)Continuous(连续模块组)连续模块组包括常用的连续模块,如图 0-5 所示。图 0-5 连续模块组 Derivative(微分器)此模块相当于自动控制系统中的微分环节,将其输入端的信号经过一阶数值微分,在其输出端输出。在实际
6、应用中应该尽量避免使用该模块。Integrator(积分器)此模块相当于自动控制系统中的积分环节,将输入端信号经过数值积分,在输出端输出。Transfer Fcn(传递函数)此模块可以直接设置系统的传递函数,以多项式的比值形式描述系统,一般形式为 G( s)bmsmbm 1 sm 1b1s b0 ,其分子分母多项式的系snan 1 sn 1a1s a0数可以自行设置。Pole-Zero(零极点)将传递函数分子和分母分别进行因式分解,变成零极点表达形式 G ( s) K ( s z1 )(s z2 )( s zm ) ,其中 zi (系统的零点)、 pj (系统的极点)可以( s p1 )(s
7、p2 )( s pn )自行设置。 Transport Delay(时间延迟)此模块相当于自动控制系统中的延迟环节,用于将输入信号延迟一定时间后输出,延迟时间可以自行调整。( 3)Math Operations(数学函数模块组)数学函数模块组包含各种数学函数运算模块,如图0-6 所示。Gain(增益函数)此模块相当于自动控制系统中的比例环节,输出信号等于输入信号的乘以模块中种指定的数值,此数值可以自行调整。Sum(求和模块)此模块相当于自动控制系统中的加法器,将输入的多路信号进行求和或求差。其它数学函数,如 Abs(绝对值函数)、Sign(符号函数)、Rounding Function(取整模
8、块)等。图 0-6 数学函数模块组( 4)Sinks(输出池模块组)输出池模块组包含那些能显示计算结果的模块,如图0-7 所示。图 0-7 输出池模块组 Out(输出端口模块)用来反映整个系统的输出端子,这样的设置在模型线性化与命令行仿真时是必需的,另外,系统直接仿真时这样的输出将自动在 MATLAB 工作空间中生成变量。 Scope(示波器模块)将其输入信号在示波器中显示出来。 x-y Graph(x-y 示波器)将两路输入信号分别作为示波器的两个坐标轴,将信号的相轨迹显示出来。 To Workspace(工作空间写入模块)将输入的信号直接写到MATLAB 的工作空间中。 To File(写
9、文件模块)将输入的信号写到文件中。 Display(数字显示模块)将输入的信号以数字的形式显示出来。 Stop Simulation(仿真终止模块)如果输入的信号为非零时,将强行终止正在进行的仿真过程。 Terminator(信号终结模块)可以将该模块连接到闲置的未连接的模块输出信号上,避免出现警告。从图 0-2 中用鼠标点击打开所需子图形库,用鼠标选中所需功能模块,将其拖曳到图 0-3 中的空白位置,重复上述拖曳过程, 直到将所需的全部功能模块拖曳到图0-3 中。拖曳时应注意下列事项:(1) 根据仿真系统框图,选择合适的功能模块进行拖曳,放到合适的位置,以便于连接。(2) 对重复的模块,可采
10、用复制和粘贴操作,也可以反复拖曳。(3) 功能模块和图 0-3 的大小可以用鼠标移动到图标或图边,在出现双向箭头后进行放大或缩小的操作。(4) 选中功能模块的方法是直接点击模块, 用鼠标选定所需功能模块区域来选中区域内所有功能模块和连接线,点击选中,并按下“ shift”键,再点击其它功能模块。3、功能模块的连接根据仿真系统框图, 用鼠标点击并移动所需功能模块到合适的位置, 将鼠标移到有关功能模块的输出端, 选中该输出端并移动鼠标到另一个功能模块的输入端, 移动时出现虚线,到达所需输入端时,释放鼠标左键,相应的连接线出现,表示该连接已完成。重复以上的连接过程,直到完成全部连接,组成仿真系统。4
11、、功能模块参数设置使用者需设置功能模块参数后, 方可进行仿真操作。不同功能模块的参数是不同的,用鼠标双击该功能模块自动弹出相应的参数设置对话框。例如, 0-8 是 Transfer Fcn( 函数)功能模 的 框。功能模 框由功能模 明和参数 置框 成。 功能模 明框用于 明 功能模 使用的方法和功能,参数框用于 置 模 的参数。Transfer Fcn 的参数框由分子和分母多 式两个 框 成,在分子多 式框中, 用 可 入系 模型的分子多 式,在分母多 式框中, 入系 模型的分母多 式。 置功能模 的参数后,点 OK 行确 ,将 置的参数送仿真操作画面,并关 框。图 0-8 Transfer
12、 Fcn (传递函数)模块参数设置对话框5、仿真器参数设置点 0-3 操作画面“ Simulation ”下拉式菜 “ Simulation Parameters” , 出如 0-9 所示的仿真参数 置画面。共有Solver、Workspace I/O 、Diagnostics、Advanced 和 Real-Time Workshop 等五个 面。在 Solver 中 置 Solver Type、Solver(步 )等。仿真操作 ,可根据仿真曲 置 止 和最大步 ,以便得到 光滑的 出曲 。6、示波器参数设置当采用示波器 示仿真曲 ,需 示波器参数 行 置。双 Scope模 , 出如 0-1
13、0 所示的示波器 示画面, 点 画面的 , 出如 0-11 所示的示波器属性 框,分 2 个 面,用于 置 示坐 窗口数、 示 范 、 和 示 率或采 等。 范 可以在示波器属性 框里的General 中的 Time range 置,设置值应与仿真器终止时间一致,以便最大限度显示仿真操作数据。鼠标右键点击示波器显示窗口,从弹出菜单选择“Autoscale”,或直接点击图标,可在响应曲线显示后自动调整纵坐标范围; 从弹出菜单选择 “Save current axes settings”,或直接点击图标,将当前坐标轴范围的设置数据存储。此外,还有打印、放大或恢复等操作。图 0-9 仿真参数设置画面
14、图 0-10 示波器显示画面图 0-11 示波器属性对话框7、运行仿真模型编辑好后,点击图0-3 操作画面“ Simulation”下拉式菜单“ start”或“ startSimulation”按钮运行,双击Scope模块,显示输出曲线。8、对数据作后续处理当仿真任务比较复杂时, 需要将 Simulation 生成的数再导入到工作空间进行处理和分析,仿真结束后,输出结果通过“To workspace”传送到工作空间中,在工作空间窗口中能看到这些变量, 使用“whos”命令能看到这些变量的详细信息。另外, “ To file”、“ From file”模块能实现文件与Simulink 的数据传
15、输。实验一典型环节的性能分析一、实验目的1、熟悉各种典型环节的阶跃响应曲线;2、了解参数变化对典型环节动态特性的影响。二、实验任务1、比例环节( K )从图 0-2 的图形库浏览器中拖曳Step(阶跃输入)、Gain(增益模块)、Scope(示波器)模块到图 0-3 仿真操作画面,连接成仿真框图。改变增益模块的参数, 从而改变比例环节的放大倍数K ,观察它们的单位阶跃响应曲线变化情况。可以同时显示三条响应曲线,仿真框图如图1-1 所示。图 1-1 比例环节仿真框图2、积分环节(1 )Ts将图 1-1 仿真框图中的Gain(增益模块)换成Transfer Fcn(传递函数)模块,设置 Trans
16、fer Fcn(传递函数)模块的参数,使其传递函数变成1 型。Ts改变 Transfer Fcn(传递函数) 模块的参数,从而改变积分环节的T ,观察它们的单位阶跃响应曲线变化情况。仿真框图如图1-2 所示。图 1-2 积分环节仿真框图13、一阶惯性环节()Ts11将图 1-2 中 Transfer Fcn(传递函数)模块的参数重新设置, 使其传递函数变成Ts1型,改变惯性环节的时间常数T ,观察它们的单位阶跃响应曲线变化情况。仿真框图如图 1-3 所示。图 1-3 惯性环节仿真框图4、实际微分环节(Ks)Ts1Ks将图 1-2 中 Transfer Fcn(传递函数)模块的参数重新设置, 使
17、其传递函数变成Ts1型,(参数设置时应注意T1)。令 K 不变,改变Transfer Fcn(传递函数)模块的参数,从而改变T ,观察它们的单位阶跃响应曲线变化情况。仿真框图如图1-4 所示。图 1-4 实际微分环节仿真框图25、二阶振荡环节(n2 )22 nssn将图 1-2 中 TransferFcn(传递函数)模块的参数重新设置,使其传递函数变成22 型(参数设置时应注意 01 ),仿真框图如图 1-5 所示。n2s 2 nsn(1)令n 不变,取不同值( 01),观察其单位阶跃响应曲线变化情况;(2)令=0.2 不变,n 取不同值,观察其单位阶跃响应曲线变化情况。图 1-5 二阶振荡环
18、节仿真框图6、延迟环节( e s )将图 1-2 仿真框图中的 Transfer Fcn(传递函数)模块换成 Transport Delay(时间延迟)模块,改变延迟时间 ,观察单位阶跃响应曲线变化情况。仿真框图如图 1-6 所示。图 1-6 延迟环节仿真框图三、实验要求1、完成实验任务所有的仿真分析;2、撰写实验报告。实验报告内容包括:( 1) 实验题目和目的;( 2) 实验原理;( 3) 各环节的仿真框图和阶跃响应曲线;( 4) 讨论各环节中参数变化对阶跃响应的影响;( 5) 实验的体会。实验二二阶系统的性能分析一、实验目的1、研究二阶系统的两个重要参数阻尼比和自然振荡频率n 对系统动态性
19、能的影响;2、比较比例微分控制的二阶系统和典型二阶系统的性能;3、比较输出量速度反馈控制的二阶系统和典型二阶系统的性能。二、实验任务1、典型二阶系统2二阶系统的传递函数为( s) =n2 ,仿真框图如图 1-5 所示。22n ssn(1)令 n =10 不变,取不同值:1 =0,2 、 3 ( 01 ), 4 =1,5 1,观察其单位阶跃响应曲线变化情况;(2)令=0 不变,n 取不同值,观察其单位阶跃响应曲线变化情况;(3)令=0.2 不变,n 取不同值,观察其单位阶跃响应曲线变化情况,并计算超调量 Mp % 和 ts ;(4)令n =10 不变,取不同值( 01),观察其单位阶跃响应曲线变
20、化情况,并计算超调量 Mp % 和 ts 。2、比例微分控制的二阶系统比例微分控制的二阶系统的结构图如图2-1。图 2-1 比例微分控制的二阶系统的结构图系统中加入比例微分控制,使系统阻尼比增加,并增加一个闭环零点,可以通过仿真比较典型二阶系统和比例微分控制的二阶系统的单位阶跃响应的性能指标。225上图所示的控制系统,令n, Td0.1 ,其中 n 5,0.2 ,从s(s 2 n )s(s 2)Simulink 图形库浏览器中拖曳Step(阶跃输入)、Sum(求和模块)、Pole-Zero(零极点)模块、 Scope(示波器)模块到仿真操作画面,连接成仿真框图如图 2-2 所示。图中Pole-
21、Zero(零极点)模块建立 G (s) 。图 2-2 典型二阶系统和比例微分控制的二阶系统比较仿真框图3、输出量速度反馈的二阶系统输出量速度反馈的二阶系统的结构图如图2-3。图 2-3 输出量速度反馈的二阶系统的结构图系统中加入输出量的速度反馈控制,使系统阻尼比增加, 可以通过仿真比较典型二阶系统和输出量速度反馈控制的二阶系统的单位阶跃响应的性能指标。225图 2-3 所示的控制系统,令n, K f0.1,其中 n 5,0.2 ,s( s 2n ) s(s2)建立仿真框图如图2-4 所示。图中0.1s11 。0.001s0.1s1图 2-4 典型二阶系统和输出量速度反馈控制的二阶系统比较仿真框
22、图三、实验要求1、完成实验任务所有的仿真分析;2、撰写实验报告。实验报告内容包括:( 1) 实验题目和目的;( 2) 实验原理;( 3) 实验任务中要求的所有仿真框图和阶跃响应曲线;( 4) 讨论下列问题:a)试讨论欠阻尼时参数n 对二阶系统阶跃响应曲线及性能指标Mp% 和 ts 的影响;b) 试讨论欠阻尼时参数 对二阶系统阶跃响应曲线及性能指标 Mp % 和 ts 的影响;c) 试讨论二阶系统加入比例微分控制后性能指标的变化;d) 试讨论二阶系统加入带输出量速度反馈控制后性能指标的变化。(5)实验体会。实验三自动控制系统的稳定性和稳态误差分析一、实验目的1、研究高阶系统的稳定性,验证稳定判据
23、的正确性;2、了解系统增益变化对系统稳定性的影响;3、观察系统结构和稳态误差之间的关系。二、实验任务1、稳定性分析欲判断系统的稳定性,只要求出系统的闭环极点即可,而系统的闭环极点就是闭环传递函数的分母多项式的根, 可以利用 MATLAB 中的 tf2zp 函数求出系统的零极点, 或者利用 root 函数求分母多项式的根来确定系统的闭环极点,从而判断系统的稳定性。(1)已知单位负反馈控制系统的开环传递函数为0.2(s 2.5),用G (s)s(s 0.5)( s 0.7)( s3)MATLAB 编写程序来判断闭环系统的稳定性,并绘制闭环系统的零极点图。在 MATLAB 命令窗口写入程序代码如下:
24、z=-2.5p=0,-0.5,-0.7,-3k=0.2Go=zpk(z,p,k)Gc=feedback(Go,1)Gctf=tf(Gc)dc=Gctf.dendens=ploy2str(dc1,s)运行结果如下:dens=s4 + 4.2 s3 + 3.95 s2 + 1.25 s + 0.5dens是系统的特征多项式,接着输入如下MATLAB 程序代码:den=1,4.2,3.95,1.25,0.5p=roots(den)运行结果如下:p =-3.0058-1.0000-0.0971 + 0.3961i-0.0971 - 0.3961ip 为特征多项式 dens的根,即为系统的闭环极点,所有
25、闭环极点都是负的实部,因此闭环系统是稳定的。下面绘制系统的零极点图,MATLAB 程序代码如下:z=-2.5p=0,-0.5,-0.7,-3k=0.2Go=zpk(z,p,k)Gc=feedback(Go,1)Gctf=tf(Gc)z,p,k=zpkdata(Gctf,v)pzmap(Gctf)grid运行结果如下:z =-2.5000p =-3.0058-1.0000-0.0971 + 0.3961i-0.0971 - 0.3961ik =0.2000输出零极点分布图如图3-1 所示。图 3-1 零极点分布图(2)已知单位负反馈控制系统的开环传递函数为 G (s)k ( s 2.5),当0.
26、5)( s 0.7)( s 3)s(s取 k =1,10,100 用 MATLAB 编写程序来判断闭环系统的稳定性。只要将( 1)代码中的 k 值变为 1,10,100,即可得到系统的闭环极点,从而判断系统的稳定性,并讨论系统增益 k 变化对系统稳定性的影响。2、稳态误差分析(1)已知如图3-2 所示的控制系统。其中s5,试计算当输入为单位G ( s)10)s2 (s阶跃信号、单位斜坡信号和单位加速度信号时的稳态误差。图 3-2 系统结构图从 Simulink 图形库浏览器中拖曳 Sum(求和模块)、Pole-Zero(零极点)模块、Scope(示波器)模块到仿真操作画面,连接成仿真框图如图3
27、-3 所示。图中, Pole-Zero(零极点)模块建立 G ( s) ,信号源选择 Step(阶跃信号)、Ramp(斜坡信号)和基本模块构成的加速度信号。为更好观察波形,将仿真器参数中的仿真时间和示波器的显示时间范围设置为 300。图 3-3 系统稳态误差分析仿真框图信号源选定 Step(阶跃信号),连好模型进行仿真,仿真结束后,双击示波器,输出图形如图 3-4 所示。图 3-4 单位阶跃输入时的系统误差信号源选定 Ramp(斜坡信号),连好模型进行仿真,仿真结束后,双击示波器,输出图形如图 3-5 所示。图 3-5 斜坡输入时的系统误差信号源选定加速度信号,连好模型进行仿真,仿真结束后,双
28、击示波器,输出图形如图 3-6 所示。图 3-6 加速度输入时的系统误差从图 3-4、3-5、3-6 可以看出不同输入作用下的系统的稳态误差,系统是II 型系统,因此在阶跃输入和斜坡输入下,系统稳态误差为零,在加速度信号输入下,存在稳态误差。(2)若将系统变为 I 型系统, G ( s)5,在阶跃输入、斜坡输入和加速度信s(s10)号输入作用下,通过仿真来分析系统的稳态误差。三、实验要求1、完成实验任务中的所有内容;2、撰写实验报告。实验报告内容包括:(1) 实验题目和目的;(2) 实验原理;(3) 实验任务中要求完成实验的程序代码、仿真框图、波形和数据结果;(4) 讨论下列问题:a) 讨论系
29、统增益 k 变化对系统稳定性的影响;b) 讨论系统型数以及系统输入对系统稳态误差的影响。(5)实验体会。实验四自动控制系统根轨迹的分析一、实验目的1、学习用 MATLAB 绘制系统根轨迹;2、掌握根据系统根轨迹图分析系统性能。二、实验任务根据系统的开环传递函数 GH (s)bm smbm 1sm 1b1sb0 ,用 MATLAB 绘制系a snasn 1a sann 110统的根轨迹时,首先将传递函数的分子分母多项式的系数写成两个一维数组:numbm bm 1b1 b0 den an an 1a1 a0 利用 MATLA 中的 rlocus 函数绘制系统的根轨迹。1、使用 MATLAB 绘制负
30、反馈系统的根轨迹,该系统的开环传递函数为GH ( s)k (s8)s(s2)( s28s32)MATLAB 程序代码如下:num=1, 8den=conv(1,2,0,1,8,32)sys=tf(num,den)rlocus(sys)%绘制根轨迹图axis(-15 5 -10 10)%调整绘制区域MATLAB 绘制的根轨迹如图4-1 所示。2、使用 MATLAB 绘制正反馈系统的根轨迹,该系统的开环传递函数为k( s8)。GH ( s)8s 32)s(s 2)( s2MATLAB 程序代码如下:num=1, 8den=conv(1,2,0,1,8,32)sys=tf(num,den)rlocu
31、s(-sys)%绘制根轨迹图axis(-15 5 -10 10)%调整绘制区域MATLAB 绘制的根轨迹如图4-2 所示。图 4-1 负反馈系统根轨迹图图 4-2 正反馈系统根轨迹图3 、 使 用 MATLAB绘 制 参 数 a 的 根 轨 迹 , 该 系 统 的 开 环 传 递 函 数 为5(sa),其中 1 a 100 。GH ( s)3)(s 12)( s 1)( sMATLAB 程序代码如下:den=conv(conv(1,1,1,3),1,12)k=5poles=param=%定义数组存储结果for a=1:100%a 从 1 变化到 100num=0 0 k k*aclpoly=n
32、um+denclp=roots(clpoly)%计算闭环极点poles=poles;clpparam=param;aendplot(poles,*)axis equalaxis(-4 0 -2 2)MATLAB 绘制的根轨迹如图4-3 所示。图 4-3 系统参变量根轨迹图、某负反馈系统的开环传递函数为k,用 MATLAB 绘制系统4GH (s)4)s(s 1)(s的根轨迹,并求下面两种情况下的K 值:(1)两分支进入右半平面时; (2)两条分支从实轴进入复平面时。MATLAB 程序代码如下:num=1den=conv(1,1,0,0,1,4)sys=tf(num,den)rlocus(sys)
33、%绘制根轨迹图axis(-15 5 -10 10)%调整绘制区域k,poles=rlocfind(sys)%计算增益值和极点MATLAB 绘制的根轨迹如图4-4 所示。图 4-4根轨迹图利用 rlocfind 命令,可求得任意点对应的K 值。两分支进入右半平面时, K19,对应的极点为 poles=-4.9701、-0.0149 + 1.9625i、-0.0149 - 1.9625i,因此可得当 K19 时,系统由两个闭环极点位于s 右半平面,系统不稳定;两条分支从实轴进入复平面时,K0.88,对应的极点为poles= -4.0706、-0.4647 + 0.0296i、-0.4647 - 0.0296i,则当19 K 0.88 时,系统存在一对共轭的复数极点,系统响应由单调变为振荡。5 、使 用MATLAB绘 制负 反馈 系统的根 轨迹 ,该系统 的开 环传递函 数为k,并求系统稳定的范围。GH ( s)s(s 5)( s22s 5)6 、使 用MATLAB绘 制正 反馈 系统的根 轨迹 ,该系统 的开 环传递函