- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
简单的二元遗传matlab算法
老师:
这是简单的y=x1^2+x2^2,其中x1,x2在[-10,10]
%产生初始种群pop,共a个个体,每个个体编码长度为b
function [pop1,pop2]=initate(a,b)
pop1=round(rand(a,b));
pop2=round(rand(a,b));
%通过number函数将个体编码转化为十进制并落在区间内
function [x1,x2]=number(pop1,pop2)
[a,b]=size(pop1);
pop11=zeros(a,b);
pop22=zeros(a,b);
for i=1:b
pop11(:,i)=pop1(:,i).*2^(b-i);
pop22(:,i)=pop2(:,i).*2^(b-i);
end
pop11=sum(pop11,2);
pop22=sum(pop22,2);
x1=(pop11.*20)./2^b-10;
x2=(pop22.*20)./2^b-10;
%计算个体适应值
function fit=fitness(x1,x2)
fit=x1.^2+x2.^2;
%通过选择/交叉/变异产生新的种群
function [newpop1,newpop2]=new(pop1,pop2,pm,pc)
[a,b]=size(pop1);
newpop1=pop1;
newpop2=pop2;
[x1,x2]=number(pop1,pop2);
fit=fitness(x1,x2);
fitvalue=fit/sum(fit);
pw=fitvalue(1);
ps=sort(rand(a));
new=1;
for i=1:a
if ps(i)pw
newpop1(i)=pop1(new);
newpop2(i)=pop2(new);
else
new=new+1;
pw=pw+fitvalue(new);
end
end
for i=1:a
if randpc
point1=round(rand*(b-1)+1);
newpop1(i,1:point1)=pop1(a-i+1,1:point1);
newpop1(a-i+1,1:point1)=pop1(i,1:point1);
end
if randpc
point2=round(rand*(b-1)+1);
newpop2(i,1:point2)=pop2(a-i+1,1:point2);
newpop2(a-i+1,1:point2)=pop2(i,1:point2);
end
end
for i=1:a
if randpm
point1=round(rand*(b-1)+1);
newpop1(i,point1)=1-pop1(i,point1);
end
if randpm
point2=round(rand*(b-1)+1);
newpop2(i,point2)=1-pop2(i,point2);
end
end
%主函数
clear
a=30;
b=15;
pc=0.6;
pm=0.0001;
[pop1,pop2]=initate(a,b);
[x1,x2]=number(pop1,pop2);
fit=fitness(x1,x2);
[yy,xx]=min(fit);
besty=yy;
bestx1=x1(xx);
bestx2=x2(xx);
for N=1:200
[newpop1,newpop2]=new(pop1,pop2,pm,pc);
[x1,x2]=number(newpop1,newpop2);
fit=fitness(x1,x2);
[yy,xx]=min(fit);
if bestyyy
besty=yy;
bestx1=x1(xx);
bestx2=x2(xx);
end
pop1=newpop1;
pop2=newpop2;
end
[x1,x2]=number(pop1,pop2);
bestx1=x1(xx)
bestx2=x2(xx)
besty
您可能关注的文档
- 课时跟踪检测(二十五) 宋明理学及明清之际活跃的儒家思想.doc
- 课时跟踪检测(七) 新民主主义革命的崛起及国共十年对峙.doc
- 课时跟踪检测(二十九) 20世纪以来中国重大思想理论成果.doc
- 课时跟踪检测(三十二) 现代中国的科技、教育与文学艺术.doc
- 课时跟踪检测(三) 古代希腊、罗马的政治制度.doc
- 课时作业08常见天气系统.doc
- 课堂教学技能模拟题四.doc
- 课堂教学技能模拟题三.doc
- 课堂教学技能模拟题9.doc
- 课堂呼唤真情实感.doc
- 人教版九年级英语全一册单元速记•巧练Unit13【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit9【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit11【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit14【单元测试·提升卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit8【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit4【单元测试·提升卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit13【单元测试·基础卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit7【速记清单】(原卷版+解析).docx
- 苏教版五年级上册数学分层作业设计 2.2 三角形的面积(附答案).docx
- 人教版九年级英语全一册单元速记•巧练Unit12【单元测试·基础卷】(原卷版+解析).docx
最近下载
- 空调主机吊装方案.docx
- 基层儿科医务人员服务能力提升学习班答案-2024华医网继续教育答案.docx VIP
- 部编 人教版小学二年级上册语文教学课件 5.课文 14.我要的是葫芦 .pptx VIP
- 让“工具包”理念和方法落地.pdf VIP
- 国家开放大学《可编程控制器应用实训》形考任务2(实训二)参考答案.docx
- 4.2 实现中华民族伟大复兴的中国梦 课件(18张PPT)-2023-2024学年高中政治统编版必修一中国特色社会主义.pptx VIP
- 费森尤斯CRRT操作流程.doc VIP
- 五年级上册英语期中试卷人教精通版.pdf VIP
- 第17课昆明的雨(课件)(共27张PPT).pptx VIP
- 小学信息技术(信息科技)第六册泰山版(2018)合集.docx
文档评论(0)