在好例子网,分享、交流、成长!
您当前所在位置:首页MATLAB 开发实例MATLAB语言基础 → 差分进化算法

差分进化算法

MATLAB语言基础

下载此实例
  • 开发语言:MATLAB
  • 实例大小:0.02M
  • 下载次数:20
  • 浏览次数:127
  • 发布时间:2021-04-19
  • 实例类别:MATLAB语言基础
  • 发 布 人:251898840
  • 文件格式:.doc
  • 所需积分:2
 相关标签: 差分进化 算法 MATLAB

实例介绍

差分演化算法的matlab程序:

 

function DE(Gm,F0)

%差分进化算法程序基本程序

%F是变异率   F0=0.6 Gm=1000; %最大迭代次数

Np=100; %种群规模

CR=0.9;  %杂交参数

G=1;%初始化代数

D=0;%所求问题的维数

eps=1e-9;%精度

ge=zeros(1,Np);%各代的最优值

bestx=zeros(Np,D);%各代的最优解

%产生初始种群

%xmin=-10;xmax=100;%带负数的下界

xmin=-5.12;xmax=5.12;

%-----函数值计算-----------

function result=DEMB(XX);

     sol=XX;

     result=0;

for i=1:D

    result=result sol(i)^2;

    %y=sum(XX.^2-10.*cos(2.*pi.*XX) 10);

end

end

%---------------------------

X0=(xmax-xmin)*rand(Np,D) xmin;

X=X0;

%%%%%%%%%%变异操作

X1new=zeros(Np,D);%初始化

X1_new=zeros(Np,D);%初始化

X1=zeros(Np,D);%初始化

value=zeros(1,Np);

while G<=Gm

    for i=1:Np

    %产生j,k,p三个不同的数

    a=1;b=Np;

    dx=randperm(b-a 1) a-1;

    j=dx(1);k=dx(2);p=dx(3);

    if j==i

        j=dx(4);

    elseif k=i

        k=dx(4);

    elseif p==i

        p=dx(4);

    end

    %变异算子

    F=0.5;

    bon=X(p,:) F*(X(j,:)-X(k,:));

    if (bon>xmin)&(bon<xmax) %防止变异超出边界

       X1new(i,:)=bon;

    else X1new(i,:)=(xmax-xmin)*rand(1,D) xmin;

    end

    end

%%%%%%%%%%%%杂交操作

    for i=1:Np

        if rand>CR %利用二项分布来交叉

            X1_new(i,:)=X(i,:);

        else

            X1_new(i,:)=X1new(i,:);

        end

    end

 %%%%%%%%%%%%%%%竞争操作

  

 for i=1:Np

     if DEMB(X1_new(i,:))<DEMB(X(i,:))

         X1(i,:)=X1_new(i,:);

     else

         X1(i,:)=X(i,:);

     end

 end

 %找出最小值

     for i=1:Np

          value(i)=DEMB(X1(i,:));

     end

    [fmin,min]=min(value);

    ge(G)=fmin;

    bestx(G,:)=X1(nmin,:);

    G=G 1;

    X=X1;

end

%ii=linspace(1,Np,Np);

%plot(ii,ge)

[gmin,n]=min(ge);

value=gmin

solution=bestx(n,:)

%目标函数的倒数

End

 

实例下载地址

差分进化算法

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警