遗传算法求函数极值.docVIP

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

智能优化算法第一次作业

--------------遗传算法洪文杰S151000853

问题:用遗传算法求解f(x)=xsin(10π*x)+2、0得最大值,x取[-1,2]、

一、分析:遗传算法基本思路

二、实例简介

1、产生初始种群

s1=13(01101)

s2=24(11000)?

s3=8?(01000)

s4=19(10011)

?2、计算适应度

假定适应度为f(s)=s^2,则

f(s1)=f(13)=13^2=169

f(s2)=f(24)=24^2=576

f(s3)=f(8)=8^2=64

f(s4)=f(19)=19^2=361

3、?选择

染色体得选择概率为:

染色体得累计概率为:

根据上面得式子,可得到:

例如设从区间[0,1]中产生4个随机数:?

??r1=0、450126,??r2=0、110347?

??r3=0、572496,??r4=0、98503?

4、交叉

基本遗传算法(SGA)中交叉算子采用单点交叉算子。

单点交叉运算

5、?变异

6、?至下一代,适应度计算→选择→交叉→变异,直至满足终止条件

三、解决问题

初始化输入种群大小,交叉概率,变异概率等条件

初始化输入种群大小,交叉概率,变异概率等条件

根据精度编码将区间[-1,2]分成Num份,再通过Num求解种群基因个数([-1,2]用二进制等分)

计算每个个体得适应度,该题适应度函数就就是f(X)

根据适应度求解积累概率,并用轮盘赌法选着个体产生备选种群

在备选种群中,利用交叉概率,随机选择个体,再随机选择交叉点进行单点交叉,形成交叉后得种群

在交叉后种群中,利用变异概率,随机选择个体,再随机选择变异点进行单点变异,形成变异后得种群

就是否达到迭代次数

输出结果最大值。

就是

四、实验结果

源代码:

/*问题:用遗传算法求解f(x)=xsin(10π*x)+2、0得最大值,x取[-1,2]、*/

/*洪文杰2016-3-9、智能优化算法第一次作业*/

#includeiostream

//#includ<stdio、h

#includestdlib、h>

#include<math、h>

#include<time、h

#include<float、h

usingnamespacestd;

#defineNUMBER50//种群规模

#defineGENE_NUMBER10000//迭代次数

intUnit[NUMBER][30];//初始种群

intUnit_choose[NUMBER][30];//选择、交叉、变异后得种群

intNumber[NUMBER];//被选择得个体编号

floatFitness[NUMBER];//适应度

floatselect_probability[NUMBER];//选择概率

floataccumula_probability[NUMBER];//积累概率

floatf_max=0、0;//最大值

floatf_x=0、0;//最大值对应得自变量

inthwj_coding(intstart,intend);//编码

voidhwj_initial_population(intnum);//产生初始种群

voidhwj_fitness(intnum);//适应度计算

voidhwj_choose();//选择个体

inthwj_binary_search(intl,intr,floattemp);//查找选择

//voidhwj_N_M(inta[],intb[],intN,intM);//从M个数中选N个不一样得数

voidhwj_cross(intnum,floatcross);//交叉后得得到种群

voidhwj_aberrance(intnum,floataberrance);//变异后得得到得种群

voidhwj_max(intnum);//找到最适应得个体

intmain(){

?intstrat,end;//区间

intNum;//编码大小

floatcross=0、8;//交叉概率

floataberrance=0、04;//变异概率

intkey=1;

cout请输入求解区间:<endl;

cinstrat>end;

?Num=hwj_coding(strat,end);

?cout<"Num:<Numendl;

// cout<"------------------------

您可能关注的文档

文档评论(0)

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

文档文档,就是专业

1亿VIP精品文档

相关文档