完成“模拟退火遗传算法”,试验结果良好.docVIP

完成“模拟退火遗传算法”,试验结果良好.doc

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
完成“模拟退火遗传算法”,试验结果良好.doc

完成“模拟退火遗传算法”,试验结果良好 作者:佚名 文章来源:本站原创 点击数: 797 更新时间:2004-5-15 研究背景: ??????????遗传算法在运行早期个体差异较大,当采用经典的轮盘赌方式选择,后代产生 个数与父个体适应度大小成正比,因此在早期容易使个别好的个体的后代充斥整个种群, 造成早熟;在遗传算法后期,适应度趋向一致,优秀的个体在产生后代时,优势不明显, 从而使整个种群进化停滞不前。由我前面测试过的预选择算法看出,算法很快就收敛。 因此对适应度适当地拉伸是必要的。引进模拟退火算法,在温度高时(遗传算法前期), 适应度相近的个体产生的后代概率相近;而当温度不断下降后,拉伸作用加强,使适应度 相近的个体适应度差异放大,从而使得优秀的个体优势更明显。 模拟退火算法简介: ??????????经过一个晚上研究模拟退火算法解决TSP代码,我总结一下模拟退火算法的基? 本思想。模拟退火算法的核心思想与热力学的原理颇为相似,本质在于对物质缓慢地制冷 以争取充足的时间,让大量原子在丧失可动性之前进行重新分布。从算法的结构上看出, 大致分为以下几个步骤: ????1、构造数学模型 ????2、定义目标函数(在遗传算法中可定义为适应度函数) ????3、确定控制参数(温度、能量) ????4、计算代价(假设进行某种操作之后所付出的代价) ????5、预测这种代价,看看是否需要对被分析的对象重新构造(在遗传算法里面就是要? 看看是否需要进行交叉操作) ????6、改变温度 ????7、重复试验 具体实现c语言代码: ????1、定义关键变量: ???????double??scale_fitness;????????/*?适应度拉伸值?*/ ???????double??temperature;??????????/*?染色体所在温度?*/ ???????struct?individual?*cospop;????/*?代价种群?*/ ???????double?T;?????????????????????/*?当前温度?*/ ???????double?T0;????????????????????/*?初始温度?*/ ???????double?TFACTOR;???????????????/*?温度下降系数?*/ ???????double?de;????????????????????/*?代价值?*/ ???????int?ans;??????????????????????/*?判断是否需要交叉?*/ ???????int?numT;?????????????????????/*?试验的温度数?*/ ???????int?curT;?????????????????????/*?当前温度试验数?*/ ?????2、定义关键函数: ???????void?scalefitness();??????????/*?拉伸适应度函数?*/ ???????double?sumofscalefitness();???/*?拉伸适应度值求和?*/ ???????int?metrop(double,?double);???/*?Metroplis算法?*/ ?????3、关键函数实现: //将原本的适应度值fi拉伸为:exp(fi/T)/sumof(exp(fi/T)) void?scalefitness() { ?int?j=0; ?sumofscale_fitness?=?sumofscalefitness(); ?for(j=0;jpopsize;j++) ?{ ??oldpop[j].scale_fitness?=?exp((oldpop[j].fitness)/T)/sumofscale_fitness; ?} } //若代价0,表明需要重构(交叉),若代价0,重构概率为exp(-de/t) int?metrop(double?p_de,?double?p_T) { ?if(p_de0)?return(1); ?else?if(flip(exp((-1)*p_de/p_T)))?return(1); ?else?return(0); } //计算代价 de?=?cospop[j].fitness?-?fmin(oldpop[mate1].fitness,oldpop[mate2].fitness); //预测 ans?=?metrop(de,T); //经过试探性的交叉之后以及由预测判断完毕,可以确定是否真的需要重构(交叉) if(ans)???/*?需要重构?*/ { ????newpop[j].fitness?=?cospop[j].fitness; ????newpop[j].tem

文档评论(0)

天马行空 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档