遗传算法matlab实现源程序.doc

上传人:11****ws 文档编号:2249874 上传时间:2019-05-03 格式:DOC 页数:10 大小:83.50KB
下载 相关 举报
遗传算法matlab实现源程序.doc_第1页
第1页 / 共10页
遗传算法matlab实现源程序.doc_第2页
第2页 / 共10页
遗传算法matlab实现源程序.doc_第3页
第3页 / 共10页
遗传算法matlab实现源程序.doc_第4页
第4页 / 共10页
遗传算法matlab实现源程序.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

1、附页:一遗传算法源程序:clc;clear;population;%评价目标函数值for uim=1:popsizevector=population(uim,:);obj(uim)=hanshu(hromlength,vector,phen);end%obj%min(obj)clear uim;objmin=min(obj);for sequ=1:popsizeif obj(sequ)=objminopti=population(sequ,:);endendclear sequ;fmax=22000;%=for gen=1:maxgen%选择操作%将求最小值的函数转化为适应度函数for in

2、divi=1:popsizeobj1(indivi)=1/obj(indivi);endclear indivi;%适应度函数累加总合total=0;for indivi=1:popsizetotal=total+obj1(indivi);endclear indivi;%每条染色体被选中的几率for indivi=1:popsizefitness1(indivi)=obj1(indivi)/total;endclear indivi;%各条染色体被选中的范围for indivi=1:popsizefitness(indivi)=0;for j=1:indivifitness(indivi)=

3、fitness(indivi)+fitness1(j);endendclear j;fitness;%选择适应度高的个体for ranseti=1:popsizeran=rand;while (ran1|ranfitness(fet-1) cpoint2=round(rand*hromlength); while (cpoint2=cpoint1) cpoint2=round(rand*hromlength);endif cpoint1cpoint2 tem=cpoint1;cpoint1=cpoint2;cpoint2=tem;endcpoint1;cpoint2;for term=cpoi

4、nt1+1:cpoint2 for ss=1:hromlengthif popcross(int,ss)=popfath(term)tem1=popcross(int,ss);popcross(int,ss)=popcross(int,term);popcross(int,term)=tem1;endendclear tem1;endfor term=cpoint1+1:cpoint2 for ss=1:hromlengthif popcross(int+1,ss)=popmoth(term)tem1=popcross(int+1,ss);popcross(int+1,ss)=popcross

5、(int+1,term);popcross(int+1,term)=tem1;endendclear tem1;endendclear term;endclear randnum;popcross;%变异操作newpop=popcross;for int=1:popsizerandnum=rand;if randnumcpoint12=round(rand*hromlength); cpoint22=round(rand*hromlength); if (cpoint12=0)cpoint12=1;endif (cpoint22=0)cpoint22=1;endwhile (cpoint22=

6、cpoint12) cpoint22=round(rand*hromlength);if cpoint22=0;cpoint22=1;endendtemp=newpop(int,cpoint12);newpop(int,cpoint12)=newpop(int,cpoint22);newpop(int,cpoint22)=temp;endendnewpop;clear cpoint12;clear cpoint22;clear randnum;clear int;for ium=1:popsizevector1=newpop(ium,:);obj1(ium)=hanshu(hromlength

7、,vector1,phen);endclear ium;obj1max=max(obj1);for ar=1:popsizeif obj1(ar)=obj1maxnewpop(ar,:)=opti;endend%遗传操作结束二粒子群算法源程序:%-初始格式化-clear all;clc;format long;%-给定初始化条件-c1=1.4962;%学习因子 1c2=1.4962;%学习因子 2w=0.7298;%惯性权重MaxDT=100;%最大迭代次数D=2;%搜索空间维数(未知数个数)N=40;%初始化群体个体数目eps=10(-6);%设置精度(在已知最小值时候用)%-初始化种群的个

8、体(可以在这里限定位置和速度的范围)-for i=1:Nfor j=1:Dx(i,j)=randn;%随机初始化位置v(i,j)=randn;%随机初始化速度endend%-先计算各个粒子的适应度,并初始化 Pi 和 Pg-for i=1:Np(i)=fitness(x(i,:),D);y(i,:)=x(i,:);endpg=x(1,:);%Pg 为全局最优for i=2:Nif fitness(x(i,:),D)FITNESS(pg,D)pg=x(i,:);endend%-进入主要循环,按照公式依次迭代,直到满足精度要求-for t=1:MaxDTtfor i=1:Nv(i,:)=w*v(i

9、,:)+c1*rand*(y(i,:)-x(i,:)+c2*rand*(pg-x(i,:);x(i,:)=x(i,:)+v(i,:);if fitness(x(i,:),D)p(i)p(i)=fitness(x(i,:),D);y(i,:)=x(i,:);endif p(i)FITNESS(pg,D)pg=y(i,:);endendPbest(t)=fitness(pg,D);end%-进入主要循环,按照公式依次迭代,直到满足精度要求-for t=1:MaxDTfor i=1:Nv(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:)+c2*rand*(pg-x(i,:);

10、x(i,:)=x(i,:)+v(i,:);if fitness(x(i,:),D)p(i)p(i)=fitness(x(i,:),D);y(i,:)=x(i,:);endif p(i)FITNESS(pg,D)pg=y(i,:);endendPbest(t)=fitness(pg,D);end%-最后给出计算结果disp(*)disp(函数的全局最优位置为:)Solution=pgdisp(最后得到的优化极值为:)Result=fitness(pg,D)disp(*)X,Y=meshgrid(-500:2:500);Z=X.*sin(sqrt(X)+Y.*(sin(sqrt(Y);hold oncontour(X,Y,Z)plot(x(:,1),x(:,2),*);hold off

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 实用文档资料库 > 策划方案

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。