网站大量收购独家精品文档,联系QQ:2885784924

遗传算法例子..docVIP

  1. 1、本文档共5页,可阅读全部内容。
  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文档。上传文档
查看更多
遗传算法例子.

基于此共同点,人们总结出了最基本的遗传算法——基本遗传算法。基本遗传算法只使用选择、、、{}{}种不同的编码,若参数与编码的对应关系为 00000000000…0 →a 00000000000…1 →a+δ ? ? ? 111111111111…-1→b 则二进制编码的编码精度 假设某一个个体的编码是,则对应的解码公式为 例如,对于[0,1023],若用长度为10的二进制编码来表示该参数的话,则下述符号串: =0010101111 就表示一个个体,它对应的参数值是=175.此时的编码精度为1. 二进制编码方法相对于其它编码方法的优点,首先是编码、解码操作简单易行;其次是交叉遗传操作便于实现;另外便于对算法进行理论分析。 2. 个体适应度函数 在遗传算法中,根据个体适应度的大小来确定该个体在选择操作中被选定的概率。个体的适应度越大,该个体被遗传到下一代的概率也越大;反之,个体的适应度越小,该个体被遗传到下一代的概率也越小。基本遗传算法使用比例选择操作方法来确定群体中各个个体是否有可能遗传到下一代群体中。为了正确计算不同情况下各个个体的选择概率,要求所有个体的适应度必须为正数或为零,不能是负数。这样,根据不同种类的问题,必须预先确定好由目标函数值到个体适应度之间的转换规则,特别是要预先确定好目标函数值为负数时的处理方法。 设所求解的问题为:, . 对于求目标函数最小值的优化问题,理论上只需简单地对其增加一个负号就可将其转化为求目标函数最大值的问题,即 当优化问题是求函数最大值,并且目标函数总取正值时,可以直接设定个体的适应度函数值就等于相应的目标函数值,即. 但实际目标优化问题中的目标函数有正也有负,优化目标有求函数最大值,也有求函数最小值,显然上面两式保证不了所有情况下个体的适应度都是非负数这个要求,必须寻求出一种通用且有效的由目标函数值到适应度之间的转换关系,有它来保证个体适应度总取非负值。 为满足适应度取负值的要求,基本遗传算法一般采用下面方法将目标函数值变换为个体的适应度 对于求目标函数最大值的优化方法问题,变换方法为 0 式中,为一个适当的相对比较小的数,它可以是预先指定的一个较小的数,或进化到当前代为止的最小目标函数值,又或当前代或最近几代群体中的最小目标函数值。 3.基本遗传操作方法 (1)比例选择:选择或称复制,建立在对个体适应度进行评价的基础之上。其作用是从当前群体中选择出一些比较优良的个体,并将其复制到下一代群体中。基本遗传算法采用比例选择的方法,所谓比例选择,是指个体在选择操作中被选中的概率与该个体的适应度大小成正比。 (2)单点交叉。单点交叉又称简单交叉,是遗传算法所使用的交叉操作方法。 (3)基本位变异。基本位变异石最简单和最基本的变异操作,也是基本遗传算法中所使用的变异操作方法。对于基本遗传算法中用二进制编码符号串所表示的个体,对需要进行变异操作的某一基因,若原有基因值为0,则变异操作将该基因值变为1;反之,若原有基因值为1,则变异操作将其变为0. 4.基本遗传算法的运行参数 执行基本遗传算法时,有4个参数需要事先指定。它们是群体的大小M、交叉概率、变异概率及终止的代数T. 群体大小M.群体的大小M表示群体中所含个体的数量。当M取值较小时,可提高遗传算法的运算速度,但却降低了群体的多样性,有可能会引起遗传算法的早熟现象;而当M取值较大时,又会使得遗传算法的运行效率偏低。一般建议范围是20~100. 交叉概率。交叉操作室遗传算法产生新个体的主要方法,所以交叉概率一般应取较大值。但若取值过大的话,它又会破坏群体活动的优良模式,对进化运算反而产生不利影响;若取值过小的话,产生新个体的速度有太慢。一般建议的取值范围是0.4~1.00. 变异概率。若变异概率取值较大的话,虽能够产生出较多的新个体,但也有可能破坏掉很多较好的模式,使得遗传算法的性能近似于随机搜索算法的性能;若变异概率取值太小的话,则变异操作产生新个体的能力和抑制早熟现象的能力就会较差。一般建议的取值范围是0.001~0.1. 终止代数T.终止代数T式表示遗传算法运行结束条件的一个参数,它表示遗传算法运行到指定的进化代数之后就停止运行,并将当前群体中的最佳个体作为所求问题的最优解输出。一般建议的取值范围是100~1000. 至于遗传算法的终止条件,还可以利用某种判定准则,当判定出群体已经进化成熟且不再有进化趋势时就可终止算法的运行过程。如连续几代个体平均适应度的差异小于某一个极小的值;或者群体中所有个体适应度的方差

文档评论(0)

sa43sad5 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档