人工蜂群算法

news2024/11/17 8:44:37

人工蜂群算法

人工蜂群算法(Artificial Bee Colony Optimization,ABC)是一种基于蜜蜂觅食行为的优化算法,由土耳其学者Karaboga于2005年提出,算法模拟蜜蜂的采蜜行为对优化问题进行求解。

算法原理

ABC算法的核心思想是将优化问题的解空间视作蜜源,蜜蜂作为搜索代理在解空间中进行探索。在算法的每一轮迭代中,蜜蜂根据当前蜜源的质量和周围蜜源的信息,选择性地进行勘探和开发,从而逐步优化搜索空间。蜜源的位置代表了优化问题的可能解决方案,蜜源的花蜜量对应于相关解决方案的优劣,ABC算法与优化问题的对应关系如下表所示。

ABC优化问题
蜜源可行解: X i = ( x i 1 , x i 2 , … , x i D ) X_i=(x_{i1},x_{i2},\dots,x_{iD}) Xi=(xi1,xi2,,xiD)
花蜜量适应度

算法超参数

ABC算法的超参数包括雇佣蜂比例和蜜源保留次数阈值等,参数影响着蜜蜂在搜索空间中的行为和搜索效率。

  • e m p l o y e d _ r a t e employed\_rate employed_rate:雇佣蜂比例;
  • l i m i t limit limit:蜜源保留次数的阈值;
  • NP:种群大小;
  • Gmax:最大迭代数。

寻优公式

人工蜂群由雇佣蜂(employed bees)、围观蜂(onlookers)和侦察蜂(scouts)三类蜜蜂组成。在标准的ABC算法中,蜂群的前半部分由受雇的人工蜜蜂组成,后半部分为观察蜂。每个蜜源只有一只雇佣蜂,受雇蜜蜂的数量等于蜂巢周围食物源的数量。被雇用的蜜蜂的食物源已被蜜蜂吃光,它就会转变为侦察蜂探索新的蜜源。ABC通过重复执行雇佣蜂、观察蜂和侦察蜂三个阶段来寻找问题的最优解。

  1. 雇佣蜂阶段,雇佣蜂在现有蜜源的位置开发新的蜜源。
    v i j t = x i j t + ϕ i j t ( x i j t − x k j t ) (1) v_{ij}^t=x_{ij}^t + \phi_{ij}^t(x_{ij}^t - x_{kj}^t) \tag{1} vijt=xijt+ϕijt(xijtxkjt)(1)
    其中, k ∈ { 1 , ⋯   , N P } k \in \{1,\cdots,NP\} k{1,,NP} k ≠ i k\neq i k=i ϕ i j ∈ [ − 1 , − 1 ] \phi_{ij} \in [-1,-1] ϕij[1,1]
    X i t + 1 = { X i t , if  f i t ( X i ) t > f i t ( V i t ) V i t + 1 , e l s e (2) X_{i}^{t+1}= \begin{cases} X_{i}^t, & \text{if $fit(X_i)^t > fit(V_i^t)$}\\ V_{i}^{t+1},& else \end{cases} \tag{2} Xit+1={Xit,Vit+1,if fit(Xi)t>fit(Vit)else(2)
  2. 观察蜂阶段,观察蜂对雇佣蜂分享的蜜源信息进行分享,采用轮盘赌策略来选址蜜源跟踪开采新的蜜源,公式与式(1)等价。
  3. 侦察蜂阶段,蜜源 X i X_i Xi拥有参数trial,统计蜜源没有被更新的次数,当蜜源更新被保留时,trail设置为0;反之,trail加1。如果一个蜜源经过多次开采没被更新,当trail超过了阈值limit,那么需要抛弃该蜜源,启动侦察探索新的蜜源。
    x i j = x i , j m i n + r a n d ( 0 , 1 ) ⋅ ( x i , j m a x − x i , j m i n ) (3) x_{ij}=x_{i,j}^{min}+rand(0,1) \cdot (x_{i,j}^{max} - x_{i,j}^{min}) \tag{3} xij=xi,jmin+rand(0,1)(xi,jmaxxi,jmin)(3)
    雇佣蜂阶段和观察蜂阶段体现了算法的开发过程即算法对已知优质解的利用,侦察蜂阶段体现了算法的探索过程即算法对新解的探索。

初始化

初始解应当覆盖整个搜索空间,一般采用均匀分布随机生成初始解。
x i j 0 = x i , j m i n + r a n d ( 0 , 1 ) ⋅ ( x i , j m a x − x i , j m i n ) (4) x_{ij}^0=x_{i,j}^{min}+rand(0,1) \cdot (x_{i,j}^{max} - x_{i,j}^{min}) \tag{4} xij0=xi,jmin+rand(0,1)(xi,jmaxxi,jmin)(4)
其中,rand(0,1)表示0-1之间的随机数, x i j m a x x_{ij}^{max} xijmax x i j m i n x_{ij}^{min} xijmin分别表示该问题第j个维度变量的上下界。

伪代码


输入:超参数 ( e m p l o y e d _ r a t e , l i m i t , N P , G m a x ) (employed\_rate,limit,NP,Gmax) (employed_rate,limit,NP,Gmax)和搜索边界 X m i n X_{min} Xmin, X m a x X_{max} Xmax
输出:最优解
1:初始化
2:根据式(4)初始化位置种群X
3:记录群体最优gbest
4:优化搜索
5:For G = 1:Gmax
6: \qquad 雇佣蜂更新
7: \qquad 观察蜂更新
8: \qquad 侦察蜂更新
9: \qquad 更新群体最优 g b e s t gbest gbest
10:End


注:优化算法并不保证能够得到问题的最优解,因此,算法输出的最优解并非问题的整体最优解,而是搜索过程中最好的一个解。

实验

实验选取二维的平方和函数,函数的最小值在点(a,b)取得,最小值为0。
f ( x 1 , x 2 ) = ( x 1 − a ) 2 + ( x 2 − b ) 2 (5) f(x_1,x_2) = (x_1 - a)^2 + (x_2-b)^2 \tag{5} f(x1,x2)=(x1a)2+(x2b)2(5)

实验参数如下:

参数
问题维度D2
种群数NP30
最大进化次数Gmax50
雇佣蜂比例0.5
limit10
取值范围(-100,100)

人工蜂群算法搜索过程

人工蜂群算法搜索过程

人工蜂群算法收敛曲线

人工蜂群算法收敛曲线

最优值最差值平均值标准差
1.686e-115.679e-76.952e-81.324e-7

代码获取

关注微信公众号数学模型与算法回复 ABC算法获取python代码

参考文献

[1] 何尧,刘建华,杨荣华.人工蜂群算法研究综述[J].计算机应用研究,2018,35(05):1281-1286.
[2] Karaboga D. An idea based on honey bee swarm for numerical optimization[R]. Technical report-tr06, Erciyes university, engineering faculty, computer engineering department, 2005.
[3] Akay B, Karaboga D. A modified artificial bee colony algorithm for real-parameter optimization[J]. Information sciences, 2012, 192: 120-142.

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

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

相关文章

Unreal Engine API:颠覆游戏开发,数字内容创造轻松驾驭!

🚀 原理介绍大揭秘 Epic Games的得意之作Unreal Engine API,是虚幻引擎跳动着的核心心脏。基于C架构,并携手可视化编程神器——蓝图系统,它为全球的游戏开发者们打造了一套火力全开的工具箱和功能丰富的接口。无论你是专业团队还…

C++vector的使用方法

文章目录 一、vector的介绍1. 文档链接2. 简要介绍 二、vector的使用1.vector的定义(1)构造函数(2)拷贝构造函数(2)赋值重载 2. vector 增删查改(1)operator [](2&#x…

Vue3 中的代理原理详解

Vue3 中的代理原理详解 Vue3 中引入了代理(Proxy)机制,取代了 Vue2 中的 Object.defineProperty() 机制,用于实现数据响应式。代理机制是 ES6 中新增的特性,它可以用来自定义对象中的操作,比如属性查找、赋…

IDS入侵检测知识整理及lDS入侵检查表

【IDS入侵检测知识整理及lDS入侵检查表】 1. 网络入侵检测IDS概念 2. IDS分类 3. IDS的工作原理 4. IDS在网络中的部署 5. 入侵检查表 项目建设全套资料获取通道:软件开发全套资料_数字中台建设指南-CSDN博客

植物病虫害:YOLO水稻虫害识别数据集(6类,五千余张图像,标注完整)

YOLO水稻虫害识别数据集,包含褐飞虱,绿叶蝉,正常叶片,稻虫,二化螟,蝇蛆6个类别,共五千余张图像,yolo标注完整。 适用于CV项目,毕设,科研,实验等 …

【QT6】打开项目 .pro 一堆报错 但是程序可以运行 打开别人的QT项目后,全是报错

报错环境 我通过在网上拷贝的项目, 然后打开pro文件 build项目 你会发现各种报错 无缘无故的报错 明明环境已经没问题了 解决方案 首先是提示no valid settings file could be found,这个错误很好解决,删除项目目录下的.user文件&#xff…

第三百八十九回

文章目录 1. 概念介绍2. 使用方法2.1 获取所有时区2.2 转换时区时间 3. 示例代码4. 内容总结 我们在上一章回中介绍了"分享一些好的Flutter站点"相关的内容,本章回中将介绍timezone包.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 我们在…

制备大量单抗腹水就选博奥龙腹水专用佐剂

博奥龙Biodragon腹水专用佐剂是一种预先注入机体内,能增强机体对抗原的免疫应答能力或改变免疫应答类型的辅助物质。主要用于在单克隆抗体腹水制备中,在小鼠腹腔内接种杂交瘤细胞前,注射本佐剂到腹腔内,可以诱导杂交瘤细胞在腹腔内…

用一个 Python 脚本实现依次运行其他多个带 argparse 命令行参数的 .py 文件

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 问题描述:在 Windows 环境中,您希望通过一个 Python 脚本来实现特定的自动化任务,该任务需要依次运行其他多个带 argparse 命令行参数的 .py 文件。您希望找到一种简…

外呼营销的出单成本

在虚拟通信里面,需要不断降低投诉骚扰营销。企业通过呼叫中心电话营销来销售产品,随着市场的管控越来越严格,那就是需要计算出呼叫意向客户的成本。 前期成本是企业引入呼叫中心系统的成本,主要取决于呼叫中心系统的类型。本地自建…

LVS集群(Linux Virtual server)介绍----及LVS的NAT模式部署(一)

群集的含义 ●Cluster,集群、群集由多台主机构成,但对外只表现为一个整体,只提供访问入口(域名或IP地址),相当于一台大型计算机 问题: 互联网应用中,随着站点对硬件性能、响应速度、服务稳定性、数据可靠…

ADS功分器模型含义

ADS功分器模型含义 文章目录 ADS功分器模型含义dbpolar和单个值polar和单个值polar和dbpolar单个值 S21和S31传输系数 S11和S22反射系数 Isolation 隔离度 Zref 端口的参考阻抗,默认为50Ω CheckPassivity 检查是否无源,默认是无源器件 目前根据仿真结…

浏览器跨域问题笔记

为保护用户安全,浏览器约定了“同源策略”,即“协议、域名、端口相同”的请求为同源可信赖的。 同源策略分为以下两种: DOM 同源策略:禁止对不同源页面 DOM 进行操作。这里主要场景是 iframe 跨域的情况,不同域名的 i…

OpenCASCADE+Qt创建建模平台

1、建模平台效果 2、三维控件OCCWidget 将V3d_View视图与控件句柄绑定即可实现3d视图嵌入Qt中&#xff0c;为了方便也可以基于QOpenGLWidget控件进行封装&#xff0c;方便嵌入各种窗体使用并自由缩放。 #ifndef OCCTWIDGET_H #define OCCTWIDGET_H#include <QWidget> #i…

C++面向对象程序设计-北京大学-郭炜【课程笔记(五)】

C面向对象程序设计-北京大学-郭炜【课程笔记&#xff08;五&#xff09;】 1、常量对象、常量成员函数1.1、常量对象1.2、常量成员函数1.3、常引用 2、友元&#xff08;friends&#xff09;2.1、友元函数2.2、友元类 3、运算符重载的基本概念3.1、运算符重载 4、赋值运算符的重…

C语言数组地址详解及相关题——各种奇奇怪怪的偏难怪

文章目录 一、数组二、[]使用原理三、指针数组与数组指针指针数组数组指针 四、数组名、*数组名与&数组名的区别一维数组二维数组 空间移动计算总结 一、数组 数组&#xff08;英文 array&#xff09;就是一组同类型变量的集合。它具有三个特性&#xff1a;长度固定、连续…

mysql 8.0 日志文件无权限问题处理

无论如何修改权限总是报这个日志文件权限问题。 解决方法 输入指令&#xff1a; setenforce 0 systemctl restart mysgld

解答关于:水牛社软件是做什么的?水牛社软件靠谱么?

很多对我们软件感兴趣但是没有入手的观望者都会有这样的疑问&#xff1a;水牛社软件具体是做什么的&#xff1f;水牛社软件靠谱么&#xff1f; 其实软件的简介已经讲的很清楚了&#xff0c;但是软件不是功能性软件&#xff0c;所以不能给大家免费试用&#xff0c;短期任务版块…

官宣!百度智能云千帆产品发布会3月21日北京见!

回望2023大模型狂奔的一年&#xff0c;百度智能云千帆大模型平台无疑是浓墨重彩的一笔。自2023年3月27日正式问世后&#xff0c;百度智能云千帆大模型平台以突飞猛进的速度持续发展。从模型、应用到生态&#xff0c;“千帆”书写着自身在大模型时代的答卷。 作为全球首个一站式…

老司机都懂的!【打赏】完美运营的最新视频打赏系统

完美运营的最新视频打赏系统优于市面上95%的打赏系统&#xff0c;与其他打赏系统相比&#xff0c;功能更加强大&#xff0c;完美运营且无bug。支付会调、短链接生成、代理后台、价格设置和试看功能等均没有问题。 以上为原简介&#xff0c;经测试验证。成功搭建并可以正常进入…