【精品PPT】数学建模专题之遗传算法.ppt
《【精品PPT】数学建模专题之遗传算法.ppt》由会员分享,可在线阅读,更多相关《【精品PPT】数学建模专题之遗传算法.ppt(100页珍藏版)》请在三一办公上搜索。
1、数学建模专题之遗传算法,重庆理工大学主讲:肖汉光Email:,Contents,Contents of Section 1,1.4,什么是遗传算法,1.1,1.2,1.3,遗传算法的特点,遗传算法的发展历程,遗传算法的研究和应用领域,1 遗传算法概述,1 遗传算法概述,1.1 遗传算法(Genetic Algorithm,GA)一种仿生全局优化算法模仿生物的遗传进化原理(Darwins theory of evolution&Mendels law of inheritance),通过选择(Selection)、交叉(Crossover)与变异(Mutation)等操作机制,使种群中个体的适应
2、性(Fitness)不断提高核心思想:物竞天择,适者生存(“天”适应度函数,Fitness Function),1 遗传算法概述,1.2 遗传算法的特点四大优点:良好的并行性(操作对象是一组可行解;搜索轨道有多条)强大的通用性(只需利用目标的取值信息,无需梯度等高价值信息)良好的全局优化性和鲁棒性良好的可操作性两个缺点:未成熟收敛问题收敛速度较慢,算法实时性欠佳,1 遗传算法概述,1.3 遗传算法的发展历史,表1.1 遗传算法理论的经典研究成果,第一阶段:20世纪60年代至70年代中期(萌芽期),1 遗传算法概述,续表1.1,1 遗传算法概述,续表1.1,第二阶段:20世纪80年代(蓬勃发展期
3、),1 遗传算法概述,1.4 遗传算法的应用领域,(1)函数优化(经典应用)(2)组合优化(旅行商问题已成为衡量算法优劣的标准、背包问题、装箱问题等)(3)生产调度问题(4)自动控制(如航空控制系统的优化设计、模糊控制器优化设计和在线修改隶属度函数、人工神经网络结构优化设计和调整人工神经网络的连接权等优化问题)(5)机器人智能控制(如移动机器人路径规划、关节机器人运动轨迹规划、机器人逆运动学求解等)(6)图像处理和模式识别(如图像恢复、图像边缘特征提取、几何形状识别等)(7)机器学习(将GA用于知识获取,构建基于GA的机器学习系统),此外,遗传算法在人工生命、遗传程序设计、社会和经济领域等方面
4、的应用尽管不是很成熟,但还是取得了一定的成功。在日后,必定有更深入的发展。,Hotspot,Contents of Section 2,2.4,遗传算法的生物学基础,2.1,2.2,2.3,2.5,遗传算法的基本流程,遗传算法的若干基本概念,遗传算法的应用步骤,欺骗问题和未成熟收敛问题,2 标准遗传算法,2.1 遗传算法的生物学基础,细胞(Cell),染色体(Chromosome),脱氧核糖核酸(Deoxyribonucleic Acid,DNA),基因(Gene)、等位基因(Allele),基因型(Genotype),表现型(Phenotype),复制(Reproduction),交叉(Cr
5、ossover),变异(Mutation),对环境的适应性,“种瓜得瓜,种豆得豆”,2 标准遗传算法,2.1 遗传算法的生物学基础,个体(Individual),种群(Population),适应度(Fitness),进化(Evolution),生存(Survival),Low,High,“物竞天择,适者生存”,死亡(Death),灭绝(Extinction),2 标准遗传算法,2.2 标准遗传算法的基本流程,实际问题参数集,参数编码成为染色体,初始化群体,计算每一个体的适应度,对染色体进行解码,满足终止条件?,得到问题最优解,进行遗传操作,群体新群体P(t)P(t+1),1、选择,2、交叉,
6、3、变异,2 标准遗传算法,2.3 遗传算法的若干概念个体(Individual)称 为个体空间,个体空间的元素 称为个体,它是染色体带有特征的实体。分量 称为基因,正整数 称为个体的基因长度。,种群(Population)称个体空间S中N个个体组成的一个子集(个体允许重复)称为一个种群,记为:其中,N称为种群规模。,2 标准遗传算法,2.3 遗传算法的若干概念,适应度(Fitness)在研究自然界中生物的遗传和进化现象时,生物学家使用适应度这个术语来度量某个物种对于生存环境的适应程度。对生存环境适应程度较高的物种将获得更多的繁殖机会,而对生存环境适应程度较低的物种,其繁殖机会就会相对较少,甚
7、至逐渐灭绝。在遗传算法中,一般通过适应度函数(Fitness function)来衡量某一个体的适应度高低。,2 标准遗传算法,解码(Decoding)解码是将遗传算法所搜索到的最优个体的染色体转换成待求解问题的实际最优解的过程,即编码的逆过程。,2.3 遗传算法的若干概念,编码(Coding)将一个待求解的问题的实际可行解从其解空间转换到遗传算法所能处理的搜索空间(即个体空间)的过程,就称为编码。,2 标准遗传算法,选择操作(Selection)根据各个个体的适应度,按照一定的规则,从第t代群体P(t)中选择出一些优良的个体遗传到下一代群体P(t+1)中。一般地,选择操作通过选择算子(Sel
8、ection Operator)进行。,2.3 遗传算法的若干概念,交叉操作(Crossover)将群体P(t)内的各个个体随机搭配成对,对每一对个体,以某个概率(称为交叉概率,Crossover Rate)遵循某一种规则交换它们之间的部分染色体。,变异操作(Mutation)对群体P(t)中的每一个个体,以某一概率(称为变异概率,Mutation Rate)改变某一个或某一些基因座上的基因值为其他的等位基因。,2 标准遗传算法,2.4 遗传算法的应用步骤,(1)确定决策变量及各种约束条件,即确定出个体的表现型X和问题的解空间。(2)建立优化模型,确定出目标函数的类型及其数学描述形式或量化方法
9、。(3)确定表示可行解的染色体编码方法,即确定出个体的基因型X*,及遗传算法的搜索空间。,编码是遗传算法解决问题的先决条件和关键步骤:不仅决定个体基因的排列形式(从而决定选择与繁殖等操作的作用方式),而且也决定从搜索空间的基因型到解空间的表现型的解码方式(从而决定对GA所获解的翻译与理解);决定GA搜索的困难度与复杂性;决定对问题的求解精度。常用的遗传算法编码方法主要有:二进制编码、浮点数编码等。可以证明,二进制编码比浮点数编码搜索能力强,但浮点数编码比二进制编码在变异操作上能够保持更好的种群多样性。,2 标准遗传算法,2.4 遗传算法的应用步骤,(4)确定解码方法,即确定出由个体基因型X*,
10、到个体表现型X的对应关系和转换方法。,标准遗传算法多采用二进制编码方法,将决策变量用二进制字符串表示,二进制编码串的长度由所求精度决定。然后将各决策变量的二进制编码串连接在一起,构成一个染色体。例如:变量x的定义域为-2,3,要求其精度为10-5,则需要将-2,3分成至少500 000个等长小区域,而每个小区域用一个二进制串表示。于是有,2L=500 000,即,向上取整,可得到L=19。即可用19位二进制串a18a17a0 来表示。,例如:对于二进制编码,其解码过程如下:若X*的取值范围为Xl,Xr,参数的二进制编码码长为L,码串对应的十进制整数为k,则解码公式为:,式中,Xl,Xr参数最小
11、、最大值;L参数编码长度;k二进制串对应的实数值。,2 标准遗传算法,(5)确定个体适应度的量化评价方法,就是确定出由目标函数值到个体适应度的转换规则。标准遗传算法的适应度函数常用一下三种:,2.4 遗传算法的应用步骤,直接以待求解的目标函数为适应度函数 若目标函数为最大值问题,则Fit(f(X)=f(X)若目标函数为最小值问题,则Fit(f(X)=f(X),界限构造法,优点:简单直观;缺点:其一,可能不满足非负的要求;其二,某些代求解的函数值分布相差很大,由此得到的平均适应度可能不利于体现种群的平均性能。,若目标函数为最大值问题,则,Cmax为f(x)的最大值估计。,2 标准遗传算法,倒数法
12、,若目标函数为最小值问题,则,2.4 遗传算法的应用步骤,该方法是第一种方法的改进,但有时存在界限值预先估计困难或估计不精确等问题。,Cmin为f(x)的最小值估计。,若目标函数为最小值问题,则,若目标函数为最大值问题,则,C为目标函数界限的保守估计值。,2 标准遗传算法,(6)确定各遗传具体操作方法。,2.4 遗传算法的应用步骤,选择算子和选择操作个体选择概率的常用分配方法有以下两种:A 按比例的适应度分配(Proportional Fitness Assignment)亦可称为选择的蒙特卡罗方法,是利用比例于各个个体适应度的概率决定其子孙的遗留可能性。若某个个体i,其适应度为fi,则其被选
13、取的概率表示为,显然选择概率大的个体,能多次被选中,它的遗传因子就会在种群中扩大。,B 基于排序的适应度分配(Rank-based Fitness Assignment)在基于排序的适应度分配中,种群按目标值进行排序。适应度仅仅取决于个体在种群中的序位,而不是实际的目标值。排序方法比比例方法表现出更好的鲁棒性,它能在一定程度上克服了比例适应度计算的尺度问题和过早收敛问题。,2 标准遗传算法,2.5 遗传算法的应用步骤,另外,还可采用以下的几种提高遗传算法性能的选择方法:稳态繁殖(Steady State Reproduction)在迭代过程中用部分优质新子个体来更新群体中部分父个体,作为下一代
14、种群。没有重串的稳态繁殖(Steady State Reproduction without Duplicates)在稳态繁殖的基础上,形成下一代新种群时,使其中的个体不重复。,个体选择概率确定后,可以选用的常用选择算法有轮盘赌选择法(Roulette Wheel Selection)、随机遍历抽样法(Stochastic Universal Sampling)、局部选择法(Local Selection)、截断选择法(Truncation Selection)和锦标赛选择法(Tournament Selection)等。标准遗传算法常用的轮盘赌选择法的原理如右下图所示。,pointer,关于
15、选择算子:如果对解的质量要求不高,要求收敛快,可取较高的选择强度;反之,可取较低的选择强度。标准遗传算法达到收敛的世代数与选择强度成反比。,2 标准遗传算法,交叉率及交叉操作,交叉,也可以称为基因重组(Recombination),是遗传算法获取新的优良个体的最重要的手段,决定了遗传算法的全局搜索能力。一般地,当随机产生的概率大于交叉率,遗传算法就会按一定规则选择两个个体,执行交叉操作。交叉率的选择决定了交叉的频率,较大的交叉率使各代充分交叉,但群体中的优良模式遭到破坏的可能性增大,以致产生较大的代沟,从而使搜索走向随机化;交叉率越低,产生的代沟越小,就会使得更多的个体直接复制到下一代,遗传搜
16、索可能陷入停滞状态,一般建议取值范围0.40.9。对于二进制编码,常用的交叉方法有:单点交叉、多点交叉和均匀交叉等。一个单点交叉的例子如下图所示。,2 标准遗传算法,变异率及变异操作 变异本身是一种局部随机搜索,使遗传算法具有局部的随机搜索能力;同时使得遗传算法保持种群的多样性,以防止出现非成熟收敛。一般地,随机产生的概率大于变异率就会触发变异操作。变异率一般可取0.0010.1。变异率不能取得太大,如果大于0.5,遗传算法就退化为随机搜索,而遗传算法的一些重要的数学特性和搜索能力也不复存在了。常用的变异操作方法有:实值变异法和二进制变异法等。,实值变异法,a(i)以概率1/m取值1,以概率1
17、-1/m取值0,通常m=20,此外,还有部分匹配交叉(Partially Matched Crossover)、顺序交叉(Ordered Crossover)、洗牌交叉(Shuffle Crossover)等等。,二进制变异法,2 标准遗传算法,(7)确定遗传算法的有关运行参数,包括群体规模(Population Size)、迭代次数(一般取为100500)、选择算子、交叉率、变异率等等。,(8)初始化群体。初始群体一般随机产生初始值最好能在解空间中均匀采样(收敛速度比较快)对于非二进制编码,还要考虑所生成的染色体是否在可行区域内。,(9)计算群体中个体解码后的适应值。(10)按照遗传策略,运
18、用所选定的选择、交叉和变异算子作用于群体,生成下一代群体。(11)判断群体性能是否满足某一指标或是否完成预定迭代次数,不满足则返回(9)。,popsize,取值较小时,提高运算和收敛速度,却降低了群体多样性,可能引起早熟现象,取值较大时,含有较多模式,可提高GA搜索质量,但计算量增大,收敛速度降低,一般取为20100,2 标准遗传算法,2.6 欺骗问题和未成熟收敛问题,2.6.1 欺骗问题(Deceptive Problem)竞争模式:若模式H与H中,*的位置完全一致,但任一确定位的编码均不一样,则称H与H互为竞争模式。欺骗性:假设f(X)的最大值对应的X集合为X*,H为一包含X*的m阶模式。
19、H的竞争模式为H,而且f(H)f(H),则f为m阶欺骗。欺骗问题:在遗传算法中,将所有妨碍评价值高的个体生成从而影响遗传算法正常工作的问题统称为欺骗问题。如对于一个2位二进制编码的模式,如果f(11)为最大值,则以下不等式任意一个成立,则存在欺骗性问题:f(*1)f(*0),f(*1)f(0*),f(1*)f(0*),f(1*)f(*0),欺骗性问题的产生往往与基因编码方法、适应度函数的确定和调整等因素相关,一般可以相应地采用不同的编码方法或者调整适应度函数等方法来化解。,2 标准遗传算法,(1)未成熟收敛现象 未成熟收敛现象是遗传算法中的特有现象,且十分常见。它是指,当遗传算法还没找到全局最
20、优解或满意解时,群体中不能再产生性能超过父代的后代,群体中的各个个体非常相似。未成熟收敛的重要特征是群体中个体结构的多样性急剧减少。,2.6.2 未成熟收敛问题(Premature Convergence),(2)未成熟收敛产生的原因理论上考虑的选择、交叉、变异操作都是绝对精确的,他们相互协调,能搜索到整个解空间,但实际不然;存在随机误差(主要包括取样误差和选择误差);所求解的问题是遗传算法欺骗问题。,(3)未成熟收敛的防止,重新启动法,替代策略(Replacement Strategies),重组策略(Recombination Strategies),匹配策略(Mating Strateg
21、ies),提高多样性,遗传算法具体步骤,选择编码策略,把参数集合(可行解集合)转换染色体结构空间;定义适应度函数,便于计算适应值;确定遗传策略,包括选择群体大小,选择、交叉、变异方法以及确定交叉概率、变异概率等遗传参数;随机产生初始化群体;,计算群体中的个体或染色体解码后的适应值;按照遗传策略,运用选择、交叉和变异算子作用于群体,形成下一代群体;判断群体性能是否满足某一指标,或者已完成预定的迭代次数,不满足则返回第五步,或者修改遗传策略再返回第六步,2 标准遗传算法,2 标准遗传算法,程序流程图,例1 利用遗传算法求解区间0,31上的二次函数y=x2的最大值,精度要求达到个位。,3、遗传算法简
22、单举例:函数极值,分析 原问题可转化为在区间0,31中搜索能使y取最大值的点a的问题。那么,0,31 中的点x就是个体,函数值f(x)恰好就可以作为x的适应度,区间0,31就是一个(解)空间。这样,只要能给出个体x的适当染色体编码,该问题就可以用遗传算法来解决。,3、遗传算法简单举例:函数极值,(1)设定种群规模,编码染色体,产生初始种群。将种群规模设定为4;用5位二进制数编码染色体;取下列个体组成初始种群S1:s1=13(01101),s2=24(11000)s3=8(01000),s4=19(10011)(2)定义适应度函数,取适应度函数:f(x)=x2,3、遗传算法简单举例:函数极值,(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 精品PPT 精品 PPT 数学 建模 专题 遗传 算法

链接地址:https://www.31ppt.com/p-2343595.html