实数编码的遗传算法与MATLAB

久未见 提交于 2020-03-10 10:52:53

实数编码的遗传算法与MATLAB

(一)函数示例

Z=x.^2-10*cos(2*pi*x)+10+y.^2-10*cos(2*pi*y)+10

(二)MATLAB的实现
1)GAss(主函数)

clc
clear
x=-5.12:0.01:5.12;
y=-5.12:0.01:5.12;
[X,Y]=meshgrid(x,y);
Z=X.^2-10*cos(2*pi*X)+10+Y.^2-10*cos(2*pi*Y)+10;
mesh(X,Y,Z)

%%%%%%%%%%%%%%%初始化种群%%%%%%%%%%%
N=50;dim=2;B=5.12;Pc=0.75;pm=0.3
Po=-B+rand(N,2)*2*B;
%%%%%%%%%%%%函数评价%%%%%%%%%%%%%%%
for it=1:10
    for i=1:N
        fit(i)=GAmb(Po(i,1),Po(i,2));
    end
    [ymax,ind1]=max(fit);
    figure(1)
    set(gca,'nextplot','replace');
    mesh(X,Y,Z)
    hold on
    plot3(Po(:,1),Po(:,2),fit,'b*')
    plot3(Po(ind1,1),Po(ind1,2),fit(ind1),'mo')
    %%%%%%%%%%%%%%选择%%%%%%%%%%%%%%%
    p=fit/sum(fit); %%计算比例概率
    Lp(1)=fit(1);
    for i=2:N
        Lp(i)=Lp(i-1)+fit(i); %%计算累积概率
    end
    for i=1:N
        ind=find((Lp-rand)>0); %%找出轮盘赌选择的指标
        Co(i)=ind(1);
        nPo(i,:)=Po(ind(1),:); %%将对应指标的染色体取出来赋值给新的种群
    end
    %%%%%%%%%%%%%%交叉%%%%%%%%%%%%%%%%%%
    for i=1:2:N
        [x1,y1]=GAjc(nPo(i,:),nPo(i+1,:),Pc);
        Nnpo(i,:)=x1;
        Nnpo(i+1,:)=y1;
    end
    %%%%%%%%%%%%%%变异%%%
    for i=1:N
        Npo(i,:)=GAby(Nnpo(i,:),pm);
    end
    %%%%%%%%%%%%%%%%%%%%%
    %保留最好的个体
    Npo(1,:)=Po(ind1,:);
    Npo(41:N,:)=-B+rand(10,2)*2*B;%%避免早熟
    %%新的种群要赋值给原来的变量
    Po=Npo;
end

2)GAmb(目标函数)

function    z1=GAmb(x1,y1)
z1=x1^2-10*cos(2*pi*x1)+10+y1^2-10*cos(2*pi*y1)+10;

3)GAjc(交叉函数)

function  [x1,y1]=GAjc(x,y,Pc)
if  rand<Pc
lameda1=0.4;
x1=lameda1*x+(1-lameda1)*y;
y1=lameda1*y+(1-lameda1)*x;
else
   x1=x; 
   y1=y;
 end

4)GAby(变异函数)

function x=GAby(x,pm)
if rand<pm
    x=x+[(1-2*rand)*10e-3  (1-2*rand)*10e-3 ];
end

5)结果图例
在这里插入图片描述

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!