1、xxx 科技大学本科生毕业设计 第 I 页一级倒立摆的 PID 控制设计摘 要本文主要研究的是一级倒立摆的 PID 控制问题,并用遗传算法对其 PID 的参数进行了优化。倒立摆是典型的快速、多变量、非线性、强耦合、自然不稳定系统。由于在实际中有很多类似于倒立摆的系统,因此对它的研究在理论上和方法论上均有深远的意义。本文首先简单地介绍了倒立摆以及倒立摆的控制方法,并对其参数优化算法做了分类介绍。然后,介绍了遗传算法的基本理论和操作方法。接着建立了一级倒立摆的数学模型,并求出其状态空间描述。本文主要采用遗传算法来对 PID 的参数进行优化,得到较好的 PID 参数。最后,用 Simulink 对系
2、统进行了仿真,验证了该方法的有效性,证明遗传算法是较为理想的参数优化方法。关键词:PID 控制器;倒立摆;遗传算法;MATLAB 仿真xxx 科技大学本科生毕业设计 第 II 页AbstractThis paper mainly studies the PID control problem of the single inverted pendulum and optimizes PID parameters with Genetic Algorithms. Inverted pendulum is a typical fast, multivariable, nonlinear, stro
3、ng-coupling and naturally unstable system. In reality there are many systems which are similar to inverted pendulum, so the research on it has profound significance both in theory and methodology. This paper first briefly introduces the inverted pendulum and the control methods of it, and makes a cl
4、assified introduction of the optimization algorithm of the parameters. The basic theory and the method of operation of the Genetic Algorithms are also introduced in this paper. Then the mathematical model of the single inverted pendulum is set up and works out the description of its state and space.
5、 This paper mainly adopts the Genetic Algorithms to optimize the parameters of PID, in order to get the better PID parameters. Finally, using Simulink to do simulation of the system verifies the validity of this method and certifies that Genetic Algorithms is a ideal optimization method of the param
6、eter.Keywords: PID controller; inverted pendulum; Genetic algorithm; MATLAB simulation xxx 科技大学本科生毕业设计 第 III 页目 录1 绪论 .11.1 倒立摆简介 .11.2 倒立摆的控制方法 .21.3 PID 控制器参数整定方法 31.4 本文的主要任务 .52 PID 简介 .62.1 PID 控制的基本原理 62.2 PID 控制器的参数整定 72.3 PID 控制的基本用途 82.4 PID 控制的重要意义 93 遗传算法的基本理论和基于遗传算法的 PID 参数寻优 .113.1 遗传算法
7、的基本原理 113.2 遗传算法的操作方法 133.2.1 二进制编码.133.2.2 适应度函数.133.2.3 遗传操作.153.3 遗传算法的应用关键 193.4 基于遗传算法的 PID 参数寻优 193.4.1 基于遗传算法的 PID 寻优优点 193.4.2 基于遗传算法的 PID 寻优方法 204 一级倒立摆的模型 224.1 一级倒立摆的物理模型 224.2 一级倒立摆的数学模型 225 直线一级倒立摆 PID 控制系统的设计及仿真 265.1 PID 控制器的设计 26xxx 科技大学本科生毕业设计 第 IV 页5.2 一级倒立摆系统的 SIMULINK模型及系统仿真 .265
8、.2.1 MATLAB 及 Simulink265.2.2 一级倒立摆系统的 Simulink 模型 265.2.3 仿真结果.275.3 小结 29结 论 .30致 谢 .31参考文献 32附 录 .33xxx 科技大学本科生毕业设计 第 1 页1 绪论1.1 倒立摆简介倒立摆控制系统是一个复杂的、不稳定的、非线性系统,是进行控制理论教学及开展各种控制实验的理想实验平台。对倒立摆系统的研究能有效的反映控制中的许多典型问题:如非线性问题、鲁棒性问题、镇定问题、随动问题以及跟踪问题等。通过对倒立摆的控制,用来检验新的控制方法是否有较强的处理非线性和不稳定性问题的能力。通过对它的研究不仅可以解决控
9、制中的理论和技术实现问题,还能将控制理论涉及的主要基础学科:力学、数学和计算机科学进行有机的综合应用。其控制方法和思路无论对理论或实际的过程控制都有很好的启迪,是检验各种控制理论和方法的有效的“试金石” 。倒立摆的研究不仅有其深刻的理论意义,还有重要的工程背景。在多种控制理论与方法的研究与应用中,特别是在工程实践中,也存在一种可行性的实验问题,使其理论与方法得到有效检验,倒立摆就能为此提供一个从理论通往实践的桥梁,目前,对倒立摆的研究已经引起国内外学者的广泛关注,是控制领域研究的热门课题之一。倒立摆不仅仅是一种优秀的教学实验仪器,同时也是进行控制理论研究的理想实验平台。由于倒立摆系统本身具有的
10、高阶次、不稳定、多变量、非线性和强耦合特性,许多现代控制理论的研究人员一直将它视为典型的研究对象,不断从中发掘出新的控制策略和控制方法,相关的科研成果在航天科技和机器人学方面获得了广阔的应用 1。二十世纪九十年代以来,更加复杂多种形式的倒立摆系统成为控制理论研究领域的热点,每年在专业杂志上都有大量的优秀论文出现。因此,倒立摆系统在控制理论研究中是一种较为理想的实验装置。倒立摆主要应用在以下几个方面:(1) 机器人的站立与行走类似于双倒立摆系统,尽管第一台机器人在美国问世至今已有三十年的历史,机器人的关键技术机器人的行走控制至今仍未能很好解决。(2) 在火箭等飞行器的飞行过程中,为了保持其正确的
11、姿态,要不断进行实时控制。(3) 通信卫星在预先计算好的轨道和确定的位置上运行的同时,要保持其稳定的姿xxx 科技大学本科生毕业设计 第 2 页态,使卫星天线一直指向地球,使它的太阳能电池板一直指向太阳。(4) 侦察卫星中摄像机的轻微抖动会对摄像的图像质量产生很大的影响,为了提高摄像的质量,必须能自动地保持伺服云台的稳定,消除震动。(5) 为防止单级火箭在拐弯时断裂而诞生的柔性火箭(多级火箭),其飞行姿态的控制也可以用多级倒立摆系统进行研究。由于倒立摆系统与双足机器人、火箭飞行控制和各类伺服云台稳定有很大相似性,因此对倒立摆控制机理的研究具有重要的理论和实践意义。1.2 倒立摆的控制方法倒立摆
12、有多种控制方法 2。对倒立摆这样的一个典型被控对象进行研究,无论在理论上和方法上都具有重要意义。不仅由于其级数增加而产生的控制难度是对人类控制能力的有力挑战,更重要的是实现其控制稳定的过程中不断发现新的控制方法,探索新的控制理论,并进而将新的控制方法应用到更广泛的受控对象中。当前,倒立摆的控制方法可分为以下几类 :(1) 线性理论控制将倒立摆系统的非线性模型进行近似线性化处理,获得系统在平衡点附近的线性化模型,然后再利用各种线性系统控制器设计方法,得到期望的控制器。PID控制、状态反馈控制、能量控制、LQR控制算法是其典型的代表。(2) 预测控制预测控制:是一种优化控制方法,强调的是模型的功能
13、而不是结构。变结构控制:是一种非连续控制,可将控制对象从任意位置控制到滑动曲面上仍然保持系统的稳定性和鲁棒性,但是系统存在颤抖。预测控制、变结构控制和自适应控制在理论上有较好的控制效果,但由于控制方法复杂,成本也高,不易在快速变化的系统上实时实现。(3) 智能控制智能控制(IC) 是一门新型的理论和技术,是传统控制的高级阶段,主要用来解决复杂系统的控制。近几年来国内外对智能控制的理论和应用研究十分活跃。随着智能控制技术的迅速发展,已提出了许多方法,如模糊控制、神经网络、专家系统、遗传算法等。xxx 科技大学本科生毕业设计 第 3 页(4) 多种算法相结合的控制尽管各类算法有自己的优点,但也存在
14、不足之处。多种算法相结合就可以取长补短,达到更好的控制效果。比如神经网络与模糊算法相结合、模糊控制与PID算法相结合、免疫算法和遗传算法相结合等。1.3 PID 控制器参数整定方法PID控制是工业过程控制中应用最广的策略之一,因此PID控制器参数的优化成为人们关注的问题,它直接影响控制效果的好坏,并和系统的安全、经济运行有着密不可分的关系。PID控制器作为最早实用化的控制器已有50多年历史,现在仍然是应用最广泛的工业控制器。PID控制器简单易懂,使用中不需精确的系统模型等先决条件,因而成为应用最为广泛的控制器。PID控制器由比例单元(P)、积分单元(I)和微分单元(D) 组成。其输入 与输出)
15、(te的关系为:)(tu(1.1)1()()()()pdetutKettTi式中积分的上下限分别是 和 ,因此它的传递函数为: 0t(1.2)()1pdiUsGKTsE式中: PK为 PID 控制器的放大系数;iT为 PID 控制器的积分时间常数;d为 PID 控制器的微分时间常数。目前PID参数的优化方法有很多种 3,如:单变量的寻优技术分割法、插值法等,多变量的寻优技术梯度法、单纯形法等。虽然两者都具有良好的寻优特性,但却存在着一些弊端,梯度法由于每步都需要计算目标函数的梯度,所以要求目标函数连续可导,该法计算繁琐费时;单纯形法对于变量较多,目标函数形态比较复杂的情况则收敛慢,同时对初值比
16、较敏感,容易陷入局部最优解,造成寻优失败。虽然传统的优化方法存在着一些弊端,但仍是现场人员常用的方法,它们同样具有较高的研xxx 科技大学本科生毕业设计 第 4 页究价值。下面介绍几种PID优化算法:(1) 临界比例度法临界比例度法又称稳定边界法,是目前应用较广的一种控制参数整定的方法。临界比例度就是先让控制器在纯比例作用下,通过现场试验找到等幅震荡的过渡过程,记下此时的比例度和等幅振荡周期,再通过简单的计算求出衰减振荡时控制器的参数。(2) 经验凑试法此时是根据经验先将控制器的参数放在某一数值上,直接在闭环控制系统中,通过改变设定值施加干扰试验信号,在记录仪上看被控量的过渡过程曲线形状,控制
17、器参数凑试的顺序有两种方法:一种认为比例作用是基本的控制作用,因此,首先把比例度凑试好,待过渡过程已基本稳定,然后加积分作用以消除余差,最后加入微分作用以进一步提高控制质量。另一种整定顺序的出发点是:比例度与积分时间在一定范围内相匹配,可以得到相同递减比的过渡过程。这样比例度的减小可用增大积分时间来补偿,反之亦然。所以要预先确定一个积分时间数值,然后由大到小调整比例度以获得满意的过渡过程。(3) 专家控制专家系统 4是一类包含着知识和推理的智能计算机程序,其内部包含有大量的某个领域专家水平的知识和经验,能够利用人类专家的知识和解决问题的方法来处理该领域的问题。专家控制的实质是基于受控对象和控制
18、规律的各种知识,以智能的方式来利用这些知识,求得受控系统尽可能地优化和实用化,它反映出智能控制的许多重要特征和功能。随着微机技术和人工智能技术的发展,出现了多种形式的专家控制器。人们自然地也想到用专家经验来建立PID参数,其中最经典的是1984年美国FOXBORO公司推出的EXACT专家式自整定控制器,将专家系统技术应用于PID控制器 5。通常,一个以规则为基础,以问题求解为中心的专家系统由知识库、推理机、综合数据库、解释接口和知识获取五部分组成。简单地讲,知识库就是领域知识的存储器。数据库用来存放用户提供的事实和由推理机得到的中间结果。这部分的内容是随时变化的,因此它不同于一般意义上的“数据
19、库” 。推理机实质上就是计算机的一组程xxx 科技大学本科生毕业设计 第 5 页序,目的是用于控制、协调整个专家系统的工作。解释接口又称为人机界面。知识获取是将某个领域内的事实性知识和领域专家所特有的经验性知识转化为计算机程序的过程。利用专家系统对PID控制参数进行优化包括四个过程。即:系统控制性能的判别,过程响应曲线的特征识别,控制参数调整量的确定以及PID控制参数的修改等。(4) 粒子群算法粒子群算法 6是由 Kennedy 和 Eberhart 等 1995 年提出的一种演化计算算 法。它是对鸟群觅食过程中的迁徙和聚集的模拟,更确切地说,是由简单个体组成的群落与环境以及个体之间的互动行为
20、。该模拟系统利用局部信息,从而可能产生不可预测的群体行为。目前已广泛应用于函数优化、神经网络训练和模糊系统控制等领域。该算法与其他进化算法相似,也是基于群体的迭代算法。粒子在解空间追随最优的粒子进行搜索,类似梯度下降算法使各染色体向适应度函数最优的方向群游。(5) 遗传算法遗传算法是模拟达尔文生物进化论的自然选择和遗传学机理的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法,它最初由美国 Michigan 大学 J.Holland 教授于 1975 年首先提出来的,并出版了颇有影响的专著 Adaptation in Natural and Artificial Systems
21、 ,GA 这个名称才逐渐为人所知,J.Holland 教授所提出的遗传算法(GA)通常为简单遗传算法(SGA) 7。遗传算法具有很强的寻优能力,能够解决各类复杂的优化问题,且具有广泛的适应性和优良的鲁棒性。其应用前景十分广阔。根据遗传算法的特点,只要将控制器的参数构成基因型,将性能指标构成相应的适应度,便可利用遗传算法来整定控制器的最佳参数,并不要求系统是否为连续可微。GA 采用纯数值计算方法和随机进化策略,无需梯度信息,能有效解决困难的优化问题,处理问题具有灵活性、适应性、鲁棒性、全局性,不仅提高了设计的品质而且降低了设计的难度。1.4 本文的主要任务本论文的主要任务是研究直线型一级倒立摆的
22、 PID 控制问题。主要设计思想是通过倒立摆的摆干的位置反馈给系统,从而作出参数调整,使之达到期望的结果。首先,通过牛顿力学的分析和微分方程的计算,初步建立一级倒立摆的数学模型,xxx 科技大学本科生毕业设计 第 6 页并计算出一级倒立摆的状态空间描述。然后,在给定的目标函数下,利用遗传算法的原理和搜索最优参数的方法,实现PID 控制器参数整定与优化,这是一种寻求全局的优化方法,且无需对目标函数微分,可提高参数优化水平,简化优化的解析计算过程。最后,结合 MATLAB 遗传算法工具箱对给定的一级倒立摆系统进行仿真,并对其结果分析。xxx 科技大学本科生毕业设计 第 7 页2 PID 简介2.1
23、 PID 控制的基本原理工 程 实 际 中 , 将偏差的比例(Proportion)、积分(Integral)和微分(Differential)通过线性组合构成控制量,用这一控制量对被控对象进行控制,这样的控制器称 PID 控制器。简 称 PID 控 制 , 又 称 PID 调 节 8。 其 系 统 基 本 原 理 结 构 如 图 所 示 :图 2.1 PID 控 制 系 统 原 理 结 构 图PID 控制器各校正环节的作用如下:a)比例环节。即成比例地反映系统的偏差信号,偏差一旦产生,控制器立即产生控制作用,以减小偏差。控制作用的强弱取决于比例系数 Kp,比例系数 Kp 越大,控制作用越强,
24、过渡过程越快,静态偏差也就越小;但 Kp 越大,也越容易产生振荡,破坏系统的稳定性。故 Kp 选择必须恰当,才能过渡时间少,静差小而又稳定的效果。b)积分环节可以消除系统稳态误差,但也会降低系统的响应速度,增加系统的超调量。Ti 越大,积分的积累作用越弱,这时系统在过渡时不会产生振荡,但是增大积分常数会减慢静态误差的消除过程,消除偏差所需的时间也较长,但可以减少超调量,提高系统的稳定性。当 Ti 较小时,则积分的作用较强,这时系统过渡时间中有可能产生振荡,不过消除偏差所需的时间较短。所以必须根据实际控制的具体要求来确定 Ti。c)积分环节微分环节的作用使阻止偏差的变化。它是根据偏差的变化趋势进
25、行控制。偏差变化的越快,微分控制器的输出就越大,并能在偏差值变大之前进行修正。微分作用的引入,将有助于减小超调量,克服振荡,使系统趋于稳定,特别对高阶系统非常有利,xxx 科技大学本科生毕业设计 第 8 页它加快了系统的跟踪速度。但微分的作用对输入信号的噪声很敏感,对那些噪声较大的系统一般不用微分,或在微分起作用之前先对输入信号进行滤波。微分部分的作用由微分时间常数Td 决定。 Td 越大时,则它抑制偏差 e(t)变化的作用越强;Td 越小时,则它反抗偏差e(t)变化的作用越弱。适当地选择微分常数Td ,可以使微分作用达到最优。PID算法蕴涵了动态控制过程中过去、现在和将来的主要信息,而且其配
26、置几乎最优。比例(P)代表了当前的信息,起纠正偏差的作用,使过程反应迅速。微分 (D)在信号变化时有超前控制作用,代表了将来的信息。在过程开始时强迫过程进行,过程结束时减小超调,克服振荡,提高系统的稳定性,加快系统的过渡过程。积分(I)代表了过去积累的信息,它能消除静差,改善系统静态特性。此三作用配合得当,可使动态过程快速、平稳、准确,收到良好的效果。PID 控 制 器 问 世 至 今 已 有 近 70 年 历 史 , 它 以 其 结 构 简 单 、 稳 定 性 好 、 工 作 可靠 、 调 整 方 便 而 成 为 工 业 控 制 的 主 要 技 术 之 一 。 当 被 控 对 象 的 结 构
27、 和 参 数 不 能 完 全掌 握 , 或 得 不 到 精 确 的 数 学 模 型 时 , 控 制 理 论 的 其 它 技 术 难 以 采 用 时 , 系 统 控 制 器的 结 构 和 参 数 必 须 依 靠 经 验 和 现 场 调 试 来 确 定 , 这 时 应 用 PID 控 制 技 术 最 为 方 便。 即 当 我 们 不 完 全 了 解 一 个 系 统 和 被 控 对 象 , 或 不 能 通 过 有 效 的 测 量 手 段 来 获 得 系统 参 数 时 , 最 适 合 用 PID 控 制 技 术 。 PID 控 制 实 际 中 也 有 PI 和 PD 控 制 。2.2 PID 控制器的
28、参数整定PID 控制器的参数整定是控制系统设计的核心内容。它是根据被控过程的特性确定 PID 控制器的比例系数、积分时间和微分时间的大小。PID 控制器参数整定的方法很多,概括起来有两大类:一是理论计算整定法。它主要是依据系统的数学模型,经过理论计算确定控制器参数。这种方法所得到的计算数据未必可以直接用,还必须通过工程实际进行调整和修改。二是工程整定方法,它主要依赖工程经验,直接在控制系统的试验中进行,且方法简单、易于掌握,在工程实际中被广泛采用。PID 控制器参数的工程整定方法,主要有临界比例法、反应曲线法和衰减法。三种方法各有其特点,其共同点都是通过试验,然后按照工程经验公式对控制器参数进
29、行整定。但无论采用哪一种方法所得到的控制器参数,都需要在实际运行中进行最后调整与完善。现xxx 科技大学本科生毕业设计 第 9 页在一般采用的是临界比例法。利用该方法进行 PID 控制器参数的整定步骤如下:(1) 首先预选择一个足够短的采样周期让系统工作;(2) 仅加入比例控制环节,直到系统对输入的阶跃响应出现临界振荡,记下这时的比例放大系数和临界振荡周期;(3) 在一定的控制度下通过公式计算得到 PID 控制器的参数。通常 PID 调节器的参数是由人工进行整定的。由于 PID 三个参数互相关联,因此PID 参数的整定并非是一件容易的事,尤其当一个过程的控制需要几百个调节器参加控制时,参数的整
30、定不仅花费时间,而且也不容易校正合适。另外,这种人工整定的方法也无法适应一些复杂系统,如时变系统、扰动噪声大的系统,非线性系统等 9。随着控制要求的提高以及控制理论技术的发展,出现了许多智能 PID 控制器和新算法,因此,对 PID 参数的整定将会出现许多先进方法。 2.3 PID 控制的基本用途它由于用途广泛、使用灵活,已有系列化产品,使用中只需设定三个参数( , Kp和 )即可。在很多情况下,并不一定需要全部三个单元,可以取其中的一到两个Tid单元,但比例控制单元是必不可少的。首先,PID 应用范围广。虽然很多工业过程是非线性或时变的,但通过对其简化可以变成基本线性和动态特性不随时间变化的
31、系统,这样 PID 就可以控制了。其次,PID 参数较易整定。也就是说 PID 参数 , 和 可以根据过程的动态KpTid特性及时整定。如果过程的动态特性变化,例如可能由负载的变化引起系统动态特性变化,PID 参数就可以重新整定。第三,PID 控制器在实践中也不断的得到改进,下面就是两个改进的例子。在工厂,总是能看到许多回路都处于手动状态,原因是很难让过程在“自动”模式下平稳工作。由于这些不足,采用 PID 的工业控制系统总是受产品质量、安全、产量和能源浪费等问题的困扰。PID 参数自整定就是为了处理 PID 参数整定这个问题而产生的。现在,自动整定或自身整定的 PID 控制器已是商业单回路控
32、制器和分散控制系统的一个标准。在一些情况下针对特定的系统设计的 PID 控制器控制得很好,但它们仍存在一些问题需要解决:xxx 科技大学本科生毕业设计 第 10 页如果自整定要以模型为基础,为了 PID 参数的重新整定在线寻找和保持好过程模型是较难的。闭环工作时,要求在过程中插入一个测试信号。这个方法会引起扰动,所以基于模型的 PID 参数自整定在工业应用不是太好。如果自整定是基于控制律的,经常难以把由负载干扰引起的影响和过程动态特性变化引起的影响区分开来,因此受到干扰的影响控制器会产生超调,产生一个不必要的自适应转换。另外,由于基于控制律的系统没有成熟的稳定性分析方法,参数整定可靠与否存在很
33、多问题。因此,许多自身整定参数的 PID 控制器经常工作在自动整定模式而不是连续的自身整定模式。自动整定通常是指根据开环状态确定的简单过程模型自动计算 PID 参数。PID 在控制非线性、时变、耦合及参数和结构不确定的复杂过程时,工作地不是太好。最重要的是,如果 PID 控制器不能控制复杂过程,无论怎么调参数都没用。虽然有这些缺点,但 PID 控制器是最简单的有时却是最好的控制器。2.4 PID 控制的重要意义自蒸汽机调速机采用比例控制以来,工业过程的自动控制理论和技术已经有很大的发展,特别是现代控制理论和微处理技术的发展,更促进了工业自动化的发展。尽管如此,工业过程控制的基础仍离不开 PID
34、 技术。曾有调查结果表明:在当时使用的控制方式中,PID 型占 84.5%、优化 PID 型占 6.8%。现代控制型占 1.6%,手动控制型占 6.6%,人工智能(AI)型占 0.6%。如果把 PID 型和优化 PID 型两者加起来,则占 90%以上。这说明 PID 控制方式占绝大多数。随着工业现代化的发展和其它各种先进技术的发展,自动化技术将会有更加新的发展。但是,可以毫不夸张地说,PID 控制技术仍然不过时,它还是占据着主导地位 10。迄今为止,PID 控制技术是最通用的控制方法。在现代工业过程控制中,目前采用最多的控制方式依然是 PID 方式,即使在工业较先进的国家,PID 控制的使用率
35、也达到 84.5%。这一方面是由于 PID 控制器具有简单而固定的形式,在很宽的操作条件范围内都能保持较好的鲁棒性;另一方面是因为 PID 控制器允许工程技术人员以一种简单而直接的方式来调节系统 11。 虽然 PID 控制器产生于 19 世纪初,其后许多先进的控制方法也不断推出,但由于xxx 科技大学本科生毕业设计 第 11 页其结构简单、可靠性较高、具有一定鲁棒性及易于操作等优点,仍被广泛应用于化工、冶金、电力、机械、航天等工业过程控制中。目前全世界大约有 90的过程控制仍在使用 PID 控制器及其改进型来完成反馈回路的控制 12。随着计算机技术和现代控制理论的发展,许多新型算法的实现成为可
36、能。这些算法在理论上已被证明优于传统的 PID 控制算法。然而,在实际的工业过程中,占主导地位的控制器还是 PID 控制器,高级控制算法的应用十分有限,它的优越性也得不到充分的体现。原因主要有:1) PID 控制器已经成为过程控制领域的一种标准控制器;从工程观点看,PID 控制器不需要精确的数学模型;2) PID 控制参数的物理意义清楚;3) PID 控制器容易在线调整 13。xxx 科技大学本科生毕业设计 第 12 页3 遗传算法的基本理论和基于遗传算法的 PID 参数寻优3.1 遗传算法的基本原理遗传算法(Genetic Algorithms) ,简称GA ,是一类借鉴生物界自然选择和自然
37、遗传机制的随机优化搜索算法,是一种近似算法 14。既然遗传算法效仿于自然选择的生物进化,是一种模仿生物进化过程的随机方法。下面给出几个生物学的基本概念与术语,这对于理解遗传算法是非常重要的。染色体:是遗传物质的主要载体,由多个遗传因子基因组成。遗传因子:染色体中一定位置的基本遗传单位,也称基因。基因型:遗传因子组合的模型,是性状染色体的内部表现。表现型:由染色体决定性状的外部表现。基因座:遗传基因在染色体中占据的位置。等位基因:同一基因座它可能有的全部基因称为等位基因。个体:指染色体带有特征的实体。种群:染色体带有特征的个体组成了种群。群体中个体数目大小称为群体大小,也叫群体规模。适应度:各个
38、体对环境适应程度。选择:指决定以一定概率从种群中选择若干个体的操作。一般而言选择过程是一种基于适应度的优胜劣汰的过程。交叉:两个染色体之间通过交叉而重组形成新的染色体。变异:染色体的某一基因发生变化,产生新的染色体,表现出新的性状。编码:遗传编码可看成是从表现型向基因型的映射。解码:是基因型向表现型的映射。引用了这些术语,可以更好的描述遗传算法,遗传算法也就是从代表问题的可能潜在解集的一个种群出发,而一个种群则由基因编码的一定数目个体组成。每个个体其实是染色体带有特征的实体。染色体作为遗传物质的主要载体,即多个基因的集合,其内部表现是某种基因的组合,它决定了个体的外部表现形状。因此,在一开始要
39、实现从表现型到基因型的编码工作。由于仿照基因编码工作很复杂,往往采取简化形式,xxx 科技大学本科生毕业设计 第 13 页如二进制编码,初代种群产生后,按照适者生存和优胜劣汰的原理,逐代演化出越来越好的近似解。在每一代,根据问题域中个体的适应度大小选择个体。并借助于自然遗传学的遗传算子进行组合交叉和变异产生出代表新的解集的种群。这个过程将导致种群象自然进化一样,后生代种群比前代更加适应于环境,末代种群的最优个体经过解码,可以作为问题的近似最优解。下面是简单遗传算法的求解步骤:1)初始化种群;2)计算种群上每个个体的适应度值;3)按由个体适应度值所决定的某个规则将进入下一代的个体;4)按概率 P
40、c 进行交叉操作;5)概率 Pc 进行突变操作;6)没有满足某种停止条件,则转第 2)步,否则进入 7) ;7)输出种群中适应度值最优的染色体作为问题的满意解或最优解。程序的停止条件有两个:完成了预定的进化代数;种群中的最优个体在连续若干代没有改进或平均适应度在连续若干代基本没有改进。遗传算法流程如图 3.1 所示:图 3.1 遗传算法结构图xxx 科技大学本科生毕业设计 第 14 页3.2 遗传算法的操作方法3.2.1 二进制编码在遗传算法中如何描述问题的可行解,即把一个问题的可行解从其解空间转换到遗传算法所能处理的搜索空间的转换方法称为编码。编码是应用遗传算法时要解决的首要问题,也是设计遗
41、传算法时的一个关键步骤。编码方法除了决定了个体的染色体排列形式之外,它还决定了个体从搜索空间的基因型变换到解空间的表现型时的译码方法,编码方法也影响到交叉操作数、变异操作数等遗传操作数的运算方法。由此可见,编码方法在很大程度上决定了如何进行群体的遗传进化运算以及遗传算法进化计算的效率。好的编码方法,有可能会使得交叉运算、变异运算等遗传操作可以简单的实现和执行。遗传算法编码方式有多种形式,本文采用适用于多种问题的一类多变量二进制编码形式。二进制编码是遗传算法中最常用的一种编码方法,它使用的编码符号集是由二进制符号 0 和 1 所组成的二值符号集0 ,1 ,它所构成的个体基因型是一个二进制编码符号
42、串。二进制编码符号串的长度与问题所要求的求解精度有关。参数的二进制字符串表示值和实际值之间的关系为:(3.1)12minaxminba其中,bin 是参数 a 的二进制编码; 是参数 a 的取值范围,n 为二进制编码的,inax长度,总共能够产生 种不同的编码。n23.2.2 适应度函数在研究自然界中生物的遗传和进化现象时,生物学家使用适应度这个术语来度量某个物种对于其生存环境的适应程度。遗传算法中也使用适应度这个概念来度量群体中各个个体在优化计算中有可能达到或接近于或有助于找到最优解的优良程度。适应度较高的个体遗传到下一代的概率就较大;而适应度较低的个体遗传到下一代的概率就相对小一些。度量个
43、体适应度的函数称为适应度函数(Fitness Function)。因此,适应度函数的确定直接关系到遗传算法的寻优效率以及效果。1.适应度函数的作用在选择操作时会出现以下问题:xxx 科技大学本科生毕业设计 第 15 页(1) 在遗传进化的初期,通常会产生一些超常的个体,若按照比例选择法,这些异常个体因竞争力太突出而控制了选择过程,影响算法的全局优化性能。(2) 在遗传进化的后期,即算法接近收敛时,由于种群中个体适应度差异较小时,继续优化的潜能降低,可能获得某个局部最优解。上述问题,通常称为遗传算法的欺骗问题。适应度函数设计不当,可能造成这种问题的出现,因此适应度函数的设计是遗传算法设计的一个重
44、要方面。2.适应度函数的设计适应度函数设计主要满足以下条件:(1) 单值、连续、非负、最大化。(2) 合理、一致性的要求适应度值反映对应解的优劣程度,这个条件的达成往往比较难以衡量。(3) 计算量小的适应度设计应尽可能简单,这样可以减少计算时间和空间上的复杂性,降低计算成本。(4) 通用性强的适应度对某类具体问题,应尽可能通用,最好无需使用者改变适应度函数中的参数。衡量控制系统的性能可用稳定性、可控性、可观性、稳态特性和动态特性来表征,用稳定裕量、稳态指标、动态指标以及综合指标评价。在控制系统中,由于其本身特有的惯性、滞后等特点,一般采用偏差积分指标来衡量控制系统性能的优良程度。偏差积分指标是
45、过渡过程中被调节量偏离其新稳态值的偏差沿时间轴的积分。无论是偏差幅度大,还是过渡过程时间长,都会使得误差积分指标增大。因此,偏差积分指标是一类综合指标,希望越小越好。常用的偏差积分指标如下:1) 误差积分:(3.2)0)(dteIE2) 误差平方和积分:(3.3)02)(teIS这种性能指标着重权衡大的偏差,在大的起始偏差时有迅速减小偏差的倾向,因此系统响应速度快,有振荡,超调量大,稳定性较差。xxx 科技大学本科生毕业设计 第 16 页3) 平方误差的矩的积分:(3.4)02)(dte4) 平方误差的二阶矩的积分:(3.5)02)(tet5) 绝对误差的积分:(3.6)0)(dteIAE该性
46、能指标是一种容易应用的指标,其最佳性能时,表明系统具有适当的阻尼和令人满意的瞬态响应,因此系统将有较快的输出响应,超调量略大。6) 绝对误差的矩的积分:(3.7)0)(dteITAE这是绝对误差积分指标的一种改进,它对阶跃响应的起始的大的偏差考虑较少,而是着重权衡瞬间响应后期的偏差。该指标的特点是瞬态响应超调量小,振荡有足够阻尼。7) 绝对误差的一阶矩的积分:(3.8)02)(dtet采用不同的积分公式意味着估计整个过渡过程优良程度的侧重点不同。控制系统的设计往往也要求同时满足多个性能指标,这些性能指标可能包括优化目标和对系统性能的约束条件等,是根据对控制系统的要求预先给定的。有时候,这些指标
47、之间往往含有相互矛盾的因素,由于控制目标具有一定的模糊性,约束指标常常也存在着一定的柔性。在一定条件下难以满足较高的性能指标时,适当放宽要求,对整个控制系统可能是有利的。性能指标的设计本身就是控制系统设计中的一个重要环节。无论是对系统性能指标的“硬约束”或“软性能期望” ,都可以统一地通过定义一个满意度函数方式描述,以综合满意度函数反映对系统总体性能的综合评价,只是具体的函数形式的区别。3.2.3 遗传操作遗传操作是模拟生物基因遗传的操作,在遗传算法中,通过编码组成初始群体后,xxx 科技大学本科生毕业设计 第 17 页遗传操作的任务就是对群体的个体,按照它们环境适应程度施加一定操作,从而实现
48、优胜劣汰的进化过程,从优化搜索而言,遗传操作可使问题的解,一代又一代的优化,并逼近最优解。简单遗传算法的遗传操作包含三个基本遗传算子:选择(Selection)、交叉(Crossover)、变异(Mutation) 。这三个遗传算子有如下特点:这三个遗传算子的操作都是在随机扰动情况进行,换句话说,遗传操作是随机操作,因此群体中个体向最优解迁移的规则是随机的。遗传操作效果和上述三个遗传算子所取操作概率、编码方法、群体大小、初始群体以及适应度函数设定密切相关。三个基本遗传算子的操作方法或操作策略随具体求解问题的不同而相异,更具体地讲,是与个体的编码方式直接相关。1.选择从群体中选择优胜个体,淘汰劣质个体的操作叫选择。选择算子有时又称为再生算子。选择的目的是把优胜的个体直接传到下一代或通过交叉配对再遗传到下一代。选择操作是建立在群体中个体适应度评估的基础之上,即个体适应度越高,其被选择的机会就越多,日前常用的选择算子有:适应度比例方法、最优保留法、期望值方法、排序选择方法、联赛选择方法、排挤方法。选择过程的第一步是计算适应度。被选择的每个个体具有一个选择概率,这个概率取决于种群中个体的适应度及其分布。按比例分配的适应度分配是个体选择概率的常用分配方法。按比例分配的适应度分配,可称为蒙特卡罗法,是利用比例于各个个体适应度的概率决定其子