ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:39.01KB ,
资源ID:18027452      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/18027452.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(5大学本科方案设计书基于matlab的智能PID控制器的方案设计书与仿真Word文档下载推荐.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

5大学本科方案设计书基于matlab的智能PID控制器的方案设计书与仿真Word文档下载推荐.docx

1、1.2 PID控制器的种类PID控制器有传统PID控制器、模糊PID控制器、专家PID控制器、以及动词PID控制器等几类。1.2.1 传统PID控制器PID控制器的参数整定是控制系统设计的核心。图1.1中的PID控制器表示的就是传统PID控制器,其kp、ki、kd三个参数在控制过程中不会自动发生变化,操作人员只能根据控制对象的特性在系统开始工作时选择最优的三个参数。但仅靠一组参数还不能满足系统的要 求,在控制过程中一般还要手动对参数进行修改,由此造成了极大的不方便。工业中实际应用 的PID控制器不会只用传统的PID控制策略。1.2.2 智能PID控制器模糊PID控制器、专家PID控制器、以及动

2、词PID控制器都是智能PID控制器,它们在传 统PID控制器的基础上实现了很多改进。模糊PID控制器和动词PID控制器都是PID参数自整 定型控制器;而专家PID根据专家经验库,可能调整PID参数,或者直接影响输出电压u。本文 主要对模糊PID控制器和动词PID控制器进行研究比较,详细介绍见后面的章节。2.模糊PID控制器模糊PID控制器全称应该叫做“模糊参数自适应(自整定)PID控制器”。图2.1表示其系统 组成。顾名思义,模糊PID控制器的三个参数是能够在线调整、实时改变的。这是模糊PID控制器在传统PID控制器的基础上实现的重大改进。2.1 模糊控制规则12.1.1 控制原理自适应控制应

3、用现代控制理论,以对象特性为基础,在线辨识对象特征参数,实时改变 控制策略。在控制过程中各种信号量不易定量表示,因此需要模糊理论来解决问题。自适应 模糊PID控制器以误差e和误差变化ec作为输入,找到输出的三个PID参数与e和ec之间的模 糊关系。在运行中不断检测e和ec,利用模糊控制规则在线对PID参数进行修改,以满足不 同e和ec对控制参数的不同要求,而使被控对象有良好的动、静态性能。2.1.2 模糊规则误差e、误差变化率ec,以及K的模糊子集均为NB,NM,NS,ZO,PS,PM,PB,分别代 表负大、负中、负小、零、正小、正中、正大。模糊控制规则具有如下形式:If(eisNB)and(

4、ecisNB)then(kpisPB)and(ki isNB)and(kdisPS)。由于e和ec都有7个子集元素,总共有49种自由组合,因此模糊控制总共有49条这样形式的规则。kp、ki、kd三个参数整定的模糊控制规则表如表2.1。kp的模糊控制规则表KpecNBNMNSZOPSPMPBeki的模糊控制规则表Kikd的模糊控制规则表Kd表2.1:模糊控制规则表2.2 模糊控制规则的实现2.2.1 隶属度1在模糊控制规则表中,各个元素子集都是用字母表示的,而在控制过程中,模糊判决器的输入和输出都是一些数值,因此需要在数值和各个语言变量之间建立联系。各个语言变量都表示一定的范围,这种范围的覆盖面

5、可以用隶属度来表示。隶属度函数有多种形状,有正态分布的,有等腰梯形的,最常用的是三角形,如图2.2所示。每个语言变量表示的范围可能有所 交叉,但除了几个特殊点,一个具体数值隶属于各个字母符号的程度是不一样的。图2.2:隶属度 模糊合成推理根据隶属度和模糊控制规则来修正PID参数:2.2.2 模糊推理2模糊判决器读取e和ec的具体数值,进行模糊推理,然后输出三个K的具体数值,有很多 算法。这里介绍一种强度转移法。所谓强度转移法,就是当控制系统有精确值输入时,精确值 在条件语句的前件中所得到的语言变量转移到后件的语言变量值去,从而得到推理结果的过 程。以kp的推理为例。步骤为:(1)前件强度的求取

6、为了简化而清晰地说明推理过程,我们假设误差e(k)及其变化率ec(k)分别最多对应2个语言变量值,设e(k)的两个语言变量值为A1、A2,且对模糊变量A1、A2的隶属度为uA1(e)、uA2(e),ec(k)的两个语言变量值为B1、B2,且对这两个模糊变量的隶属度为uB1(ec)、uB2(ec),控制规则如下:if e(k) is A1and ec(k) is B1then kp is C1 if e(k) is A1and ec(k) is B2 then kp is C2if e(k) is A2and ec(k) is B1 then kp is C3if e(k) is A2and e

7、c(k) is B2 then kp is C4从以上4条规则中,可产生出模糊推理的前件强度为:u1= uA1(e) uB1(ec) u2 = uA1(e) uB2(ec)u3= uA2(e) uB1(ec)u4= uA2(e) uB2(ec)(2)后件强度的求取由于在强度转移法中,是把精确值对前件的作用强度转移到后件中去,并作为后件模糊量kpi的隶属度,因此,依前件强度可得后件强度为:uC1 (kp1 ) = u1uC2 (kp2 ) = u2uC3 (kp3 ) = u3uC4 (kp4 ) = u4(3) 精确值kp的求取: 根据kp的语言变量值和隶属度的解读表达式求出kp1、kp2、k

8、p3、kp4。它们分别为C1、C2、C3和C4在隶属度为u1、u2、u3和u4时的推理结果元素,则利用重心法可求得: (2.1)当误差e(k)和误差变化率ec(k)具有多个语言变量值时,其推导过程与上述过程相似。 模糊推理中,在求解前件强度和后件强度时,对e,ec以及PID三个参数的描述,都是用名词来表示。这些名词不能互相包含,因此模糊控制的49条规则各不相同,缺一不可。3 动词PID控制器3.1 动词控制规则3.1.1 模糊规则的动词化 动词PID控制器的系统组成大部分与模糊PID控制器相似,在控制规则方面,动词PID控 制器相比模糊PID控制器做了改进。对e,ec以及PID三个参数的描述,

9、由名词变成动词。动词反映的是参数的变化趋势,这样一来,不同的名词组合,可以用相同的动词来表示。计算动词规则是对模糊规则进行提取,浓缩。把相同的变化趋势合并,可以减少规则数目。通过简化,用7条计算动词规则就可以涵盖49条模糊控制规则,应用于控制系统的各个阶段。3.1.2 动词规则4 动词种类繁多,为了规范化,方便地描述计算动词规则,可以只用一个动词(become)加名词和副词参数来替换所有动词。采用becomeadverb(noun1,noun2)的形式。比如“jump”可以表示成become fast(current,biggerthancurrent),stayhigh可以表示成become

10、(high,high)等 等。参数不一样,become所表示的动词效果就不一样。7条计算动词规则如下:其中Z、S、M、B分别代表zero、small、medium、big。(1)If(|e|become(Z,Z)then(kpbecome(S,B),ki become(B,S),kdbecome(S,B)(2)If(|e|become(B,M)then(kpbecomefast(B,S),ki becomefast(B,S),kdbecomefast(S,B)(3)If(|e|become(M,S)then(kpbecome(B,S),ki become(B,S),kdbecome(S,B)(

11、4)If(|e|become(S,Z)then(kpbecomeslow(B,S),kibecomeslow(B,S),kdbecomeslow(S,B)(5)If(|e|become(Z,S)then(kpbecomeslow(S,B),kibecomeslow(S,B),kdbecomeslow(B,S)(6)If(|e|become(S,M)then(kpbecome(S,B),ki become(S,B),kdbecome(B,S)(7)If(|e|become(M,B)then(kpbecomefast(S,B),ki becomefast(S,B),kdbecomefast(B,S

12、)3.2 动词相似度在控制过程中,e的变化大部分时间并不是完全等同于上述的某一个规则中的前件条件; 但反过来说,任一时刻,肯定能在上述七条规则的前件条件中中,找到一个和e的变化趋势最相似的become。用“动词相似度(similarities)”来恒量各个动词之间的关系。动词相似度是一个数值,取值范围0,1,相似度越接近1表示这两个动词相似的程度越大,相似度越接近0则表示越不相像。 在动词控制规则里,可以把前件条件里的7个动词定义为7个标准动词,控制过程中观察到的 动词都和这些标准动词做比较。动词推理的输出也定义成几个标准输出动词。3.2.1 基于进化函数的动词相似度的计算4上一节提到,所有动

13、词都可以用Become来进行规范化。在计算动词相似度之前,首先定 义Become的进化函数:(3.1)其离散时间形式为(假设Tw=wTs):(3.2)become(state1,state 2)的时间跨度取Tw,x(t)是观察到的波形,一个被观察的动词的进化函数:(3.3)t是当前时间,观察动词是从过去某个时间开始的。计算动词进化函数的构造需要 依赖以下两个因素:名词中心和物理语义学的动词中心。现在来求“observed”这个动 词和become(state1,state2)的相似度,首先把become(state1,state2)的开始时间定 在(tTw)时刻。求动词的相似度首先将Tw分成s

14、tate1和state2两个区间,再按以下几个步骤 进行运算。 1)在前半个区间求出a1和b1(3.4)2)在后半个区间求出a2和b2: (3.5)3)平衡因子e (3.6)4)在整个Tw范围内求相似度:(3.7)对观察到的动词取不同的隶属度,分两个区间分别与标准进化函数进行 “”和 “” 运算,不同的计算动词规则的相似度的求取中,用来与标准进化函数进行“” 和 “” 运算的被观察 动词的进化函数是不一样的,运算的结果进行积分,积分相当于求面积。将两个窗口“”的 面积相加,“”的面积也相加,相似度是 “” 的总面积与 “” 的总面积之比。这个比值越大,说明观察动词与标准动词的相似度越大。比如,

15、取state1=big,state2=medium,把观察动词的big、medium与标准进化函数进行 “”、 “”、积分、加法、除法运算之后,比值与其他规则的计算结果相比最大,则说明被观察动词与become(big,medium)最相似。3.2.2 简化的动词相似度5一个动词可以表示成Become(offset,offset+),即上一时刻位于offset位置,现在变化了 。一个观察到的动词与Become(offset,offset+ )求相似度,可分为两部分,一部分是变化趋势的相似度,另一部分是起始位置的相似度。3.2.2.1变化趋势的相似度一个观察到的动词与“增大”这个动词的相似度可以表

16、示成:(3.8)式中,x是一个运动对象相邻两个时间点上的位移差,即变化量;0是设定的一个标准 变化量;K在计算中是一个常量,在不同的场合可以取不同的值。0取0.5,K取6时,画出不同 的观察动词与增大0.5的相似度。如图3.2。这种动词相似度的求法适合于计算动词的(2)(7)号控制规则,不同的规则对应不同 的0和,求“增大”的相似度时,Kx的前面需要一个负号,求“减小”的相似度时,不 用负号。但这个算法不适合于求与“eBecome(Zero,Zero)”的相似度,因为当estayZero时,其0为0,而在式3.8中,0是一个分母,所以与这条规则相对应的动词相似度的求解采用另外一种算法。(3.9

17、)图3.2:动词与的相似度K取5时,观察到的不同动词与stayZero的相似度如图3.3。图3.3:3.2.2.2起始位置的相似度 观察到的动词的起始位置为offsetobserved,定义标准动词的起始位置为offset0,计算起始 位置的相似度我采用如下算法:(3.10)p取正偶数。当K=10,p=2,offset0=0.8(假设起始位置为big)时,画出不同的起始位置与起始 位置为big的相似度。如图3.4。图3.4:起始位置与big的相似度 起始位置的相似度与模糊隶属度函数有相似之处。3.3 动词控制规则的实现4计算动词规则的推理建立在动词相似度的基础上,在控制过程中,观察控制误差e的

18、变化 趋势,求出e和7个标准动词的相似度。控制器的输入和输出都是动词形式。控制规则是这样的:If(ebecome0i)Then(kVi),输出的动词Vy是7个标准输出动词Vi(i=17)以相似度为权的 加权平均量。(3.11)公式的形式与模糊推理强度转移法中重心法(式2.1)的形式有相似之处。这种加权平均的 算法符合控制需求,e的变化和哪个规则中的前件条件最相似,控制输出就和那个规则的K的 变化最相近。在求出k之后,PID三个参数的修正方式为:Knext =Kcurrent+k。4 用Simulink进行PID控制仿真4.1 炉温控制简介4.1.1 背景随着工业的快速发展,钢铁的需求量越来越大

19、。而对于生产钢铁的最重要的一环高炉的要求也越来越高。在钢铁的冶炼的过程中,越来越多地使用交流电弧炉设备,温度控制系统的性能直接影响到钢铁的质量,所以炉温控制占据重要的位置。PID控制是温度控制系统中一种典型的控制方式,是在温度控制中应用最广泛、最基本的一种控制方式。随着科学技术的发展,各行各业对温度控制精度的要求越来越高,经典PID在某些场合已经不能满足要求。因此,智能PID控制的引入时精密温度控制系统的发展趋势。为了改善电弧炉系统恒温控制质量的现状,研制具有快速响应的、经济性好的、适合国情的恒温控制装置具有十分重要的意义。4.1.2 系统函数高炉温度控制系统具有非线性、时变性、滞后性等特性。

20、根据实际测量,被控对象近似一阶惯性加滞后模型:(4.1)4.2 Simulink简介3Simulink是个交互式动态系统建模、仿真和分析图形环境,是一个进行基于模型的嵌入 式系统开发的基础开发环境。Simulink可以针对控制系统等进行系统建模、仿真、分析等工 作。Simulink提供了一个建立控制系统方框图,并对系统进行模拟仿真的环境。在Mablab6.5的命令主窗口中单击FileNewModel,即可打开如图4.1所示的Simulink模型编辑窗口。在Simulink模型编辑窗口中单击ViewLibrarybrowser,即可打开如图4.2所示 的Simulink库浏览窗口。根据控制系统的

21、结构,用户可以从模型库中选择所需要的各种模块,按要求连接、修改各 模块的参数,建立系统模型。图4.1:simulink模型编辑窗口图4.2:simulink库浏览器4.3 传统PID控制Simulink仿真4.3.1 建立系统模型在模型库中,从Simulink库Continuous子库中选择Derivative、Integrator、Transfer Fcn、Transport Delay模块,从MathOperations子库中选择Gain、Sum模块,Sinks子库中选择Scope,Sources子库中选择Step,放到模型编辑窗口。各个模块的属性都可通过双击该模块进行更改。按图4.1更改

22、各模块属性,连线,就建立了一个传统PID控制系统模型。其中Step阶跃信号幅值为1,TransportDelay为208秒。在模型编辑器中选择“start simulink”,就可以开始进行仿真。仿真波形可以双击scope进行观察。4.3.2 调试过程及结果 参数整定过程: (1)令ki和kd为0,调整kp。若kp太小,则控制结果无法向原定的控制目标靠近,kp增大,响 应曲线开始出现振荡。如果振荡的振幅呈增大趋势,系统将无法达到稳定。所以应该调整kp, 使响应看起来是一条振幅越来越小的曲线。 (2)观察振荡趋向的平衡位置,ki为0时,一般会存在静态误差。ki从0开始增大,调整ki,使响应曲线保

23、持在控制目标上下振荡。由于ki也加强了控制作用,所以kp应该基于第(1)步调出的值再往小调。一般通过合适的ki把振荡的平衡位置修正之后,不必再调ki了。(3)调整kd。kd能抑制响应曲线上下振荡的振幅,但kd过大,反而降低响应速度。最后对kp和ki进行联合微调。对式4.1所示的加热电源的温度的传统PID控制进行参数调整,我调整得效果最好的一组参数已标在图4.1中,即kp=18,ki=0.015,kd=1000。温度变化波形如图4.3。大约3000秒控制达到稳定,超调量30%。Simulink的Scope中的响应曲线原本是黑色背景,黄色曲线。为了便于浏览,本人做了一 些反色的处理,后面的图4.5

24、也进行了同样的处理,不再重复说明。图4.3:传统PID仿真4.4 模糊PID控制Simulink仿真4.4.1 在Matlab中建立模糊判决器 4.4.1.1 用FISEditor建立模糊判决器3在Matlab主窗口中输入fuzzy,弹出FIS Editor,这是一个新建的空白的FIS,如图2.3所示。解模糊算法默认是Mamdani法,如果要改变算法,Matlab提供的另一种算法为Sugeno。在新建FIS时,点击FileNew FISSugeno即可。图2.3:FIS Editor点击EditAdd variableinput(或output),添加判决器的输入和输出,我们使用的模糊PID判

25、决器是2个输入3个输出。把这5个变量(variable)的名字(Name)改成e、ec、kp、ki和kd。双击任一个variable ,弹出Membership Function Editor,可以设定这个variable 的取值范围(range)。如图2.4所示。新建的variable默认只有3个子集,在Membership Function Editor中点击EditAdd MFs ,添加子集,加到7个。按照模糊隶属度设定每个子集的名字(Name)、形状(Type)和覆盖范围(Params)。添加规则:在FIS Editor中点击EditRules,弹出Rule Editor。如图2.5所

26、示。新建的模糊判决器有0条规则,按照模糊控制规则表,使用Rule Editor底部的“添加规则(Add rule)”和“修改规则(Change rule)”按钮设定模糊控制的49条规则。先添加条数,再按规则修改。最后将该FIS保存,在FIS Editor中点击FileExportTo Disk,保存为fuzzpid.s 。图2.4:Membership Function Editor图2.5:Rule Editor4.4.1.2 用Matlab程序生成模糊判决器1用Matlab程序语言也能生成和上一节一模一样的fuzzpid.fis。 a=newfis(fuzzpid)。建立一个新的FIS,取名fuzzpid。escale=1。a=addvar(a,input,e,-3*escale,3*escale)。添加variable a=addmf(a,input,1,NB,zmf,-3*escale,-1*escale)。本行往下共7行分别添加MFsa=addmf(a,input,1,NM,trimf,-3*escale,-2*escale,0)。 a=addmf(a,inp

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1