- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于GA的TSP求解.ppt
第十七章 MATLAB优化算法案例分析与应用 第17章 基于GA的TSP求解 第十七章 MATLAB优化算法案例分析与应用 17.1 旅行商问题分析 旅行商问题(Traveling Salesman Problem,简称TSP),也称货郎担问题,是数学领域中的著名问题之一。TSP问题已经被证明是一个NP-hard问题,由于TSP问题代表一类组合优化问题,因此对其近似解的研究一直是算法设计的一个重要问题。该问题的求解算法主要分为两类。一类是与问题特征相关的启发式搜索算法。主要有动态规划法、分支界定法等。另一类是独立于问题的智能优化算法,如模拟退火法、禁忌搜索法、蚁群算法、遗传算法、粒子群算法等。本文将基于遗传算法进行TSP问题的求解。 第十七章 MATLAB优化算法案例分析与应用 17.2 遗传算法算子分析 在遗传算法中,通过编码组成初始群体后,遗传操作的任务就是对群体的个体按照它们对环境适应度施加一定的操作,从而实现优胜劣汰的进化过程。从优化搜索的角度而言,遗传操作可使问题的解,一代又一代地优化,并逼进最优解。 遗传操作包括以下三个基本遗传算子,选择算子、交叉算子和变异算子。 17.2.1 选择算子(selection) 从群体中选择优胜的个体,淘汰劣质个体的操作叫选择。选择的目的是把优化的个体直接遗传到下一代或通过配对交叉产生新的个体再遗传到下一代。选择操作是建立在群体中个体的适应度评估基础上的,目前常用的选择算子有适应度比例方法、随机遍历抽样法、局部选择法。 其中轮盘赌选择法(Roulette Wheel Selection)是最简单也是最常用的选择方法。 第十七章 MATLAB优化算法案例分析与应用 17.2 遗传算法算子分析 17.2.2 交叉算子(crossover) 交叉算子根据交叉率将种群中的两个个体随机地交换某些基因,能够产生新的基因组合,期望将有益基因组合在一起。根据编码表示方法的不同分为实值重组和二进制交叉两类算法。 其中实值重组(real valued recombination)可分为: (1)离散重组 (discrete recombination); (2)中间重组(intermediate recombination); (3)线性重组(linear recombination); (4)扩展线性重组(extended linear recombination)。 二进制交叉(binary valued crossover)可分为: (1)单点交叉(single-point crossover); (2)多点交叉(multiple-point crossover); (3)均匀交叉(uniform crossover); (4)洗牌交叉(shuffle crossover); (5)缩小代理交叉(crossover with reduced surrogate)。 其中,最常用的交叉算子为单点交叉(one-point crossover)。具体操作是,在个体串中随机设定一个交叉点,实行交叉时,该点前或后的两个个体的部分结构进行互换,并生成两个新个体。 第十七章 MATLAB优化算法案例分析与应用 17.2 遗传算法算子分析 17.2.3 变异算子(mutation) 一般来说,变异算子操作的分两步完成。 (1)对群中所有个体以事先设定的编译概率判断是否进行变异; (2)对进行变异的个体随机选择变异位进行变异。 遗传算法引入变异的目的有两个:一是使遗传算法具有局部的随机搜索能力。当遗传算法通过交叉算子已接近最优解邻域时,利用变异算子的这种局部随机搜索能力可以加速向最优解收敛。显然,此种城市的指定为一个明确的目标情况下的变异概率应取较小值,否则接近最优解的积木块会因变异而遭到破坏。二是使遗传算法可维持群体多样性,以防止出现未成熟收敛现象。此时收敛概率应取较大值。 遗传算法中,交叉算子因其全局搜索能力而作为主要算子,变异算子因其局部搜索能力而作为辅助算子。遗传算法通过交叉和变异这对相互配合又相互竞争的操作而使其具备兼顾全局和局部的均衡搜索能力。 所谓相互配合,是指当群体在进化中陷于搜索空间中某个超平面而仅靠交叉不能摆脱时,通过变异操作可有助于这种摆脱。所谓相互竞争,是指当通过交叉已形成所期望的积木块时,变异操作有可能破坏这些积木块。如何有效地配合使用交叉和变异操作,是目前遗传算法的一个重要研究内容。 第十七章 MATLAB优化算法案例分析与应用 17.
原创力文档


文档评论(0)