matlab练习程序(演化策略ES)

还是这本书上的内容,不过我看演化计算这一章是倒着看的,这里练习的算法正好和书中介绍的顺序是相反的。

演化策略是最古老的的演化算法之一,和上一篇DE算法类似,都是基于种群的随机演化产生最优解的算法。

算法步骤如下:

1.设定种群个体数和需要迭代的次数。
2.选择父代中的个体按照公式z1=sqrt(-2*ln(u1))*sin(2*pi*u2)*m,z2=sqrt(-2*ln(u1))*cos(2*pi*u2)*m进行演化。

这里u1,u2都是随机值,m是控制因子,演化次数越多m,m越小,父代通过与z1,z2相加得到后代。

3.计算后代的适应性。

4.选择后代中最优的适应性作为全局最优适应性。

其实整个过程和DE非常类似。过程都是随机变异,求适应性,再找最优。

我还试着将z1和z2横设为1,竟也能得到非常好的解。

算法结果如下:

matlab代码如下:

main.m

clear all;close all;clc;

[x y]=meshgrid(-100:100,-100:100);
sigma=50;
img = (1/(2*pi*sigma^2))*exp(-(x.^2+y.^2)/(2*sigma^2)); %目标函数,高斯函数
mesh(img);
hold on;
n=50;       %种群个体的数量
iter=100;   %迭代次数

%初始化种群,定义结构体
par=struct([]);
for i=1:n
    par(i).x=-100+200*rand();       %个体的x特征在[-100 100]随机初始化
    par(i).y=-100+200*rand();       %个体的y特征在[-100 100]随机初始化
    par(i).fit=compute_fit(par(i));       %个体在[x,y]处的适应度
end
par_best=par(1);    %初始化种群中最佳个体

for k=1:iter     %迭代次数
    plot3(par_best.x+100,par_best.y+100,par_best.fit,'g*'); %画出最佳个体的位置,+100为相对偏移
    [par par_best]=select_and_recombin(par,par_best,n,k,iter);     %差异演化函数
end

select_and_recombin.m

function [next_par par_best]=select_and_recombin(par,par_best,n,k,iter)
    mul=(iter-k)/iter;  %限制进化因子,代数越高变异越小
    next_par=par;       %新种群
    for i=1:n
        
        %产生变异随机数        
        u1=rand();  
        u2=rand();
        z1=sqrt(-2*log(u1))*sin(2*pi*u2)*mul;
        z2=sqrt(-2*log(u1))*cos(2*pi*u2)*mul;

        %变异
        next_par(i).x=par(i).x+z1;      
        next_par(i).y=par(i).y+z2;              
      
        %计算变异后个体的适应度
        next_par(i).fit=compute_fit(next_par(i));
        %如果新个体没有变异前个体适应度高,新个体还原为旧个体
        if par(i).fit>next_par(i).fit
            next_par(i)=par(i);
        end
        %如果变异后适应度高于种群最高适应个体,则更新种群适应度最高个体
        if next_par(i).fit>par_best.fit
            par_best=next_par(i);
        end
    end    
end

compute_fit.m

function re=compute_fit(par)
    x=par.x;
    y=par.y;
    sigma=50;
    if x<-100 || x>100 || y<-100 || y>100 
        re=0;        %超出范围适应度为0
    else            %否则适应度按目标函数求解
        re=(1/(2*pi*sigma^2))*exp(-(x.^2+y.^2)/(2*sigma^2)); 
    end
end

 

posted @ 2013-07-01 19:37  Dsp Tian  阅读(4169)  评论(0编辑  收藏  举报