DE算法简介

文章目录

  • 前言
  • 一、DE是什么?
  • 二、DE流程
    • 2.1 初始化种群
    • 2.2 变异(差分操作)
    • 2.3 交叉
    • 2.4 选择
    • 2.5 重复迭代
  • 三、DE运行结果

前言

这两天看了DE算法,简单说下自己的认识
在这里插入图片描述

一、DE是什么?

百科定义:差分进化算法(Differential Evolution Algorithm,DE)是一种高效的全局优化算法。它也是基于群体的启发式搜索算法,群中的每个个体对应一个解向量。

差分进化算法DE(Differential Evolution)由Storn等人于1995年提出。最初用于解决切比雪夫多项式问题,现在DE广泛用于解决复杂优化问题,并且取得非常不错的效果。它通过模拟生物进化的过程,通过不断演化生成一组解,以期望找到问题的最优解。

二、DE流程

在这里插入图片描述

  1. 初始化种群: 随机生成一定数量的个体,形成初始种群;
  2. 变异(差分操作):对每个个体执行差分操作,生成新的个体。差分操作涉及目标个体、两个随机选择的其他个体和一个缩放因子;
  3. 交叉: 将变异后的个体与目标个体进行交叉操作,生成新的解;
  4. 选择: 比较新生成的解和当前种群中对应位置的个体,选择其中更优秀的个体作为下一代的种群;
  5. 重复迭代: 重复执行上述步骤,直到满足停止条件,例如达到最大迭代次数。

2.1 初始化种群

初始化种群先确定个体的数量NP(又称种群规模)和个体的初始基因数D;然后指定范围后随机生成结果;
如下所示,博主是生成了一个基因数D为10的种群,种群数量NP为2(放的太多会影响内容,出于演示考虑就放两个,真正运行时不能这样)。

[[-18.02048681 -14.41718301  -9.71498628 -19.59758138   2.962614349.88606516 -17.80244701  10.98612544   7.85991822  -4.35000201][-11.12895672   7.22395332  -8.69086121  -7.86988929  -3.975883627.80052737   7.26921488   6.6008707  -10.11471569  15.70808097]]

2.2 变异(差分操作)

在第g次迭代中,从种群中随机选择3个个体Xp1(g),Xp2(g),Xp3(g),且p1≠p2≠p3≠i,生成的变异向量为
在这里插入图片描述
Xp1(g)称为基向量,(Xp2(g)-Xp3(g))称为差分向量;
F是缩放因子,F越大,越不容易陷入局部极值点;F越小,越有利于收敛到局部极值点;
计算出来的结果Hi(g)被称为变异个体
上面的i代表的是当前第g代种群中的第i个个体,所以其实当前种群中的每个个体都会生成一个变异个体。

2.3 交叉

以一定概率让新产生的变异个体与原种群中个体进行交叉重组,增强种群的多样性
在这里插入图片描述
其中cr∈[0,1]为交叉概率,得出的结果Vi,j被称为试验个体

2.4 选择

将试验个体和父代个体相比较选择损失函数较小的作为下一代个体
在这里插入图片描述

2.5 重复迭代

重复执行上述步骤,直到满足停止条件,例如达到最大迭代次数。

三、DE运行结果

在这里插入图片描述
附代码

import numpy as np
import random
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif']=['SimHei'] #设置显示中文标签
plt.rcParams['axes.unicode_minus']=False   #设置正常显示符号
import math as mt#损失函数
def funcl(x):y = 0for i in range(len(x)):y = y + x[i] ** 2return y#初始化参数
NP = 100  # 初始化种群数
D = 10  # 基因数目
CR = 0.1  # 交叉算子
F0 = 0.4  # 初始变异算子
G = 1000  # 最大遗传代数
Xs = 20  # 上限
Xx = -20  # 下限jiyi = np.random.rand(NP, D)
f = jiyi * (Xs - Xx) + Xx  # 随机获得初始种群
FIT = []  # 适应度计算存储列表
trace = []
xtrace = []for i in range(NP):FIT.append(funcl(f[i]))# 差分进化循环
for i in range(G):print(f'第{i}代')vec = []  # 变异种群,没看懂但是都是2维的u = [[] for i in range(NP)]  # 选择种群lamda = mt.exp(1 - G / (G - i))  # 自适应变异算子,随着迭代次数发生变化,之后可以讨论一下F = F0 * (2 ** lamda)# 变异操作,和遗传算法的变异不同!,得到任意两个个体的差值,与变异算子相乘加第三个个体for m in range(NP):r1 = random.sample(range(0, NP), 1)[0]while r1 == m:r1 = random.sample(range(0, NP), 1)[0]r2 = random.sample(range(0, NP), 1)[0]while r2 == m or r2 == r1:r2 = random.sample(range(0, NP), 1)[0]r3 = random.sample(range(0, NP), 1)[0]while r3 == m or r3 == r2 or r3 == r1:r3 = random.sample(range(0, NP), 1)[0]vec.append(f[r1] + F * (f[r2] - f[r3]))# 交叉操作,交叉所有个体的第j维r = random.sample(range(0, NP), 1)[0]for j in range(D):cr = np.random.rand()tem = []if cr <= CR or j == r:for k in range(len(f)):u[k].append(vec[k][j])  # 添加所有个体的第j维else:for k in range(len(f)):u[k].append(f[k][j])# 边界条件处理for j in range(NP):for m in range(D):if u[j][m] < Xx or u[j][m] > Xs:u[j][m] = np.random.rand() * (Xs - Xx) + Xx  # 因为vec是变异得到的,所以不一定在取值范围之内else:continue# 选择操作FIT1 = []for m in range(NP):FIT1.append(funcl(u[m]))for m in range(NP):if FIT1[m] < FIT[m]:f[m] = u[m]FIT = []for m in range(NP):FIT.append(funcl(f[m]))trace.append(min(FIT))xtrace.append(f[FIT.index(min(FIT))].tolist())  # 这里呀,ndarray读进来的时候会发生浅拷贝和深拷贝的问题,转成列表形式保存就不会出问题了
xvalue = []
for i in range(len(xtrace)):xvalue.append(xtrace[i][2])# 绘制结果
plt.plot(trace, color='deepskyblue', marker='o', linewidth=2, markersize=3)
plt.xlabel('迭代次数', fontsize=10)
plt.ylabel('损失函数', fontsize=10)
plt.show()
plt.close()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/148178.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++sqrt函数题目

判断完全平方数 #include<bits/stdc.h> using namespace std; int n;int main() {cin>>n;if(sqrt(n)n/sqrt(n)&&sqrt(n)/1sqrt(n)){cout<<"yes";}else cout<<"no";return 0; } 输出所有因数 #include<bits/stdc.h> …

vivado产生报告阅读分析10-时序报告6

1、“ Timing Summary Report ”详情 “ Bus Skew Report ” &#xff08; 总线偏差报告 &#xff09; 包含下列部分 &#xff1a; • “ General Information ”部分 • “ Summary ”部分 • “ Set Bus Skew ”部分 “ General Information ”部分 “ Timing Summa…

Python OpenCV调整图像亮度对比度及RGB色彩

python通过opencv库调整图像的步骤&#xff1a; 1. 读取图像 直接通过cv2库读取图像&#xff0c;可以读取jpg, png等格式 import cv2 import numpy as npimage cv2.imread(C:\\D\\temp\\205250_last.png) 2. 调整图像亮度及对比度 OpenCV提供 convertScaleAbs 函数来调整…

Vue+ElementUI技巧分享:自定义表单项label的文字提示

文章目录 概要在表单项label后添加文字提示1. 使用 Slot 自定义 Label2. 添加问号图标与提示信息 slot的作用详解1. 基本用法2. 具名插槽 显示多行文字提示的方法1. 问题背景2. 实现多行内容显示3. 样式优化 结语 概要 在Vue和ElementUI的丰富组件库中&#xff0c;定制化表单是…

Linux进程间通信之匿名管道

文章目录 为什么要有进程间通信pipe函数共享管道原理管道特点管道的四种情况 管道的应用场景&#xff08;进程池&#xff09;ProcessPool.ccTask.hpp 为什么要有进程间通信 数据传输&#xff1a;一个进程需要将它的数据发送给另一个进程 资源共享&#xff1a;多个进程之间共享…

Vue3-自定义hook函数

Vue3-自定义hook函数 功能&#xff1a;可以将组合式API封装成一个函数&#xff0c;用于解决代码复用的问题。注意&#xff1a;需要在src文件夹下创建一个文件夹hooks&#xff0c;在里面放js文件&#xff0c;命名随意&#xff0c;主要是将setup函数中的代码放入js文件中。 // s…

岁月

《岁月》 作者&#xff0f;罗光记 岁月如梭逝不停&#xff0c; 往事如烟散无影。 青春已去心犹在&#xff0c; 笑看人生淡如菊。

Qt的日志输出

在Qt中&#xff0c;一般习惯使用qDebug信息进行输出和打印调试信息到console或者文件中&#xff0c;在qDebug中&#xff0c;也有一些小技巧&#xff0c;可以帮助我们更好的使用qDebug打印日志记录&#xff0c;本文分享了qDebug使用的一些小技巧。 1. 打印出文件名、行号、调用函…

Windows10下Maven3.9.5安装教程

文章目录 1.下载maven2.安装3.配置系统变量3.1.新建系统变量 MAVEN_HOME3.2.编辑系统变量Path 4.CMD命令测试是否安装成功5.配置maven本地仓库6.配置国内镜像仓库 1.下载maven 官网 https://maven.apache.org/download.cgi 点击下载。 2.安装 解压到指定目录 D:\installSoft…

计算机硬件的基本组成

一、冯诺依曼结构 存储程序&#xff1a; “存储程序”的概念是指将指令以二进制代码的形式事先输入计算机的主存储器&#xff0c;然后按其在存储器中的首地址执行程序的第一条指令&#xff0c;以后就按该程序的规定顺序执行其他指令&#xff0c;直至程序执行结束。 冯诺依曼计…

io多路复用:select、poll和epoll

1、为什么使用多路复用&#xff1a; 1.1单线程BIO监听socket 多路复用一般用于网络io当中&#xff0c;提到网络io我们肯定能想到socket。如果我们想要一个线程单纯的用向下文的方式监听很多个socket看他是否有事件发生&#xff0c;那这样是不可行。 但上一个socket1没有可读事…

Codewhisperer 使用评价

最近亚⻢逊推出了一款基于机器学习的 AI 编程助手 Amazon CodeWhisperer&#xff0c;可以实时提供代码建议。在编写代码时&#xff0c;它会自动根据现有的代码和注释给出建议。Amazon CodeWhisperer 与GitHub Copilot类似&#xff0c;主要的功能有: 代码补全注释和文档补全代码…

Banana Pi BPI-W3之RK3588安装Qt+opencv+采集摄像头画面.

场景&#xff1a;在Banana Pi BPI-W3 RK3588上做qt开发工作RK3588安装Qtopencv采集摄像头画面 2. 环境介绍 硬件环境&#xff1a; Banana Pi BPI-W3RK3588开发板、MIPI-CSI摄像头( ArmSoM官方配件 )软件版本&#xff1a; OS&#xff1a;ArmSoM-W3 Debian11 QT&#xff1a;QT5…

MySQL/Oracle用逗号分割的id怎么实现in (逗号分割的id字符串)。find_in_set(`id`, ‘1,2,3‘) 函数,

1.MySQL 1.1.正确写法 select * from student where find_in_set(s_id, 1,2,3); 1.2.错误示范 select * from student where find_in_set(s_id, 1,2 ,3); -- 注意&#xff0c;中间不能有空格。1、3 select * from student where find_in_set(s_id, 1,2, 3); -- 注意…

【vue】Vue项目中如何在父组件中直接调用子组件的方法

方案一&#xff1a;通过ref直接调用子组件的方法 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 //父组件中 <template> <div> <Button click"handleClick">点击调用子组件…

在Windows系统中查找GitBash安装位置

使用注册表可以轻松获取&#xff1a; reg query HKEY_LOCAL_MACHINE\SOFTWARE\GitForWindows /v InstallPath | findStr InstallPath此时输出一串字符&#xff0c; 通过字符串切割即可获取&#xff1a;

【PTA题目】6-20 使用函数判断完全平方数 分数 10

6-20 使用函数判断完全平方数 分数 10 全屏浏览题目 切换布局 作者 张高燕 单位 浙大城市学院 本题要求实现一个判断整数是否为完全平方数的简单函数。 函数接口定义&#xff1a; int IsSquare( int n ); 其中n是用户传入的参数&#xff0c;在长整型范围内。如果n是完全…

「Verilog学习笔记」使用8线-3线优先编码器Ⅰ实现16线-4线优先编码器

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 分析 当EI10时、U1禁止编码&#xff0c;其输出端Y为000&#xff0c;GS1、EO1均为0。同时EO1使EI00&#xff0c;U0也禁止编码&#xff0c;其输出端及GS0、EO0均为0。由电路…

软件测试/人工智能丨深入人工智能软件测试:PyTorch引领新时代

在人工智能的浪潮中&#xff0c;软件测试的角色变得愈发关键。本文将介绍在人工智能软件测试中的一些关键技术&#xff0c;以及如何借助PyTorch深度学习框架来推动测试的创新与升级。 PyTorch&#xff1a;深度学习的引擎 PyTorch作为一种开源的深度学习框架&#xff0c;为软件…

LeetCode【36】有效的数独

题目&#xff1a; 思路&#xff1a; https://blog.51cto.com/u_15072778/3788083 代码&#xff1a; public boolean isValidSudoku(char[][] board) {// 二维数组第一个标识 0-9行&#xff0c;第二个表示 0-9数字&#xff0c;存的内容boolean 表示第0-9行&#xff0c;0-9这些…