模拟退火算法和遗传算法(精品).ppt
10.110.1 模拟退火算法模拟退火算法 模拟退火算法(Simulated Annealing Algorithm,简记为SAA)是受金属热加工技术的启迪而发展起来的一种随机搜索算法。模拟退火算法及模型模拟退火算法及模型模拟退火算法及模型模拟退火算法及模型 w算法的提出算法的提出 模拟退火算法最早的思想由模拟退火算法最早的思想由Metropolis等(等(1953)提出,提出,1983年年Kirkpatrick等将其应用于组合优化。等将其应用于组合优化。w算法的目的算法的目的 解决解决NP复杂性复杂性问题;问题;克服优化过程陷入局部极小;克服优化过程陷入局部极小;克服初值依赖性。克服初值依赖性。物理退火过程物理退火过程物理退火过程物理退火过程模拟退火算法及模型模拟退火算法及模型模拟退火算法及模型模拟退火算法及模型 w物理退火过程物理退火过程 什么是退火:什么是退火:退火是指将固体加热到足够高的温度,使分子呈随退火是指将固体加热到足够高的温度,使分子呈随机排列状态,然后逐步降温使之冷却,最后分子以机排列状态,然后逐步降温使之冷却,最后分子以低能状态排列,达到某种稳定状态。低能状态排列,达到某种稳定状态。物理退火过程物理退火过程物理退火过程物理退火过程模拟退火算法及模型模拟退火算法及模型模拟退火算法及模型模拟退火算法及模型 w物理退火过程物理退火过程 加温过程加温过程增强粒子的热运动,消除系统原先可增强粒子的热运动,消除系统原先可能存在的非均匀态;能存在的非均匀态;等温过程等温过程对于与环境换热而温度不变的封闭系对于与环境换热而温度不变的封闭系统,系统状态的自发变化总是朝自由能减少的方向统,系统状态的自发变化总是朝自由能减少的方向进行,当自由能达到最小时,系统达到平衡态;进行,当自由能达到最小时,系统达到平衡态;冷却过程冷却过程使粒子热运动减弱并渐趋有序,系统使粒子热运动减弱并渐趋有序,系统能量逐渐下降,从而得到低能的晶体结构。能量逐渐下降,从而得到低能的晶体结构。物理退火过程物理退火过程物理退火过程物理退火过程10.1.1 10.1.1 模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理 w数学表述数学表述 在温度在温度T,分子停留在状态,分子停留在状态r满足满足Boltzmann概率分概率分布布物理退火过程物理退火过程物理退火过程物理退火过程10.1.1 10.1.1 模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理 w数学表述数学表述 在在同一个温度同一个温度T,选定两个能量,选定两个能量E1E2,有,有在同一个温度,分子停留在能量小的状态的概率比在同一个温度,分子停留在能量小的状态的概率比停留在能量大的状态的概率要大。停留在能量大的状态的概率要大。10.1.1 10.1.1 模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理 w数学表述数学表述 若若|D|为状态空间为状态空间D中状态的个数,中状态的个数,D0是具有最低能是具有最低能量的状态集合:量的状态集合:当温度很高时,每个状态概率基本相同,接近平均当温度很高时,每个状态概率基本相同,接近平均值值1/|D|;状态空间存在超过两个不同能量时,具有最低能量状态空间存在超过两个不同能量时,具有最低能量状态的概率超出平均值状态的概率超出平均值1/|D|;当温度趋于当温度趋于0时,分子停留在最低能量状态的概率时,分子停留在最低能量状态的概率趋于趋于1。10.1.1 10.1.1 模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理模拟退火算法的基本原理 wMetropolis准则(准则(1953)以概率接受新状态以概率接受新状态 若在温度若在温度T,当前状态,当前状态i 新状态新状态j 若若Ej=randrom0,1 s=sj;Until 抽样稳定准则满足;抽样稳定准则满足;退温退温tk+1=update(tk)并令并令k=k+1;Until 算法终止准则满足;算法终止准则满足;输出算法搜索结果。输出算法搜索结果。10.1.3 10.1.3 模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性 w定义定义 10.1.3 10.1.3 模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性 w定义定义 一步转移概率:一步转移概率:n步转移概率:步转移概率:若解空间有限,称马尔可夫链为若解空间有限,称马尔可夫链为有限状态有限状态;若若 ,称马尔可夫链为,称马尔可夫链为时齐的时齐的。马尔科夫链马尔科夫链马尔科夫链马尔科夫链10.1.3 10.1.3 模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性 w模拟退火算法对应了一个马尔可夫链模拟退火算法对应了一个马尔可夫链 模拟退火算法:新状态接受概率仅依赖于新状态和模拟退火算法:新状态接受概率仅依赖于新状态和当前状态,并由温度加以控制。当前状态,并由温度加以控制。若固定每一温度,算法均计算马氏链的变化直至平若固定每一温度,算法均计算马氏链的变化直至平稳分布,然后下降温度,则称为稳分布,然后下降温度,则称为时齐算法时齐算法;若无需各温度下算法均达到平稳分布,但温度需按若无需各温度下算法均达到平稳分布,但温度需按一定速率下降,则称为一定速率下降,则称为非时齐算法非时齐算法。w分析收敛性分析收敛性10.1.3 10.1.3 模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性 w模拟退火过程是从一个状态(解)到另一个状态模拟退火过程是从一个状态(解)到另一个状态(解)不断地随机游动,我们称这种游动为(解)不断地随机游动,我们称这种游动为变换变换。从邻域从邻域Si中选出某个解中选出某个解j的方法称为解的产生机制的方法称为解的产生机制.从当前解变换到下一个解的过程称为转移,它由产从当前解变换到下一个解的过程称为转移,它由产生机制的应用和接受准则的应用两部分组成。生机制的应用和接受准则的应用两部分组成。10.1.3 10.1.3 模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性 10.1.3 10.1.3 模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性模拟退火算法的计算步骤及收敛性 10.1.4 10.1.4 模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题冷却进度表冷却进度表控制参数值控制参数值Tf的选取的选取马尔科夫链长度马尔科夫链长度Lk的选取的选取控制参数衰减函数的选取控制参数衰减函数的选取10.1.4 10.1.4 模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题w原则原则 (1)在固定温度下,接受使目标函数下降的候选解的在固定温度下,接受使目标函数下降的候选解的概率要大于使目标函数上升的候选解概率;概率要大于使目标函数上升的候选解概率;(2)随温度的下降,接受使目标函数上升的解的概率随温度的下降,接受使目标函数上升的解的概率要逐渐减小;要逐渐减小;(3)当温度趋于零时,只能接受目标函数下降的解。当温度趋于零时,只能接受目标函数下降的解。w方法方法 具体形式对算法影响不大具体形式对算法影响不大 一般采用一般采用min1,exp(-C/t)10.1.4 10.1.4 模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题w方法方法 (1)均匀抽样一组状态,以各状态目标值得方差)均匀抽样一组状态,以各状态目标值得方差为初温;为初温;(2)随机产生一组状态,确定两两状态间的最大)随机产生一组状态,确定两两状态间的最大目标值差,根据差值,利用一定的函数确定初温;目标值差,根据差值,利用一定的函数确定初温;(3)利用经验公式。)利用经验公式。初温初温初温初温10.1.4 10.1.4 模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题w时齐算法的温度下降函数时齐算法的温度下降函数 (1),越接近越接近1 1温度下降越慢,温度下降越慢,且其大小可以不断变化;且其大小可以不断变化;(2),其中,其中t0为起始温度,为起始温度,K为算法温度下为算法温度下降的总次数。降的总次数。温度更新函数温度更新函数温度更新函数温度更新函数10.1.4 10.1.4 模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题w非时齐模拟退火算法非时齐模拟退火算法 每个温度下只产生一个或少量候选解每个温度下只产生一个或少量候选解w时齐算法时齐算法常用的常用的Metropolis抽样稳定准则抽样稳定准则 (1)检验目标函数的均值是否稳定;)检验目标函数的均值是否稳定;(2)连续若干步的目标值变化较小;)连续若干步的目标值变化较小;(3)按一定的步数抽样。)按一定的步数抽样。内循环终止准则内循环终止准则内循环终止准则内循环终止准则10.1.4 10.1.4 模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题模拟退火算法实现的技术问题w模拟退火算法的优点模拟退火算法的优点 质量高;质量高;初值鲁棒性强;初值鲁棒性强;简单、通用、易实现。简单、通用、易实现。w模拟退火算法的缺点模拟退火算法的缺点 由于要求较高的初始温度、较慢的降温速率、较低由于要求较高的初始温度、较慢的降温速率、较低的终止温度,以及各温度下足够多次的抽样,因此的终止温度,以及各温度下足够多次的抽样,因此优化过程较长。优化过程较长。模拟退火算法的优缺点模拟退火算法的优缺点模拟退火算法的优缺点模拟退火算法的优缺点模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用w算法流程算法流程 3030城市城市城市城市TSPTSP问题问题问题问题模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用w运行过程运行过程 3030城市城市城市城市TSPTSP问题问题问题问题模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用w运行过程运行过程 3030城市城市城市城市TSPTSP问题问题问题问题模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用模拟退火算法的实现与应用w运行过程运行过程 3030城市城市城市城市TSPTSP问题问题问题问题10.2 10.2 遗传遗传遗传遗传算法算法算法算法 遗传算法(遗传算法(Genetic Algorithm,简称,简称GA)是一种以)是一种以自然选择和遗传理论为基础,将生物进化过程中适自然选择和遗传理论为基础,将生物进化过程中适者生存规则与种群内部染色体的随机交换机制相结者生存规则与种群内部染色体的随机交换机制相结合的随机化搜索算法。合的随机化搜索算法。10.2 10.2 遗传遗传遗传遗传算法算法算法算法 w达尔文的自然选择说达尔文的自然选择说遗传(遗传(heredity):子代和父代具有相):子代和父代具有相 同或相似的性状,保证物种的稳定性;同或相似的性状,保证物种的稳定性;变异(变异(variation):子代与父代,子代不同个体之间):子代与父代,子代不同个体之间总有差异,是生命多样性的根源;总有差异,是生命多样性的根源;生存斗争和适者生存:具有适应性变异的个体被保生存斗争和适者生存:具有适应性变异的个体被保留,不具适应性变异的个体被淘汰。留,不具适应性变异的个体被淘汰。自然选择过程是长期的、缓慢的、连续的过程。自然选择过程是长期的、缓慢的、连续的过程。生物进化理论和遗传学的基本知识生物进化理论和遗传学的基本知识生物进化理论和遗传学的基本知识生物进化理论和遗传学的基本知识 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w遗传学基本概念与术语遗传学基本概念与术语基因座(基因座(locus):遗传基因在染色体中所占据的位):遗传基因在染色体中所占据的位置,同一基因座可能有的全部基因称为等位基因置,同一基因座可能有的全部基因称为等位基因(allele););个体(个体(individual):指染色体带有特征的实体;):指染色体带有特征的实体;种群(种群(population):个体的集合,该集合内个体数):个体的集合,该集合内个体数称为种群的大小;称为种群的大小;遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w遗传学基本概念与术语遗传学基本概念与术语进化(进化(evolution):生物在其延续生存的过程中,):生物在其延续生存的过程中,逐渐适应其生存环境,使得其品质不断得到改良,逐渐适应其生存环境,使得其品质不断得到改良,这种生命现象称为进化;这种生命现象称为进化;适应度(适应度(fitness):度量某个物种对于生存环境的):度量某个物种对于生存环境的适应程度。对生存环境适应程度较高的物种将获得适应程度。对生存环境适应程度较高的物种将获得更多的繁殖机会,而对生存环境适应程度较低的物更多的繁殖机会,而对生存环境适应程度较低的物种,其繁殖机会就会相对较少,甚至逐渐灭绝种,其繁殖机会就会相对较少,甚至逐渐灭绝;遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w遗传学基本概念与术语遗传学基本概念与术语选择(选择(selection):指决定以一定的概率从种群中):指决定以一定的概率从种群中选择若干个体的操作选择若干个体的操作;复制(复制(reproduction):细胞在分裂时,遗传物质):细胞在分裂时,遗传物质DNA通过复制而转移到新产生的细胞中,新的细胞通过复制而转移到新产生的细胞中,新的细胞就继承了旧细胞的基因就继承了旧细胞的基因;交叉(交叉(crossover):在两个染色体的某一相同位置):在两个染色体的某一相同位置处处DNA被切断,其前后两串分别交叉组合形成两个被切断,其前后两串分别交叉组合形成两个新的染色体。又称基因重组,俗称新的染色体。又称基因重组,俗称“杂交杂交”;遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w遗传学基本概念与术语遗传学基本概念与术语变异(变异(mutation):在细胞进行复制时可能以很小):在细胞进行复制时可能以很小的概率产生某些复制差错,从而使的概率产生某些复制差错,从而使DNA发生某种变发生某种变异,产生出新的染色体,这些新的染色体表现出新异,产生出新的染色体,这些新的染色体表现出新的性状的性状;编码(编码(coding):表现型到基因型的映射;):表现型到基因型的映射;解码(解码(decoding):从基因型到表现型的映射。):从基因型到表现型的映射。遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点遗传算法的基本原理和特点10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w遗传算法的基本思路遗传算法的基本思路 遗传算法实现的技术问题遗传算法实现的技术问题遗传算法实现的技术问题遗传算法实现的技术问题10.2 10.2 遗传算法遗传算法遗传算法遗传算法 遗传算法实现的技术问题遗传算法实现的技术问题遗传算法实现的技术问题遗传算法实现的技术问题 遗传算法的工作步骤10.2 10.2 遗传算法遗传算法遗传算法遗传算法 遗传算法实现的技术问题遗传算法实现的技术问题遗传算法实现的技术问题遗传算法实现的技术问题10.2 10.2 遗传遗传遗传遗传算法算法算法算法 w问题的提出问题的提出 一元函数求最大值:一元函数求最大值:简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传遗传遗传遗传算法算法算法算法 w编码编码 表现型:表现型:x 基因型:二进制编码(串长取决于求解精度)基因型:二进制编码(串长取决于求解精度)串长与精度之间的关系串长与精度之间的关系:若要求求解精度到若要求求解精度到6位小数,区间长度为位小数,区间长度为2-(-1)3,即需将区间分为,即需将区间分为3/0.000001=3106等份。等份。所以编码的二进制串长应为所以编码的二进制串长应为22位。位。简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w产生初始种群产生初始种群 产生的方式:随机产生的方式:随机 产生的结果:长度为产生的结果:长度为22的二进制串的二进制串 产生的数量:种群的大小(规模),如产生的数量:种群的大小(规模),如30,50,1111010011100001011000 1100110011101010101110 1010100011110010000100 1011110010011100111001 0001100101001100000011 0000011010010000000000 简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w计算适应度计算适应度 不同的问题有不同的适应度计算方法不同的问题有不同的适应度计算方法 本例:直接用目标函数作为适应度函数本例:直接用目标函数作为适应度函数 将某个体转化为将某个体转化为-1,2区间的实数:区间的实数:s=x=0.637197 计算计算x的函数值(适应度):的函数值(适应度):f(x)=xsin(10 x)+2.0=2.586345 简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w计算适应度计算适应度 二进制与十进制之间的转换二进制与十进制之间的转换:第一步,将一个二进制串(第一步,将一个二进制串(b21b20b0)转化为)转化为10进制进制数:数:第二步,第二步,x对应的区间对应的区间-1,2内的实数:内的实数:简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 (0000000000000000000000)-1(1111111111111111111111)210.2 10.2 遗传算法遗传算法遗传算法遗传算法 w遗传操作遗传操作 选择:轮盘赌选择法;选择:轮盘赌选择法;交叉:单点交叉;交叉:单点交叉;变异:小概率变异变异:小概率变异 简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模拟结果模拟结果 设置的参数设置的参数:种群大小种群大小50;交叉概率;交叉概率0.75;变异概率;变异概率0.05;最大;最大代数代数200。得到的最佳个体得到的最佳个体:smax=;xmax=1.8506;f(xmax)=3.8503;简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 世代数世代数自变量自变量适应度适应度11.44953.449491.83953.7412171.85123.8499301.85053.8503501.85063.8503801.85063.85031201.85063.85032001.85063.8503w模拟结果模拟结果 进化的过程进化的过程:简单函数优化的实例简单函数优化的实例简单函数优化的实例简单函数优化的实例 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w编码原则编码原则完备性(完备性(completeness):问题空间的所有解都能表):问题空间的所有解都能表示为所设计的基因型;示为所设计的基因型;健全性(健全性(soundness):任何一个基因型都对应于一):任何一个基因型都对应于一个可能解;个可能解;非冗余性(非冗余性(non-redundancy):问题空间和表达空):问题空间和表达空间一一对应。间一一对应。10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w适应度函数的重要性适应度函数的重要性 适应度函数的选取直接影响遗传算法的收敛速度以适应度函数的选取直接影响遗传算法的收敛速度以及能否找到最优解。及能否找到最优解。一般而言,适应度函数是由目标函数变换而成的,一般而言,适应度函数是由目标函数变换而成的,对目标函数值域的某种映射变换称为适应度的对目标函数值域的某种映射变换称为适应度的尺度尺度变换变换(fitness scaling)。)。适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w几种常见的适应度函数几种常见的适应度函数若目标函数为最大化问题:若目标函数为最大化问题:若目标函数为最小化问题:若目标函数为最小化问题:适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w适应度函数的线性变换法适应度函数的线性变换法 f=*f+系数的确定满足以下条件:系数的确定满足以下条件:缩放前后的平均适应度相等缩放前后的平均适应度相等.favg=favg 缩放后的最大适应度要等于原平均适应度缩放后的最大适应度要等于原平均适应度 的指定倍数的指定倍数 fmax=cmult favg cmult=1.02.0 适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w适应度函数的作用适应度函数的作用 适应度函数设计不当有可能出现欺骗问题:适应度函数设计不当有可能出现欺骗问题:(1)进化初期,个别超常个体控制选择过程;)进化初期,个别超常个体控制选择过程;(2)进化末期,个体差异太小导致陷入局部极值。)进化末期,个体差异太小导致陷入局部极值。适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w适应度函数的设计适应度函数的设计单值、连续、非负、最大化单值、连续、非负、最大化合理、一致性合理、一致性计算量小计算量小通用性强通用性强 适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换适应度函数及其尺度变换 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w个体选择概率的常用分配方法个体选择概率的常用分配方法按比例的适应度分配(按比例的适应度分配(proportional fitness assignment)某个体某个体i,其适应度为,其适应度为fi,则其被选取的概率,则其被选取的概率Pi为:为:遗传操作遗传操作遗传操作遗传操作选择选择选择选择 个体个体ff2P12.56.250.1821.01.000.0333.09.000.2641.21.440.0452.14.410.1360.80.640.0272.56.250.1881.31.690.0590.90.810.02101.83.240.0910.2 10.2 遗传算法遗传算法遗传算法遗传算法 个体个体1234567891011适应度适应度2.01.81.61.41.21.00.80.60.40.20.1选择概率选择概率0.180.160.150.130.110.090.070.060.030.020.0累计概率累计概率0.180.340.490.620.730.820.890.950.981.001.00w常用选择方法常用选择方法轮盘赌选择法(轮盘赌选择法(roulette wheel selection)遗传操作遗传操作遗传操作遗传操作选择选择选择选择 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w实值重组实值重组离散重组离散重组 子个体的每个变量可以按等概率随机地挑选父个体。子个体的每个变量可以按等概率随机地挑选父个体。遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 父个体父个体1 12 25 5父个体父个体2 123 4 34子个体子个体1 123 4 5子个体子个体2 12 4 3410.2 10.2 遗传算法遗传算法遗传算法遗传算法 w实值重组实值重组中间重组中间重组 子个体父个体子个体父个体1(父个体(父个体2父个体父个体1)是比例因子,由是比例因子,由-d,1+d上均匀分布地随机数产生。上均匀分布地随机数产生。d=0时为中间重组,一般取时为中间重组,一般取d=0.25。子代的每个变量均产生一个子代的每个变量均产生一个。遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w实值重组实值重组中间重组中间重组 遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 父个体父个体1 12 25 5父个体父个体2 123 4 34子个体子个体1子个体子个体2值样本值样本1 0.5 1.1 -0.1值样本值样本2 0.1 0.8 0.5120.5(12312)=67.567.5251.1(425)=1.91.92.1120.1(12312)=23.123.18.219.510.2 10.2 遗传算法遗传算法遗传算法遗传算法 w实值重组实值重组线性重组线性重组 遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 父个体父个体1 12 25 5父个体父个体2 123 4 34子个体子个体1子个体子个体2值样本值样本1 0.5值样本值样本2 0.1120.5(12312)=67.567.5250.5(425)=14.514.519.5120.1(12312)=23.123.122.97.910.2 10.2 遗传算法遗传算法遗传算法遗传算法 w实值重组实值重组线性重组线性重组 遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w二进制交叉二进制交叉单点交叉单点交叉 遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w二进制交叉二进制交叉多点交叉多点交叉 遗传操作遗传操作遗传操作遗传操作交叉交叉交叉交叉/基因重组基因重组基因重组基因重组 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w变异是将某一个体的某一位字符进行补运算,即将变异是将某一个体的某一位字符进行补运算,即将1变为变为0,或将,或将0变为变为1.遗传操作遗传操作遗传操作遗传操作变异变异变异变异 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w运行程序运行程序 算法的设计与实现算法的设计与实现算法的设计与实现算法的设计与实现 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w运行程序运行程序 算法的设计与实现算法的设计与实现算法的设计与实现算法的设计与实现 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w运行程序运行程序 算法的设计与实现算法的设计与实现算法的设计与实现算法的设计与实现 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w运行程序运行程序 算法的设计与实现算法的设计与实现算法的设计与实现算法的设计与实现 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式模式 将种群中的个体即基因串中的相似样板称为将种群中的个体即基因串中的相似样板称为模式模式。在二进制编码的串中,模式是基于三个字符集(在二进制编码的串中,模式是基于三个字符集(0,1,*)的字符串,符号)的字符串,符号*称作通配符,代表任意称作通配符,代表任意字符,即字符,即0或或1。如模式如模式*1*描述了一个四个元的子集描述了一个四个元的子集010,011,110,111。模式定理模式定理模式定理模式定理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式阶和定义距模式阶和定义距 模式模式 H 中确定位置的个数(即中确定位置的个数(即H 中中0或或1的个数)称的个数)称为模式为模式 H 的的模式阶模式阶,记作,记作 O(H),如,如 O(0 1 1*1*)=4。模式阶用来反映不同模式间确定性的差异,模式阶模式阶用来反映不同模式间确定性的差异,模式阶越高,模式的确定性就越高,所匹配的样本个数就越高,模式的确定性就越高,所匹配的样本个数就越少。越少。模式定理模式定理模式定理模式定理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式阶和定义距模式阶和定义距 模式模式 H 中第一个确定位置和最后一个确定位置之间中第一个确定位置和最后一个确定位置之间的距离称为模式的的距离称为模式的定义距定义距,记作,记作(H),如,如 (0 1 1*1*)=5-1=4。阶数相同的模式会有不同的性质,定义距就反映了阶数相同的模式会有不同的性质,定义距就反映了这种性质的差异。这种性质的差异。模式定理模式定理模式定理模式定理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w平均适应度平均适应度 模式模式H的平均适应度是指在一个确定的群体的平均适应度是指在一个确定的群体内,与内,与H相匹配的所有个体之平均适应度,相匹配的所有个体之平均适应度,记做记做f(H).模式定理模式定理模式定理模式定理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式模式定理(定理(schema theorem)在给定时间步在给定时间步 t,一个特定模式一个特定模式 H 有有 m 个代表串包个代表串包含在种群含在种群 A(t)中,记为中,记为 m=m(H,t),在再生阶段,在再生阶段,每个串根据它的适应值每个串根据它的适应值fi进行复制,一个串进行复制,一个串 Ai 的再的再生概率为生概率为 模式定理模式定理模式定理模式定理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式模式定理(定理(schema theorem)当采用非重叠的当采用非重叠的 n 个串的种群替代种群个串的种群替代种群 A(t),可以,可以得到:得到:其中其中 f(H)是在时间是在时间 t 表示模式表示模式 H 的串的平均适应度。的串的平均适应度。模式定理模式定理模式定理模式定理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 模式定理模式定理模式定理模式定理 w模式模式定理(定理(schema theorem)假设从假设从 t=0 开始,某一特定模式适应度值保持在种开始,某一特定模式适应度值保持在种群平均适应度以上一个群平均适应度以上一个 cf(c 为一常数),则模式为一常数),则模式的选择生长方程为的选择生长方程为10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式模式定理(定理(schema theorem)考虑交叉操作,模式考虑交叉操作,模式 H 被破坏的概率为被破坏的概率为(H)/(l-1),模式,模式 H 生存概率为生存概率为 1-(H)/(l-1),若交叉操作发,若交叉操作发生的概率为生的概率为 pc,因此对于模式,因此对于模式 H 的生存概率计算为:的生存概率计算为:同时考虑选择、交叉操作对模式的影响,可得:同时考虑选择、交叉操作对模式的影响,可得:模式定理模式定理模式定理模式定理 H1=*1 *0H2=*1 0 *10.2 10.2 遗传算法遗传算法遗传算法遗传算法 w模式模式定理(定理(schema theorem)考虑变异操作,单个等位基因存活的概率为考虑变异操作,单个等位基因存活的概率为 pm,当模式当模式 H 中中 O(H)个确定位都存活时,模式个确定位都存活时,模式 H 才被才被保留,存活概率为:保留,存活概率为:同时考虑选择、交叉和变异操作对模式的影响,可同时考虑选择、交叉和变异操作对模式的影响,可得:得:模式定理模式定理模式定理模式定理 H1=*1 *0H2=*1 0 *010.2 10.2 遗传算法遗传算法遗传算法遗传算法 w隐并行机理隐并行机理:在遗传算法中尽管每一代只处理:在遗传算法中尽管每一代只处理n个个个体,但实际上却是处理了个体,但实际上却是处理了O(n3)个模式个模式.隐并行机理隐并行机理隐并行机理隐并行机理 10.2 10.2 遗传算法遗传算法遗传算法遗传算法 隐并行机理隐并行机理隐并行机理隐并行机理 结束结束谢谢观看谢谢观看