版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第五章遗传算法与组合优化5.1 背包问题(knapsack problem)5.1.1问题描述0/1背包问题:给出几个尺寸为S , S ,,S的物体和容量为C的背包,此处S , S ,, Sn和C都是正整数;要求找出n个物件何一个子集使其尽可能多地填满容量为C的背包。数学形式:最大化W S Xi 二1满足 W S X C, X . e 0,1, 1 i ni二1广义背包问题:输入由c和两个向量c=(sS2,S)和p=(pp2,p)组成。 设X为一整数集合,即X=1,2,3,n,T为X的子集;则问题就是找出满足约束条件 W X C,而使W P获得最大的子集T,即求S和P.的下标子集。iiieTi
2、eT在应用问题中,设S的元素是n项经营活动各自所需的资源消耗,C是所能提供的资源总 量,P的元素是人们从每项经营活动中得到的利润或收益,则背包问题就是在资源有限的条 件下,追求总的最大收益的资源有效分配问题。广义背包问题可以数学形式更精确地描述如下:最大化W P Xi 二1满足 W S X C, X & 0,1, 1 i ni二1背包问题在计算理论中属于NP一完全问题,其计算复杂度为O(2n),若允许物件可以部分 地装入背包,即允许X,可取从0.00到1.00闭区间上的实数,则背包问题就简化为极简单 的P类问题,此时计算复杂度为O(n)。5.1.2遗传编码采用下标子集T的二进制编码方案是常用的
3、遗传编码方法。串T的长度等于n (问题规模), T (1忍i忍n) =1表示该物件装入背包,T =0表示不装入背包。基于背包问题有近似求解知识, 以及考虑到遗传算法的特点(适合短定义距的、低阶的、高适应度的模式构成的积木块结构 类问题),通常将P , S按P/S值的大小依次排列,即P/S NP/S NNP/S。i i i i1122n n5.1.3适应度函数在上述编码情况下,背包问题的目标函数和约束条件可表示如下。目标函数: J (T) = t Pi ii = 1约束条件:2 t S C i = 1按照利用惩罚函数处理约束条件的方法,我们可构造背包问题的适应度函数f(T)如下式: f(T) =
4、 J(T) + g(T)式中g(T)为对T超越约束条件的惩罚函数,惩罚函数可构造如下:C 一。r-lC - 0式中Em为Pi/S(1in)i的最大值,0为合适的惩罚系数。5.2 货郎担问题(Traveling Salesman ProblemTSP)在遗传其法研究中,TSP问题已被广泛地用于评价不同的遗传操作及选择机制的性能。之 所以如此,主要有以下几个方面的原因:TSP问题是一个典型的、易于描述却难以处理的NP完全(NP-complete)问题。有效地解 决TSP问题在可计算理论上有着重要的理论价值。TSP问题是诸多领域内出现的多种复杂问题的集中概括和简化形式。因此,快速、有效地 解决TSP
5、问题有着极高的实际应用价值。TSP问题因其典型性已成为各种启发式的搜索、优化算法的间接比较标准,而遗传算法就 其本质来说,主要是处理复杂问题的一种鲁棒性强的启发式随机搜索算法。因此遗传算法 在TSP问题求解方面的应用研究,对于构造合适的遗传算法框架、建立有效的遗传操作以 及有效地解决TSP问题等有着多方面的重要意义。问题描述:寻找一条最短的遍历n个城市的路径,或者说搜索整数子集X=1, 2,,n (X的元 素表示对n个城市的编号)的一个排列 (X) = vi,v2,vj,使Ji-1n H(如功+1)+ d(功皿)f-1取最小值。式中的d(v, v )表示城市v到城市v的距离。i i+1ii+1
6、5.2.1编码与适应度函数编码以遍历城市的次序排列进行编码。如码串1 2 3 4 5 6 7 8表示自城市l开始,依次经城市2,3,4,5,6,7,8,最后返 回城市1的遍历路径。显然,这是一种针对TSP问题的最自然的编码方式。这一编码方案的 主要缺陷在于引起了交叉操作的困难。采用“边”的组合方式进行编码。例如码串2 4 5 3 6 8 7 1的第1个码2表示城市1到城市2的路径在TSP圈中,第2个 码4表示城市2到城市4的路径在TSP圈中,以此类推,第8个码1表示城市8到城市1的 路径在TSP圈中。这一编码方式有着与前面的“节点”遍历次序编码方式相类似的缺陷。间接“节点”编码方式。以消除“一
7、点交叉”策略(或多点交叉策略)引起的非法路径问题。码串长度仍为n,定 义各等位基因的取值范围为(n - i + 1),i为基因序号,解码时,根据相应基因位的取值, 从城市号集合中不回放地取一个城市号,直至所有城市号被取完。由于这种编码方式特征遗 传性较差,因此现行的研究中很少采用。适应度函数适应度函数常取路径长度Td的倒数,即f=1/Td若结合TSP的约束条件(每个城市经过且只经过一次),则适应度函数可表示为:f=1/(Td +a *N,其中N是对TSP路径不合法的度量(如取付N为未遍历的城市的个数),a为惩罚系数, 常取城市间最长距离的两倍多一点(如2.05*匕);5.2.2交叉策略问题:基
8、于TSP问题的顺序编码(其它编码如以边的组合状态进行编码也呈现相似特性), 若采取简单的一点交叉或多点交叉策略,必然以极大的概率导致未能完全遍历所有城市的非 法路径。如8城市的TSP问题的两个父路径为1 2 3 4 | 5 6 7 88 7 6 5 | 4 3 2 1若采取一点交叉,且交叉点随机选为4,则交叉后产生的两个后代为8 7 6 5 5 6 7 81 2 3 4 4 3 2 1显然,这两个子路径均未能遍历所有8个城市,都违反TSP问题的约束条件。可以采取上述构造惩罚函数的方法,但试验效果不佳。可能的解释:这一方法将本已十分复杂的TSP问题更加复杂化了。因为满足TSP问题约 束条件的可行
9、解空间规模为n!;而按构造惩罚函数的方法,其搜索空间规模变为小;随着n 的增大n!与nn之间的差距是极其惊人的。解决这一约束问题的另一种处理方法是对交叉、变异等遗传操作做适当的修正,使其自 动满足TSP的约束条件。常用的几种交叉方法:1 .部分匹配交叉(PMX, Partially Matched Crossover)法PMX操作是由Goldberg和Lingle于1985年提出的。在PMX操作中,先依据均匀随机分 布产生两个位串交叉点,定义这两点之间的区域为一匹配区域,并使用位置交换操作交换两 个父串的匹配区域。实例:如两父串及匹配区域为 TOC o 1-5 h z A = 9 8 4|56
10、7|1320B = 8 7 1|230|9546首先交换A和B的两个匹配区域,得到A=9 84|230|l320B=8 71|567|9546对于A、B两子串中匹配区域以外出现的遍历重复,依据匹配区域内的位置映射关系, 逐一进行交换。对于A有2到5, 3到6,0到7的位置符号映射,对A的匹配区以外的2, 3,0分别以5,6,7替换,则得A”=9 8 4 | 2 3 0 | 1 6 5 7同理可得:B”=8 0 1 | 5 6 7 | 9 2 4 3这样,每个子串的次序部分地由其父串确定。顺序交叉法(OX, Order Crossover)法与PMX法相似,Davis(1985)等人提出了一种O
11、X法,此方法开始也是选择一个匹配区域: TOC o 1-5 h z A = 9 8 4|567|1320B = 8 7 1|230|9546并根据匹配区域的映射关系,在其区域外的相应位置标记H,得到A=9 84|567|1HHHB=8 H1|230|9H4H再移动匹配区全起点位置,且在其后预留相等于匹配区域的空间(H数目),然后将其余的 码按其相对次序排列在预留区后面,得到A”=5 6 7 H H H 1 9 8 4B”=2 3 0 H H H 9 4 8 1最后将父串A,B的匹配区域相互交换,并放置到A”,B”的预留区内,即可得到两个子 代:A”=5 6 7 | 2 3 0 | 1 9 8
12、4B”=2 3 0 | 5 6 7 | 9 4 8 1虽然,PMX法与OX法非常相似,但它们处理相似特性的手段却不同。PMX法趋向于所期 望的绝对城市位置,而OX法却趋向于期望的相对城市位置。循环交叉(CX,cycle crossover)法Smith等人提出的CX方法与PMX方法和OX方法有不同之处。循环交叉的执行是以父串的 特征作为参考,使每个城市在约束条件下进行重组。设两个父串为C = 9 8 2 1 7 4 5 0 6 3D=1 2 3 4 5 6 7 8 9 0不同于选择交叉位置,我们从左边开始选择一个城市C=9D=1再从另一父串中的相应位置,寻找下一个城市:C=9 1D=1 一一一
13、一一一一一 9 一再轮流选择下去,最后可得C=9 2 3 1 5 4 7 8 6 1 0D=1 8 2 4 7 6 5 1 0 9 3基于知识的交叉方法这种方法是一种启发式的交叉方法,按以下规划构造后代:随机地选取一个城市作为子代圈的开始城市。比较父串中与开始城市邻接的边,选取最小的边添加到圈的路径中。重复第(2)步,如果发现按最小边选取的规划产生非法路径(重复经过同一城市),则 按随机法产生一合法的边,如此反复,直至形成一完整的TSP圈。使用这一方法,可获得较好的结果。在200个城市的TSP优化方面,已产生接近由模拟 退火程序计算出的最优结果。不过,这一方法使用了基于问题的一些知识,损失了遗
14、传算法 的通用性和鲁棒性。关于TSP问题的遗传交叉方法还有各种各样的变形方法,一般来说,交叉方法应能使父 串的待征遗传给子串,子串应能部分或全部地继承父串的结构特征和有效基因。5.2.3变异技术从遗传算法的观点来看,解的进化主要靠选择机制和交叉策略来完成,变异只是为选择、 交叉过程中可能丢失的某些遗传基因进行修复和补充,变异在遗传算法的全局意义上只是一 个背景操作。针对TSP问题,主要的变异技术如下述。位点变异变异仅以一定的概率(通常较小)对串的某些位作值的变异。逆转变异在串中,随机选择两点,再将这两点内的子串按反序插入到原位置中,如串A的逆转点 为3,6,则经逆转后,变为AA =1 2 3
15、| 4 5 6 | 7 8 9 0A=1 2 3 | 6 5 4 | 7 8 9 0这种变异操作对于TSP问题,就调整前后引起的TSP圈的长度变化而言用于最细微的调 整,因而局部优化的精度较高;但码串绝对位置所呈现的“模式”变化较大,所需的计算也 稍为复杂一点。3 .对换变异随机选择串中的两点,交换其值(码)。对于串AA=1 2 3 4” 5 6 7” 8 9若对换点为4,7,则经对换后,A为A=1 2 3 7” 5 6 4” 8 9这种变异操作在求解TSP问题优化算法中常被采用。在遗传算法中,对换变异操作对码 串绝对位置所呈现的“模式”变化影响较小,所需的计算也简单一些,但局部优化精度稍差。
16、插人变异从串中随机选择1个码,将此码插入随机选择的插入点中间,对于上述A而言.若取插 入码为5,选取插入点为23之间.则A=1 2 5 3 4 6 7 8 95.2.4选择机制和群体构成在遗传算法中,最常见的选择机制是依据适应度的比例概率选择机制;在有限规模的群 体中,适应度较高的个体有较大的机会繁殖后代,即生物进化论上的适者生存规则。在新一代群体构成方法方面存在:N方式:全部替换上一代群体的全刷新代际更新方式。E方式:保留一个最好的父串的最佳保留(elitist)群体构造方式。G方式:按一定比例更新群体中的部分个体的部分更新方式(或称代沟方法,这种情况的 极端是每代仅删去一个最不适的个体的最
17、劣死亡方式)。B方式:从产生的子代和父代中挑选最好的若干个个体的群体构成形式。从群体规模来看,有变化规模的方式,也有恒定规模的群体构成方式等。一般讲,N方式的全局搜索性能最好,但收敛速度最慢;B方式收敛速度最快,但全局搜 索性能最差;E方式和G方式的性能介于N方式和B方式之间。在求解货郎担问题的应用中, 多选用E方式。5.2.5基于遗传算法求解TSP的算法实现编码与适应度函数我们以n城市的遍历次序作为遗传算法的编码,由于在可行解群体的韧始化、交叉操作 及变异操作中均隐台TSP问题的合法性约束条件,故适应度函数取为哈密尔顿圈的长度的倒 数(无惩罚函数)。选择机制开始,我们用随机方法产生初始解群。
18、随着遗传算法的执行,我们保留M个较优的个体 作为样本群体,以供选择;在每一代运算过程中,个体被选中的概率与其在群体中的相对适 应度成正比。3 .交叉方法我们选用的交叉方法与OX法有点类似,现介绍如下:随机在串中选择一个交配区域,如两父串及交配区域选定为 TOC o 1-5 h z A=1 2 |3456| 789B = 9 8 |7654| 321将B的交配区域加到A的前面或后面,A的交配区域加到B的前面或后面得到A=7 654|12 3456789B=3 456|98 7654321在入中自交配区域后依次删除与交配区相同的城市码,得到最终的两子串为A=7 6 5 4 1 2 3 8 9B=3
19、 4 5 6 9 8 7 2 1与其它方法相比,这种方法在两父串相同的情况下仍能产生一定程度的变异效果,对维 持群体内一定的多样化持性有一定的作用,实验中也显示了较好的结果。4.变异技术由于在选择机制中采用保留最佳样本方式,以及引入了“进化逆转”操作技术,为保持 群体内个体的多样化,我们采取连续多次对换的变异技术,使可行解有较大的顺序排列上的 变化,以抑制“进化逆转”的同化作用。变异操作发生的概率取得比较小(1%左右),一旦变 异操作发生,则用随机方法产生交换次数K,对所需变异操作的串进行K次对换(对换的两 码位也是随机产生的)。“进化逆转”操作引入“进化逆转”操作的主要目的是改善遗传算法的局
20、部搜索能力。所谓局部搜索通常 指的是基于邻域的试探搜索方法。在基本遗传算法操作中,交叉操作在可行解空间今动作范 围较宽,步伐较大;变异操作由于受“选择”压力的作用,通常也难以发挥局部搜索的功效 (特别在遗传算法趋向收敛的后期阶段)。因此,在遗传算法框架中加入适当的、基于邻域的 局部搜索机制,构成一种全局搜索和局部搜索相结合的优化搜索算法,对改进优化质量以及 提高搜索效率都是很有意义的。在自然遗传和进化过程中,“逆转”也是一种常见的现象。如一染色体内各片断的正常顺 序是(123456),在区间23和区间56发生了两处断裂,断裂片断又以反向顺 序插入,于是逆转后的染色体顺序变为(125-4-3-6
21、)。自然生物遗传上的“逆转”现 象有消极的作用(如导致致死因素、不育因素等),也可能产生积极的作用(如导致生物的适 应能力增强等)。从进化意义上讲,如果说交叉、变异等遗传操作使子代趋向于拥有较优品质 的基因型的话,那么逆转、对换等遗传操作的功能就是使这些基因型及其组合以较优的次序 遗传给后代。在针对TSP问题的遗传算法中,“逆转”是一种常见的“变异”技术。我们使用 的“进化逆转”是一种单方向的(朝着改进的方向)和连续多次的“逆转”操作,即对于结定 的串,若“逆转”使串(可行解)的适应度提高,则执行逆转换作,如此反复,直至不存在这 样的逆转操作为止。这一操作实际上使给定的串改良到它的局部极点,这种局部爬山能力与 基本遗传算法的全局搜索能力相结合在实验中显示了较好的效果。算法的流程框图实验结果实验中,群体规模定为100,交叉概率为0.95,变异概率为0.003,初始可行解群体由随 机法产生。实验结果表明:(1)当nV15时,随机样本实验表明,本算法可100%搜索到用穷举法求得的最优解。(2)当15VMV30时,我们对一
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 糕点店装修粉刷施工协议
- 建筑设计科技合同管理办法
- 公路隧道照明工程合同范本
- 农业大棚外保温施工合同
- 电视连续剧演员招聘合同
- 2025年度VOC废气处理设备定期检查与维修合同3篇
- 农田水利招投标监管与优化
- 青年旅社施工合同
- 矿山梦想钢管架施工合同
- 高新技术产业投标响应范本
- BT3无线网络密码破解图文教程
- (新平台)国家开放大学《0-3岁婴幼儿的保育与教育》形考任务1-4参考答案
- 大学计算机基础(山东农业大学)知到章节答案智慧树2023年
- 16G362 钢筋混凝土结构预埋件
- 朗文2A试卷汇总
- GA 1811.2-2022传媒设施反恐怖防范要求第2部分:广播电视传输覆盖网设施
- XX站房建工程施工组织设计
- 普通心理学(梁宁建)
- 口腔医学专业认证标准指标体系
- 101501意见陈述书(关于非正常申请)2022版
- 南洋理工学院办学理念茂名职业技术学院课件
评论
0/150
提交评论