云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > 差分进化算法-入门

差分进化算法-入门

  • 62 次阅读
  • 3 次下载
  • 2025/5/5 13:18:59

差分进化算法-入门

基本差分进化算法

1基本差分进化算法的基本思想

DE算法是一种基于实数编码的用于优化函数最小值的进化算法,是在求解有关切比雪夫多项式的问题时提出来的,是基于群体差异的进化计算方法。它的整体结构类似于遗传算法,一样都存在变异、交叉和选择操作,但是它又不同于遗传算法。与基本遗传算法的主要区别在于变异操作上,如:

1、传统的遗传算法采用二进制编码,而差分进化算法采用实数编码。 2、在遗传算法中通过两个父代个体的交叉产生两个子个体,而在差分进化算法中通过第两个或几个个体的差分矢量做扰动来产生新个体。

3、在传统的遗传算法中,子代个体以一定概率取代其父代个体,而在差分进化中新产生的个体只有当它比种群中的个体优良时才替换种群中的个体。

变异是DE算法的主要操作,它是基于群体的差异向量来修正各个体的值,其基本原理是通过把种群中两个个体的向量差加权后,按一定的规划与第三个个体求和来产生新个体,然后将新个体与当代种群中某个预先决定的个体相比较,如果新个体的目标值优于与之相比较的个体的目标值,则在下一代中就用新个体取代,否则,旧个体仍保存下来。

差分进化算法其基本思想是:首先由父代个体间的变异操作构成变异个体;接着按一定的概率,父代个体与变异个体之间进行交叉操作,生成一试验个体;然后在父代个体与试验个体之间根据适应度的大小进行贪婪选择操作,保留较优者,实现种群的进化。 2 差分进化算法的基本操作

设当前进化代数为t,群体规模为NP,空间维数为D,当前种群为

X(t)??x,x,L,xt1t2tNP?,x??x,xtiti1ti2,L,xtTiD?为种群中的第i个个体。在进化过程

中,对于每个个体xit依次进行下面三种操作。 2.1 变异操作

tT),则 对于每个个体xit按下式产生变异个体vit?(vit1,vit2,L,viDtvij?xrt1j?F(xrt2j?xrt3j) j?1,2,L,D (1)

ttttTttttTttttT其中xr,和是群?(x,x,L,x)x?(x,x,L,x)x?(x,x,L,x)rrrr2r21r22r2Dr3r31r32r3D111121D体中随机选择的三个个体,并且r1?r2?r3?i;xrt1j,xrt2j和xrt3j分别为个体r1,r2和r3的第j维分量;F为变异因子,一般取值于[0,2]。这样就得到了变异个体vit。

2.2 交叉操作

tT),则 由变异个体vit和父代个体xit得到试验个体uit?(uit1,uit2,L,uiDt?vij? if rand[0 1]?CR or j?j_randt (2) uij??t??xij if rand[0 1]?CR and j?j_rand其中,rand[0,1]是[0,1]间的随机数;CR是范围在[0,1]间的常数,称为交叉因子,

CR值越大,发生交叉的可能性就越大;j_rand是在[1,D]随机选择的一整数,它保证了对于试验个体uit至少要从变异个体vit中获得一个元素。以上的变异操作和交叉操作统称为繁殖操作。 2.3 选择操作

差分进化算法采用的是“贪婪”选择策略,即从父代个体xit和试验个体uit中选择一个适应度值最好的作为下一代的个体xit+1,选择操作为:

ttt?x if fitness (x)?fitness(u?iii)t?1xi??t (3)

??ui otherwise其中,fitness(?)为适应度函数,一般以所要优化的目标函数为适应度函数。本文的适应度函数如无特殊说明均为目标函数且为求函数极小值。3 差分进化算法的算法流程

由前面对基本差分进化算法的基本原理的了解,我们可以得到差分进化算法的算法流程设计如下。

3.1 基本差分进化算法的基本步骤

(1) 初始化参数:种群规模NP;缩放因子F;变异因子CR;空间维数D;进化代数t?0。

tttt(2) 随机初始化初始种群X(t)??x1,x2,L,xNP?。 ?,其中xit??xit1,xit2,L,xiDT

(3) 个体评价:计算每个个体的适应度值。

(4) 变异操作:按(1)式对每个个体进行变异操作,并得到变异个体vit。 (5) 交叉操作:按(2)式对每个个体进行交叉操作,得到试验个体uit。 (6) 选择操作:按(3)式从父代个体xit和试验个体uit中选择一个作为下一代个体。

t?1t?1t?1(7) 终止检验:由上述产生的新一代种群X(t?1)??x1设X(t+1),x2,L,xNP?,t?1中的最优个体为xbest,如果达到最大进化代数或满足误差要求,则停止进化并输出xt?1best为最优解,否则令t=t+1 ,转(3)。

3.2 基本差分进化算法的流程图

生成初始群体变异交叉选择满足条件NY输出结果

差分进化算法流程图

4 基本差分进化算法的MATLAB描述

function [Pb]=DE

%参数初始化

D=input('请输入空间维数D='); N=input('请输入种群规模N=');

搜索更多关于: 差分进化算法-入门 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

差分进化算法-入门 基本差分进化算法 1基本差分进化算法的基本思想 DE算法是一种基于实数编码的用于优化函数最小值的进化算法,是在求解有关切比雪夫多项式的问题时提出来的,是基于群体差异的进化计算方法。它的整体结构类似于遗传算法,一样都存在变异、交叉和选择操作,但是它又不同于遗传算法。与基本遗传算法的主要区别在于变异操作上,如: 1、传统的遗传算法采用二进制编码,而差分进化算法采用实数编码。 2、在遗传算法中通过两个父代个体的交叉产生两个子个体,而在差分进化算法中通过第两个或几个个体的差分矢量做扰动来产生新个体。 3、在传统的遗传算法中,子代个体以一定概率取代其父代个体,而在差分进化中新产生的个体只有当它比种群中的个体优良时才替换种群中的个体。 变异是DE算法的主要操作,

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com