【智能算法】人工电场算法(AEFA)原理及实现

在这里插入图片描述

目录

    • 1.背景
    • 2.算法原理
      • 2.1算法思想
      • 2.2算法过程
    • 3.结果展示
    • 4.参考文献


1.背景

2019年,A Yadav等人受库伦定律和运动定律启发,提出了人工电场算法(Artificial Electric Field Algorithm,AEFA)。

2.算法原理

2.1算法思想

AEFA中每个个体是一个带电的粒子,每个粒子的位置代表问题的一个解,这些带电的粒子在它们之间的电场力的引导下,逐步的向种群中最优的位置靠近。电量较小的粒子在电量较大的粒子的引力下,向带电量较大的粒子移动。在引力的不断作用下,整个种群逐渐向电量较大的个体方向逼近,最终搜索到问题的最优解,整个过程遵循牛顿第二定律。
在这里插入图片描述

2.2算法过程

库伦定律规定两个带电粒子间的电场力与粒子所带的电量成正比,与粒子间的距离成反比。假如两个粒子的带电量分别为 Q1和Q2 ,引力常数用K 来表示,粒子间的欧氏距离用 D 来表示,则粒子间的电场力F可用公式表示为:
F = K Q 1 Q 2 D 2 (1) F=K\frac{Q_{1}Q_{2}}{D^{2}}\tag{1} F=KD2Q1Q2(1)
在第 t次迭代,第 i个粒子和第 j个粒子间的作用力可表示为:
F i j d ( t ) = K ( t ) Q i ( t ) × Q j ( t ) R i j ( t ) + ϵ ( p j d ( t ) − x i d ( t ) ) (2) F_{ij}^{d}(t)=K(t)\frac{Q_{i}(t)\times Q_{j}(t)}{R_{ij}(t)+\epsilon}\Big(p_{j}^{d}(t)-x_{i}^{d}(t)\Big)\tag{2} Fijd(t)=K(t)Rij(t)+ϵQi(t)×Qj(t)(pjd(t)xid(t))(2)
其中,Rij表示粒子i与粒子j的欧式距离。K(t)是第t代的库伦常数:
K ( t ) = K 0 exp ⁡ ( − α i t m a x i t ) (3) K(t)=K_0\exp\biggl(-\alpha\frac{it}{maxit}\biggr)\tag{3} K(t)=K0exp(αmaxitit)(3)
第i个个体所具有的电量:
q i ( t ) = exp ⁡ ( f i t p i ( t ) − w o r s t ( t ) b e s t ( t ) − w o r s t ( t ) ) Q i ( t ) = q i ( t ) ∑ i = 1 N q i ( t ) (4) q_{i}(t)=\exp\biggl(\frac{fit_{pi}(t)-worst(t)}{best(t)-worst(t)}\biggr)\\Q_{i}(t)=\frac{q_{i}(t)}{\sum_{i=1}^{N}q_{i}(t)}\tag{4} qi(t)=exp(best(t)worst(t)fitpi(t)worst(t))Qi(t)=i=1Nqi(t)qi(t)(4)
粒子i在第d维所受到的合力以及所具有的加速度:
F i d ( t ) = ∑ j = 1 , j = i N r a n d ∗ F i j d ( t ) a i d ( t ) = F i d ( t ) Q i ( t ) (5) F_{i}^{d}(t)=\sum_{j=1,j=i}^{N}rand*F_{ij}^{d}(t)\\a_{i}^{d}(t)=\frac{F_{i}^{d}(t)}{Q_{i}(t)}\tag{5} Fid(t)=j=1,j=iNrandFijd(t)aid(t)=Qi(t)Fid(t)(5)
速度和位置更新为:
V i d ( t + 1 ) = r a n d × V i d ( t ) + a i d ( t ) X i d ( t + 1 ) = X i d ( t ) + V i d ( t + 1 ) (6) V_{i}^{d}\big(t+1\big)=rand\times V_{i}^{d}\big(t\big)+a_{i}^{d}\big(t\big)\\X_{i}^{d}\big(t+1\big)=X_{i}^{d}\big(t\big)+V_{i}^{d}\big(t+1\big)\tag{6} Vid(t+1)=rand×Vid(t)+aid(t)Xid(t+1)=Xid(t)+Vid(t+1)(6)

伪代码

在这里插入图片描述

3.结果展示

在这里插入图片描述

4.参考文献

[1] Yadav A. AEFA: Artificial electric field algorithm for global optimization[J]. Swarm and Evolutionary Computation, 2019, 48: 93-108.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

二维相位解包理论算法和软件【全文翻译- DCT相位解包裹(5.3.2)】

5.3.2 基于 DCT 的方法 在本节中,我们将详细介绍如何通过 DCT 算法解决非加权最小二乘相位解缠问题,而不是通过FFT.我们将使用公式 5.53 所定义的二维余弦变换。我们开发的算法等同于 FFT 方法 2(第 5.3.1 节)。与 FFT 方法 I 等价的 DCT 算法也可以推导出来,但我们将其作…

selenium 如何获取 session 指定的数据

代码核心在于这几个部分: 其一:使用元素定位来获取页面上指定需要抓取的关键字; 其二:将页面上定位得到的数据永久存储到本地文件中。 具体来梳理一下从访问URL开始到爬取数据整个流程下来的各个节点我们都做了哪些工作。 我们来看…

C语言——详解字符函数和字符串函数(二)

Hi,铁子们好呀!之前博主给大家简单地介绍了部分字符和字符串函数,那么这次,博主将会把这些字符串函数给大家依次讲完! 今天讲的具体内容如下: 文章目录 6.strcmp函数的使用及模拟实现6.1 strcmp函数介绍和基本使用6.1.1 strcmp函…

Vulnhub靶机练习笔记-Os-hackNos-1

vulnhub靶机下载 https://www.vulnhub.com/entry/hacknos-os-hacknos,401/ 靶场环境: NAT模式 kali:192.168.242.131 靶机:192.168.242.142 渗透 nmap探测靶机 开放了80和22端口 dirsearch对80端口进行目录扫描,发现drupal…

nacos derby.log无法的读取+derby数据库启动失败分析解决

排查思路分析 日志报错: derby.log文件权限不够(root权限),无法读取,我用普通用户启动。 使用命令chown xx:xx derby.log修改属主和属组为普通用户后,又报出其他错误。 数据库启动不了,无…

图片怎么批量改格式png改jpg?一键批量搞定方法

在创建幻灯片或演示文稿时,使用jpg格式可以减小文件大小,方便分享和传输。转换png格式的图片为jpg,可以确保文件大小的合理控制,同时保持图像的可视质量,当遇到需要批量处理的时候,许多小伙伴都不太懂图片怎…

鸿蒙OS开发学习:【尺寸适配实现】

概述 在鸿蒙开发中,尺寸适配是一个重要的概念,它可以帮助我们在不同屏幕尺寸的设备上正确显示和布局我们的应用程序。本文将介绍如何在鸿蒙开发中实现尺寸适配的方法。 流程图 详细步骤 1. 定义适配方案 在鸿蒙开发中,我们可以通过定义适…

基于springboot+vue实现的的成人教育教务系统

作者主页:Java码库 主营内容:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app等设计与开发。 收藏点赞不迷路 关注作者有好处 文末获取源码 技术选型 【后端】:Java 【框架】:spring…

Windows Nginx 启动

先解压 nginx安装包,进入到安装目录下(配置环境变量没有用) 解压后的目录结构如上。 #启动服务 默认是80端口, #如果端口被占用,是启动不了的,会生成error log在log目录下 start nginx#停止nginx 服务 nginx -s stop#重新加载配置…

C语言进阶课程学习记录-第29课 - 指针和数组分析(下)

C语言进阶课程学习记录-第29课 - 指针和数组分析(下) 数组名与指针实验-数组形式转换实验-数组名与指针的差异实验-转化后数组名加一的比较实验-数组名作为函数形参小结 本文学习自狄泰软件学院 唐佐林老师的 C语言进阶课程,图片全部来源于课…

数字社会下的智慧公厕:构筑智慧城市的重要组成部分

智慧城市已经成为现代城市发展的趋势,而其中的数字化转型更是推动未来社会治理体系和治理能力现代化的必然要求。在智慧城市建设中,智慧公厕作为一种新形态的信息化公共厕所,扮演着重要角色。本文智慧公厕源头实力厂家广州中期科技有限公司&a…

线圈大小的测量和圈数的绕制办法

测量一根线圈的大小,让线圈多出来一公分多一点!!! 我在这简称样圈 然后在模具上进行绕制。 把样圈放在模具上,松紧度要刚好,确定好模具 具体位置 线记在 中间铁心上 开始绕制 这叫做一圈 绕好相应的圈数后…

如何通过代码混淆绕过苹果机审,解决APP被拒问题

目录 iOS代码混淆 功能分析 实现流程 类名修改 方法名修改 生成垃圾代码 替换png等静态资源MD5 info.plist文件添加垃圾字段 功能分析 实现流程 类名修改 方法名修改 生成垃圾代码 替换png等静态资源MD5 info.plist文件添加垃圾字段 混淆前后对比 iOS代码混淆 …

自定义树形筛选选择组件

先上效果图 思路:刚开始最上面我用了el-input,选择框里面内容用了el-inputel-tree使用,但后面发现最上面那个可以输入,那岂不是可以不需要下拉就可以使用,岂不是违背了写这个组件的初衷,所以后面改成div自定…

【ZZULIOJ】1053: 正弦函数(Java)

目录 题目描述 输入 输出 样例输入 Copy 样例输出 Copy code 题目描述 输入x,计算上面公式的前10项和。 输入 输入一个实数x。 输出 输出一个实数,即数列的前10项和,结果保留3位小数。 样例输入 Copy 1 样例输出 Copy 0.841 c…

求三角形面积(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h> # include <math.h>int main() {//初始化变量值&#xff1b;double a, b, c, s, area;//赋值&#xff1b;a 3.67;b 5.43;c 6.21;//运算求s&#xff1b…

快速掌握SpringBoot多环境开发

多环境开发 在一个项目当中可能同一套代码需要用于多种环境进行不同的用途例如&#xff1a;生产环境&#xff0c;开发环境&#xff0c;测试环境&#xff0c;需要通过配置进行不同环境的开发切换&#xff1a; spring:profiles:active: shengchan # 通过属性active进行选择 …

二阶巴特沃兹滤波器的数字推导

二阶巴特沃兹滤波器的数字推导 原型双线性变换no warpper双线性变换warpper或者 参考 原型 H ( s ) Ω c 2 s 2 2 ∗ Ω ∗ s Ω c 2 H(s)\frac{\Omega_c^2}{s^2\sqrt{2}*\Omega * s\Omega_c^2} H(s)s22 ​∗Ω∗sΩc2​Ωc2​​ 双线性变换no warpper Ω c ω c T \Omega…

Elastic:加速生成式人工智能体验

作者&#xff1a;Matt Riley 搜索驱动的人工智能和开发人员工具专为速度和规模而打造。 在大型语言模型&#xff08;LLM&#xff09;和生成式 AI 的每日突破中&#xff0c;开发者站在了这场运动的最前沿&#xff0c;影响着它的方向和可能性。在这篇博客中&#xff0c;我将分享…

STL容器之unordered_map类

文章目录 STL容器之unordered_map类1、unordered_map1.1、unordered_map介绍1.2、unordered_map的使用1.2.1、unordered_map的常见构造1.2.2、unordered_map的迭代器1.2.3、unordered_map的容量1.2.4、unordered_map的增删查1.2.5、unordered_map的桶操作 2、unordered_multima…