📄 gas.m
字号:
function [ok]=gas(popsize,lchrom,pcross,pmutation,maxgen)
% solve the max value of f(x)=x^2 in [0 31] by using GAs,
ok=0;
%%%%%%%%%%%% define variables
popsize=4; % popular size
lchrom=5; % length of chromosome
pcross=0.8;
pmutation=0.05;
maxgen=20; % max generation
%%%%%%%%%%%%% initial variables
oldpop=inital(popsize,lchrom)
newpop=zeros(popsize,lchrom);
bestever=zeros(maxgen,1);
bestsite=zeros(maxgen,1);
sumfit=0;
% maxfit=0;
% maxsite=0;
fitness=zeros(popsize,1);
[value10]=b2d(oldpop)
[sumfit,bestever(1),bestsite(1),fitness]=cfitness(value10,lchrom);
%%%%%%%%%%%%%%%%%%%%%% GAs Operation %%%%%%%%%%%%%%%%%%%%%%%%%%%%%
for gen=1:maxgen
for m=1:popsize
mate(m)=select(fitness,sumfit);
end
newpop=oldpop(mate,:)
for m=1:2:popsize
[newpop(m,:),newpop(m+1,:)]=cross(newpop(mate(m),:),newpop(mate(m+1),:),pcross,lchrom)
end
x=randint(1,popsize)
newpop(x,:)=mutation(newpop(x,:),pmutation,lchrom)
[value10]=b2d(newpop)
[sumfit,bestever(gen),bestsite(gen),fitness]=cfitness(value10,lchrom)
oldpop=newpop
end
x=[1:gen];
figure
plot(x,bestsite)
title('函数f(x)=x^2在[0 31]的最大值')
ok=1;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -