求遗传算法的matlab程序

求遗传算法的matlab程序,第1张

function

my_ga()

options=gaoptimset

%设置变量范围

options=gaoptimset(options,'PopInitRange',[09])

%设置种群大小

options=gaoptimset(options,'PopulationSize',100)

%设置迭代次数

options=gaoptimset(options,'Generations',100)

%选择选择函数

options=gaoptimset(options,'SelectionFcn',@selectionroulette)

%选择交叉函数

options=gaoptimset(options,'CrossoverFcn',@crossoverarithmetic)

%选择变异函数

options=gaoptimset(options,'MutationFcn',@mutationuniform)

%设置绘图:解的变化、种群平均值的变化

options=gaoptimset(options,'PlotFcns',{@gaplotbestf})

%执行遗传算法,fitness.m是函数文件

[x,fval]=ga(@fitness,1,options)

function ret=Code(lenchrom,bound)

%本函数将变量编码成染色体,用于随机初始化一个种群

% lenchrom input : 染色体长度

% bound input : 变量的取值范围

% retoutput: 染色体的编码值

flag=0

while flag==0

pick=rand(1,length(lenchrom))

ret=bound(:,1)'+(bound(:,2)-bound(:,1))'.*pick%线性插值

flag=test(lenchrom,bound,ret)%检验染色体的可行性

end

function ret=Cross(pcross,lenchrom,chrom,sizepop,bound)

%本函数完成交叉 *** 作

% pcorssinput : 交叉概率

% lenchrom input : 染色体的长度

% chrom input : 染色体群

% sizepop input : 种群规模

% ret output : 交叉后的染色体

for i=1:sizepop

% 随机选择两个染色体进行交叉

pick=rand(1,2)

while prod(pick)==0

pick=rand(1,2)

end

index=ceil(pick.*sizepop)

% 交叉概率决定是否进行交叉

pick=rand

while pick==0

pick=rand

end

if pick>pcross

continue

end

flag=0

while flag==0

% 随机选择交叉位置

pick=rand

while pick==0

pick=rand

end

pos=ceil(pick.*sum(lenchrom))%随机选择进行交叉的位置,即选择第几个变量进行交叉,注意:两个染色体交叉的位置相同

pick=rand%交叉开始

v1=chrom(index(1),pos)

v2=chrom(index(2),pos)

chrom(index(1),pos)=pick*v2+(1-pick)*v1

chrom(index(2),pos)=pick*v1+(1-pick)*v2%交叉结束

flag1=test(lenchrom,bound,chrom(index(1),:)) %检验染色体1的可行性

flag2=test(lenchrom,bound,chrom(index(2),:)) %检验染色体2的可行性

if flag1*flag2==0

flag=0

else flag=1

end%如果两个染色体不是都可行,则重新交叉

end

end

ret=chrom

clc

clear all

% warning off

%% 遗传算法参数

maxgen=50%进化代数

sizepop=100 %种群规模

pcross=[0.6] %交叉概率

pmutation=[0.1] %变异概率

lenchrom=[1 1] %变量字串长度

bound=[-5 5-5 5]%变量范围

%% 个体初始化

individuals=struct('fitness',zeros(1,sizepop), 'chrom',[]) %种群结构体

avgfitness=[] %种群平均适应度

bestfitness=[] %种群最佳适应度

bestchrom=[] %适应度最好染色体

% 初始化种群

for i=1:sizepop

individuals.chrom(i,:)=Code(lenchrom,bound) %随机产生个体

x=individuals.chrom(i,:)

individuals.fitness(i)= (x(1)*exp(-(x(1)^2 + x(2)^2)))

%-20*exp(-0.2*sqrt((x(1)^2+x(2)^2)/2))-exp((cos(2*pi*x(1))+cos(2*pi*x(2)))/2)+20+2.71289

% 这个是我的测试函数

% 如果有这个函数的话,可以得到最优值

end

%找最好的染色体

[bestfitness bestindex]=min(individuals.fitness)

bestchrom=individuals.chrom(bestindex,:) %最好的染色体

avgfitness=sum(individuals.fitness)/sizepop%染色体的平均适应度

% 记录每一代进化中最好的适应度和平均适应度

trace=[]

%% 进化开始

for i=1:maxgen

% 选择 *** 作

individuals=Select(individuals,sizepop)

avgfitness=sum(individuals.fitness)/sizepop

% 交叉 *** 作

individuals.chrom=Cross(pcross,lenchrom,individuals.chrom,sizepop,bound)

% 变异 *** 作

individuals.chrom=Mutation(pmutation,lenchrom,individuals.chrom,sizepop,[i maxgen],bound)

% 计算适应度

for j=1:sizepop

x=individuals.chrom(j,:)

individuals.fitness(j)=(x(1)*exp(-(x(1)^2 + x(2)^2)))

%-20*exp(-0.2*sqrt((x(1)^2+x(2)^2)/2))-exp((cos(2*pi*x(1))+cos(2*pi*x(2)))/2)+20+2.71289

% -20*exp(-0.2*sqrt((x(1)^2+x(2)^2)/2))-exp((cos(2*pi*x(1))+cos(2*pi*x(2)))/2)+20+2.71289

end

%找到最小和最大适应度的染色体及它们在种群中的位置

[newbestfitness,newbestindex]=min(individuals.fitness)

[worestfitness,worestindex]=max(individuals.fitness)

% 代替上一次进化中最好的染色体

if bestfitness>newbestfitness

bestfitness=newbestfitness

bestchrom=individuals.chrom(newbestindex,:)

end

individuals.chrom(worestindex,:)=bestchrom

individuals.fitness(worestindex)=bestfitness

avgfitness=sum(individuals.fitness)/sizepop

trace=[traceavgfitness bestfitness]%记录每一代进化中最好的适应度和平均适应度

end

%进化结束

%% 结果显示

[r c]=size(trace)

figure

plot([1:r]',trace(:,1),'r-',[1:r]',trace(:,2),'b--')

title(['函数值曲线 ' '终止代数=' num2str(maxgen)],'fontsize',12)

xlabel('进化代数','fontsize',12)ylabel('函数值','fontsize',12)

legend('各代平均值','各代最佳值','fontsize',12)

ylim([-0.5 5])

disp('函数值 变量')

% 窗口显示

disp([bestfitness x])

在matlab里没有

for

i

=

1

to

80

...

endfor

这样的语法的

在matlab里应该是:

for

i

=

1:

1:

80

...

end

1:1:80

第一个1是初始值,第二个是每次+1的意思

当然如果是我古若寡闻那也请见谅~~哈哈~~


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11030473.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存