系统建模可以分为两种机理建模和建模建模就是通过Read.docx
- 文档编号:9892976
- 上传时间:2023-02-07
- 格式:DOCX
- 页数:16
- 大小:690.26KB
系统建模可以分为两种机理建模和建模建模就是通过Read.docx
《系统建模可以分为两种机理建模和建模建模就是通过Read.docx》由会员分享,可在线阅读,更多相关《系统建模可以分为两种机理建模和建模建模就是通过Read.docx(16页珍藏版)》请在冰豆网上搜索。
系统建模可以分为两种机理建模和建模建模就是通过Read
系统建模
系统建模可以分为两种:
机理建模和实验建模.实验建模就是通过在研究对象上加上一系列的研究者先确定的输入信号,激励研究对象并通过传感器的检测其可观测的输出,应用数学手段建立起系统输入---输出关系.这里包括输入信号的设计选取,输出信号的精确检测,数学算法的研究等等内容.机理建模就是在了解研究对象在运动规律基础上,通过物理,化学的知识和数学手段建立起的系统内部的输入输出状态关系.系统的建模原则:
1)建模之前,要全面了解系统的自然特征和运动机理,明确研究目的和准确性要求,选择合适的分析方法。
2)按照所选分析法,确定相应的数学模型的形式;
3)根据允许的误差范围,进行准确性考虑,然后建立尽量简化的合理的数学模型。
小车—倒立摆系统是各种控制理论的研究对象。
只要一提小车—倒立摆系统,一般均认为其数学模型也已经定型。
事实上,小车—倒立摆的数学模型与驱动系统有关,常见到的模型只是对应于直流电机的情况,如果执行机构是交流伺服电机,就不是这个模型了。
本文主要分析由直流电机驱动的小车—倒立摆系统。
小车倒立摆系统是检验控制方式好坏的一个典型对象,其特点是高阶次、不稳定、非线性、强耦合,只有采取有效的控制方式才能稳定控制.
在忽略空气阻力,各种摩擦之后,可将直线一级倒立摆系统抽象成小车忽然均匀质杆组成的系统,如下图所示:
θ
图中F是施加于小车的水平方向的作用力,x是小车的位移,Φ是摆的倾斜角。
若不给小车施加控制力,倒摆会向左或向右倾斜,控制的目的是当倒摆出现偏角时,在水平方向上给小车以作用力,通过小车的水平运动,使倒摆保持在垂直的位置。
即控制系统的状态参数,以保持摆的倒立稳定。
M小车的质量0.5Kg
m摆杆的质量0.2Kg
B小车的摩擦力0.1N/m/sec
L摆杆转动轴心到杆之质心的长度0.3m
I摆杆惯量0.006kg×m2
T采样频率0.005sec
F加在小车上的力
X小车位置
θ摆杆与垂直方向向下的夹角
Φ摆杆与垂直方向向上的夹角
倒立摆系统最终的控制目的是使倒立摆这样一个不稳定的被控对象,通过引入适当的控制策略使之成为一个能够满足各种性能指标的稳定系统,单节倒立摆系统的控制模型是目前国内外广泛采用的模型是研究各种控制算法的基础。
该系统由计算机,运动控制卡,伺服机构,倒立摆,本体和光电码盘等几部分组成了一个闭环系统。
如图所示:
光电码盘将小车的位移速度信号反馈给伺服驱动器和运动控制卡,摆杆的位置,速度信号由光电码盘也反馈回运动控制卡。
计算机从运动控制卡中读取实时数据,确定控制决策(小车向哪个方向移动,移动速度,加速度等。
)并实现该控制决策,产生相应的控制量,使电机带动小车,保持平衡。
1.结构参数
倒立摆是不稳定的,如果没有适当的控制力作用在它的上面,它将随时可能向任何方向倾倒。
这里只考虑二维问题,即认为倒立摆只在图3所示平面内运动。
控制力F作用于小车上。
摆杆长度为l,质量为m,小车的质量为M,小车瞬时位移为x,摆杆瞬时位置为(x+2L*sinΦ),在外力的作用下,系统产生运动。
假设摆杆的重心位于其几何中心。
设输入为作用力F,输出为摆角Φ。
2.系统的运动方程
控制要求:
在摆受到外力F时,调节小车的位置x,保持摆杆平衡。
图3小车受力分析图图4一级摆受力分析图
应用牛顿力学可推导出该倒立摆系统的运动学方程
注意:
此方程中力矩的方向,由于θ=π+Φ,
故等式前有负号.
约去P和N,得到方程:
(1)
(2)
3.线性化
设θ=π+Φ假设Φ与1(单位是弧度)相比很小,即Φ远远小于1,则可以进行近似处理
设u代表被控对象的输入力F,方程
(1)和方程
(2)经过线性化后
(3)
其中
因此倒立摆的状态方程为:
4.单节倒立摆传递函数的推导
对式(3)进行拉氏变换,得到:
初始条件为0时,
由于输出角度为
求解方程组的第一个方程,可以得到
把上式代入到(4)中的第二个方程中,得到:
整理后得到:
其中
5.状态空间方程的推导
系统的状态方程:
其中:
Α为状态矩阵。
Β为输入矩阵。
C为输出矩阵。
D为前馈矩阵。
方程组(3)求解得:
整理后,系统状态空间方程为
由直线一级倒立摆的数学模型式可知,被控对象是个单输入力(F)、双输出(小车的位移,摆杆的角度)的对象
6.系统稳定性分析
一级倒立摆系统的特征方程为det{λI-A}=0,经过Matlab计算得到系统开环特征根为:
λ(A)=(0,5.5651,-0.1428,-5.6041)
系统有一个极点在复平面的右半平面上,有一个极点在原点,因此系统是不稳定的。
由一级倒立摆系统线性状态方程得到:
rank[BABA2BA3B]=4
rank[CCACA2CA3]=4
所以一级倒立摆是能控且能观测的。
对于一缴倒立摆状态方程,对A矩阵进行奇异值分解,得到A矩阵的奇异值阵:
定义:
被控对象控制的难易程度,即系统状态矩阵最大奇异值的到数称为相对能控度。
A矩阵的奇异值为W对角线上的值,所以一级倒立摆的相对能控度,
,δ越小系统的控制难度越高。
PID控制
考虑角度的PID控制
对于一级倒立摆,由前面式子及系统数据,得到数学模型如下:
系统结构框图如图所示:
图1PID控制框图
图中KD(S)是控制器的传递函数,G(S)是一级倒立摆的传递函数。
考虑到r(s)=0,结构图可以变换成:
图2输入为0时系统框图
该系统的输出为:
其中,num—被控对象传递函数的分子项
den一被控对象传递函数的分母项
numPID——PID控制器传递函数的分子项
denPID—PID控制器传递函数的分母项
被控对象的传递函数是:
其中,
PID控制器的传递函数为:
在工程实际当中,常采用工程整定法,它们是在理论基础上通过实践总结出来的。
这些方法通过并不复杂的经验便能迅速获得调节器的近似最佳整定参数,因而在工程中得到广泛应用。
具体步骤如下:
(1)置调节器积分时间Ti到最大值,微分时间Td为0,比例带置较大值,使系统投入运行。
(2)待系统运行稳定后,逐渐增大Kp,直到系统出现等幅震荡过程,记下此时的比例带并计算两个波峰间的时间Tcr(临界震荡周期)。
利用δcr和Tcr,的值,按照下面给出的经验公式计算:
对于PID调节器:
得:
KP=40KI=1KD=10
系统响应曲线如图所示:
control为受控系统,nature为自然状态:
图3PID控制一级倒立摆相应曲线
从上图中可以看出,进过PID控制后,倒立摆在1.5达到稳定状态,系统超调量很小,而且没有稳态误差,该方法对单级倒立摆的控制可以很容易实现。
考虑小车位置的PID控制
考虑小车位置的系统结构如图所示:
图4改进系统框图
其中,G1(S)是摆杆传递函数,G2(S)是小车传递函数。
由于输入信号r(s)=0,所以可以把结构图4转换成结构图5
图5转换成单输入单输出系统
其中,反馈环代表我们前面设计的控制器。
小车位置输出为:
其中,numl,den1,num2,den2分别代表被控对象1和被控对象2传递函数的分子和分母。
根据前面的推导:
可以推导出小车位置的传递函数为:
其中,
可以看出,den1=den2=den,小车的闭环传递函数可以简化成:
根据上面控制摆角度的Z-N方法,可以控制小车的位置,但是由Simulink系统框图4可以看出,此系统为单输入双输出系统,所以我们只能在两个输出量中选择一个作为被控量。
在这种PID方法中,选择控制优先级高的输出量(摆的角度)作为系统输出。
要想既控制倒立摆的角度又控制小车的位置,简单的PID方法是无法实现的。
模糊控制
一级倒立摆系统模糊控制器结构如图1.首先利用线性二次型状态反馈控制,然后加入模糊控制器以达到更好的控制效果。
图1模糊控制器结构图
一级倒立摆有4个状态变量,而模糊控制器仅有两个输入,因此必须对4个状态变量做一些处理才能作为模糊控制器的输入。
首先引入两个辅助变量E和EC:
其中,x1,x2,x3,x4分别为x
,φ,
,
,K=[k1,k2,k3,k4]T为状态反馈系统,线性二次型控制指标:
通过求解Riccati方程:
得到:
E和EC分别为上面图中模糊控制器的输入,它们有如下特征:
(1)它们包含了状态变量的全部信息;
(2)通过改变Q和R的值,可以改变各个状态变量在E和EC中的权重,从而可以有目的地改变状态变量对于模糊控制器输出的作用;
(3)这两个量具有较明确的物理意义。
模糊控制器相当于由综合误差E和综合误差变化率EC构成的非线性控制器:
得到:
无论从系统动态性能还是静态性能,此种模糊控制方法都能满足要求。
而且无论怎样改变小车的理想位置,系统经过一段时间后都能够回到要求的位置。
不会因输出要求的改变,小车位置的变化过大而不能够达到控制目的。
神经网络控制
倒立摆具有不稳定性,若想通过开环试验获取数据,抽取控制规则很困难。
所以,从闭环试验中抽取一些有效的数据作为训练样本,比如简单的比例、LQR控制规则等。
在进行B-P网络设计前,一般从网络层数、每层神经元数、初始值、以及学习方法等方面来考虑。
具有偏差和至少一个S型隐含层加上一个线性输出层的网络,能够逼近任何有理函数。
影响神经网络B-P的因素有网络的层数,网络各层神经元的个数等。
影响神经BP算法的因素还有学习速率、初始权值的选取、以及神经网络期望误差的选取,可以选择一个具有一个隐含层的二层网络,它的输入分别为系统的四个状态变量:
小车的位置,小车的速度,摆的角度和摆的角速度。
隐含层有10个神经元,输出层为一个。
隐含层采用“tansig”转换函数,输出层采用线性转换函数“purelin”。
如图1所示。
图1神经网络结构图
获得训练样本并确定神经网络结构后,即可以对神经网络进行训练。
图2训练后网络输出与期望输出
图形表明我们通过上述训练方法能够使训练后网络的输出很好的逼近期望输出,并达到较为理想的效果。
利用系统的传递函数:
小车的位置和输出之间的传递函数G1(s),摆的角度和输出量之间的传递函数G2(s)队倒立摆进行仿真。
神经网络控制器的输入参数为四个即倒立摆系统的四个状态变量:
小车的位置、小车的速度、摆的角速度和摆的角加速度。
输出为对小车所加控制量。
神经网络控制模块可以利用MatlabFunction定义,此模块的主要作用是通过调用一个函数来实现某项功能,当然这个函数可以用Matlab语言编写。
图3倒立摆神经网络仿真
图4仿真结果图
由图4所示仿真结果图可以看出,小车在3秒内即回到平衡位置,且基本保持在轨道中间,摆杆也在较快时间内保持在垂直平面上。
可见通过神经网络控制器仿真,可以得到满意的控制结果。
由前面的仿真模块可以看出,神经网络控制器控制效果很好,所以把其对应的训练输出,根据BP算法编辑控制器的框图,控制器的子系统框图如图5。
其中的权值矩阵都用Matlab中的gain框图表示,而偏值用constant表示,两个传递函数分别为tansig模块和purelin线性模块。
通过net.iw{l,1}和net.lw{2,1}来求第一第二层的权值矩阵,用net.b{1),net.b{2)来分别求网络的偏值。
根据BP算法的正向传播算法计算网络输出。
控制器的两个输出分别为理论运算的速度Vel和加速度Acc。
并分别把训练好的数据依次输入到对应的模块。
对倒立摆的实际控制时,采用Subsystem封装控制器的子框图,进行设计神经网络控制器。
计算出需要发出的控制量,最后通过转换把输出的控制量转换为电压,对伺服电动机进行控制,从而实现了对倒立摆系统的控制。
图5控制器子框图
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 系统 建模 可以 分为 机理 就是 通过 Read