- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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<"------------------------
您可能关注的文档
- 四年级数学上册全册练习题.docx
- 2015版质量及环境体系全套程序文件.doc
- 国际金融名词解释 (2).doc
- 幼儿园大班数学活动找规律 PPT.ppt
- 各种管道标识 PPT.ppt
- 可视化管理手册.doc
- 综合布线题目汇总.doc
- 化学化学实验室意外事故的应急处理办法.doc
- 第10章 网络常见故障及处理 PPT.ppt
- 第五节获得性免疫缺陷综合征病人的护理.pptx
- 广东省深圳市龙岗区德琳学校初中部2022-2023学年七年级上学期期中考试英语试题(原卷版+解析).docx
- 广东省珠海市第四中学、立才学校、梅华中学2022-2023学年七年级上学期期中质量检测英语试题(原卷版+解析).docx
- 教科版2024-2025学年六年级科学上册第一单元第4课时《生物细胞》同步练习(含答案).docx
- 牛津沪教版七年级英语上册单元速记•巧练 Unit 7 【单元测试 · 提高卷】.docx
- 牛津沪教版七年级英语上册单元速记•巧练 Unit 5【单元测试 · 基础卷】.docx
- 广东省深圳市南山区太子湾学校2022-2023学年七年级上学期期中考试英语试题(原卷版+解析).docx
- 广东省深圳市南山第二外国语学校(集团)2022-2023学年七年级上学期期中考试英语试题(含听力)(原卷版+解析).docx
- 牛津沪教版七年级英语上册单元速记•巧练 2023-2024学年七年级上学期期末英语全真模拟卷(深圳适用02).docx
- 广东省阳江市江城区2022-2023学年七年级上学期期中考试英语试题(原卷版+解析).docx
- 广东省梅州市梅县区宪梓中学2022-2023学年七年级上学期期中英语试题(原卷版+解析).docx
文档评论(0)