差分进化算法介绍及matlab实现
引言
差分进化算法是基于群体智能理论的优化算法,是通过群体内个体间的合作与竞争而产生的智能优化搜索算法,它保留了基于种群的全局搜索策略,采用实数编码、基于差分的简单变异操作和“一对一”的竞争生存策略,降低了进化计算操作的复杂性。
差分进化算法的原理
差分进化算法是一种自组织最小化方法,利用种群中两个随机选择的不同向量来干扰现有向量,种群中的每一个向量都要进行干扰。
- 它通过把种群中的两个成员之间的加权差向量加到第三个成员上来产生新的参数向量,该操作成为“变异”。
- 将变异向量的参数与另外预先确定的目标向量参数按一定规则混合来产生实验向量,该操作成为“交叉”;
- 若实验向量的代价函数比目标向量的代价函数低,实验向量就在下一代中替代目标向量,该操作成为“选择”;
差分进化算法流程
具体步骤如下:
- 确定差分进化算法的控制参数和所要采用的具体策略。控制参数包括:种群数量、变异算子、交叉算子、最大进化代数、终止条件等。
- 随机产生初始种群,进化代数k=1;
- 对初始种群进行评价,即计算初始种群中每个个体的目标函数值。
- 判断是否达到终止条件或达到最大进化代数;若是,则进化终止,将此时的最佳个体作为解输出;否则,继续下一步操作。
- 进行变异操作和交叉操作,对边界条件进行处理,得到临时种群。
- 对临时种群进行评价,计算临时种群中每个个体的目标函数值。
- 对临时种群中的个体和原种群中对应的个体,进行“一对一”的选择操作,得到新种群。
- 进化代数k=k+1,转步骤(4).
实例:
$$计算函数的最小值,其中个体x的维数n=10.这是一个简单的平方和函数,只有一个极小点x=(0,0,...,0)。$$
%%%%%%%差分进化求函数极值%%%%%%%%%
%%%%%%%初始化%%%%%%%%
clear all;
close all;
clc;
NP = 50; %种群的数量
D = 10; %变量的维度
G = 200; %最大进化代数
F0 = 0.4; %初始变异算子
CR = 0.1; %交叉算子
Xs = 20; %上限
Xx = -20; %下限
yz = 10^-6; %阈值
%%%%%%%%赋初值%%%%%%%%%%%%
x = zeros(D,NP); %初始种群
v = zeros(D,NP); %变异种群
u = zeros(D,NP); %选择种群
x = rand(D,NP) * (Xs-Xx) + Xx; %赋初值
%%%%%%%%%%计算目标函数%%%%%%%%%%%
for m = 1:NP
Ob(m) = func1(x(:,m));
end
trace(1) = min(Ob);
%%%%%%%%%差分进化循环%%%%%%%%%%
for gen = 1:G
%%%%%%%%%%%变异操作%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%自适应变异算子%%%%%%%
lamda = exp(1-G/(G+1-gen));
F = F0*2^(lamda);
%%%%%%%%r1,r2,r3和m互不相同%%%%
for m = 1:NP
r1 = randi([1,NP],1,1);
while(r1 == m)
r1 = randi([1,NP],1,1);
end
r2 = randi([1,NP],1,1);
while (r2 == m) | (r2 == r1)
r2 = randi([1,NP],1,1);
end
r3 = randi([1,NP],1,1);
while (r3 == m) | (r3 == r1 | r3 == r2)
r3 = randi([1,NP],1,1);
end
v(:,m) = x(:,r1) + F * (x(:,r2) - x(:,r3));
end
%%%%%%%%%%%%%%%%%%交叉操作%%%%%%%%%%%%%%%%%
r = randi([1,NP],1,1); %确保必有一个v(:)进入u(:)中
for n = 1:D
cr = rand(1);
if (cr <= CR) | (n == r)
u(n,:) = v(n,:); %批量操作,替换所有个体第n维
else
u(n,:) = x(n,:);
end
end
%%%%%%%%%%%%%%%%边界条件的处理%%%%%%%%%%%%%%%
for n = 1:D
for m = 1:NP
if (u(n,m) < Xx) | (u(n,m) > Xs)
u(n,m) = rand * (Xs - Xx) + Xx;
end
end
end
%%%%%%%%%%%%%%%%选择操作%%%%%%%%%%%%%%%%%%%%
for m = 1:NP
Ob1(m) = func1(u(:,m));
end
for m = 1:NP
if Ob1(m) < Ob(m)
x(:,m) = u(:,m);
end
end
for m = 1:NP
Ob(m) = func1(x(:,m));
end
trace(gen+1) = min(Ob);
if min(Ob) < yz
break;
end
end
%%%%%%%%%%%%%%%%画图%%%%%%%%%%%%%%%
figure
plot(trace);
xlabel('迭代次数');
ylabel('目标函数值');
title('DE目标函数曲线');
%%%%%%%%%%%%%%适应度函数%%%%%%%%%%
function result = func1(x)
summ = sum(x.^2);
result = summ;
end
差分进化算法介绍及matlab实现的更多相关文章
- 标准差分进化算法matlab程序实现(转载)
标准差分进化算法matlab程序实现 自适应差分演化算法方面的Matlab和C++代码及论文 差分进化算法 DE-Differential Evolution matlab练习程序(差异演化DE) [ ...
- 差分进化算法 DE-Differential Evolution
差分进化算法 (Differential Evolution) Differential Evolution(DE)是由Storn等人于1995年提出的,和其它演化算法一样,DE是一种模拟生物进化 ...
- 差分进化算法(DE)的C++面向对象方法实现
代码来源于网络,写得非常棒 /*DE_test *对相应的Matlab程序进行测试 */ #include <iostream> #include <cmath> #inclu ...
- 差分进化算法-python实现
DEIndividual.py import numpy as np import ObjFunction class DEIndividual: ''' individual of differen ...
- Python遗传和进化算法框架(一)Geatpy快速入门
https://blog.csdn.net/qq_33353186/article/details/82014986 Geatpy是一个高性能的Python遗传算法库以及开放式进化算法框架,由华南理工 ...
- [Evolutionary Algorithm] 进化算法简介
进化算法,也被成为是演化算法(evolutionary algorithms,简称EAs),它不是一个具体的算法,而是一个“算法簇”.进化算法的产生的灵感借鉴了大自然中生物的进化操作,它一般包括基因编 ...
- 基于改进人工蜂群算法的K均值聚类算法(附MATLAB版源代码)
其实一直以来也没有准备在园子里发这样的文章,相对来说,算法改进放在园子里还是会稍稍显得格格不入.但是最近邮箱收到的几封邮件让我觉得有必要通过我的博客把过去做过的东西分享出去更给更多需要的人.从论文刊登 ...
- 蚁群算法和简要matlab来源
1 蚁群算法原理 从1991由意大利学者 M. Dorigo,V. Maniezzo 和 A. Colorni 通过模拟蚁群觅食行为提出了一种基于群体的模拟进化算法--蚁群优化.极大关注,蚁群算法的特 ...
- geatpy - 遗传和进化算法相关算子的库函数(python)
Geatpy The Genetic and Evolutionary Algorithm Toolbox for Python Introduction Website (including doc ...
随机推荐
- 我不信这篇文章能让你学会C语言,但是我还是想分享一下!
前言 C 语言是一门抽象的.面向过程的语言,C 语言广泛应用于底层开发,C 语言在计算机体系中占据着不可替代的作用,可以说 C 语言是编程的基础,也就是说,不管你学习任何语言,都应该把 C 语言放在首 ...
- 扫描仪扫描文件处理-图像扫描加工到生成PDF步骤简述[JAVA版]
另参见:https://www.cnblogs.com/whycnblogs/p/8034276.html 详细见:https://github.com/barrer/scan-helper 用途: ...
- Logstash 国内加速下载 转
Logstash. 国内直接从官网(https://www.elastic.co)下载比较困难,需要一些技术手段.这里提供一个国内的镜像下载地址列表,方便网友下载. 找不到想要的版本?您可以访问 索引 ...
- Eclipse JSP +Tomcat 环境搭建 错误记录
环境搭建请参考原文:https://www.cnblogs.com/james-lee/p/5964238.html 错误1:运行时,弹出如下错误:(如果没有此错误,请忽略) 原因是,我们之前点击了T ...
- Halcon软件介绍与图像基本知识
1.halcon环境 halcon功能:1.视觉算法(核心)基本 2. 弱语言 3.解释性语言 halcon软件介绍: 1.标题栏 2.菜单栏 3.工具栏 4.工作区 图形窗口(显示图像) 变量窗口( ...
- 懒人福音——GitHub 热点速览 Vol.42
作者:HelloGitHub-小鱼干 懒人福音是什么?就是省时省事,正如 Waypoint 一样,你不需要在多个平台构建代码即可部署发布应用,它允许你将应用程序构建.部署和发布生命周期定义为代码.Bi ...
- Linux 发行版本简介
1991年的10月5日Linus Benedict Torvalds在comp.os.minix 新闻组上发布消息,正式向外宣布他自行编写的完全自由免费的内核诞生(Freeminix-like ker ...
- 64位Ubuntu14.04配置adb后提示No such file or directory
配置好SDK的环境变量后,输入adb提示 No such file or directory. 原因:由于是64位的linux系统,而Android SDK只有32位的,需要安装一些支持包才能使用 1 ...
- git学习(八) git stash操作
git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容.git stash作用的范围包括工作区和暂存区中的内容,没有提交的内容都会 ...
- Linux入门到放弃之一《在VMware虚拟机中安装Linux系统(RedHat)》
1.启动VMware: 2.新建虚拟机: 3.自定义配置(1安装客户机操作系统点击"稍后安装操作系统"2选择客户机操作系统为Linux,版本为Red Hat Enterprise ...