智能优化算法:浣熊优化算法

文章目录

  • 智能优化算法:浣熊优化算法
    • 1.浣熊优化算法
      • 1.1 初始化
      • 1.2 阶段一:狩猎和攻击(探索阶段)
    • 2.实验结果
    • 3.参考文献
    • 4. Matlab
    • 5.python

摘要:浣熊优化算法(Coati Optimization Algorithm(COA)),是于2022年提出的一种基于浣熊行为的优化算法,该算法通过模拟浣熊猎食行为来进行寻优,具有寻优能力强,收敛速度快等特点

1.浣熊优化算法

1.1 初始化

与其他优化算法类似,在寻优空间里随机初始化种群:
x i , j = l b j + r ⋅ ( u b j − l b j ) (2) x_{i, j}=l b_j+r \cdot\left(u b_j-l b_j\right) \tag{2} xi,j​=lbj​+r⋅(ubj​−lbj​)(2)
其中 x i , j x_{i,j} xi,j​为个体, l b j lb_j lbj​为寻优下边界, u b j ub_j ubj​为寻优上边界, r r r为[0,1]之间的随机数。

1.2 阶段一:狩猎和攻击(探索阶段)

在搜索空间中更新coatis种群的第一阶段是基于模拟它们攻击鬣蜥(Iguana)时的策略进行建模的。在这一策略中,一群coatis爬上树去够一只鬣蜥并吓唬它。其他几只coatis在树下等待,直到鬣蜥摔倒在地。鬣蜥落地后,coatis攻击并猎杀它。这种策略导致coatis移动到搜索空间的不同位置,这表明了COA在解决问题空间的全局搜索中的探索能力。

在COA设计中,假设种群中最好成员的位置是鬣蜥的位置。也有人假设,一半的鬣蜥爬上树,另一半等待鬣蜥掉到地上。因此,使用等式(4)对从树上升起的涂层的位置进行数学模拟。
X i P 1 : x i , j P 1 = x i , j + r ⋅ ( Iguana  j − I ⋅ x i , j ) , for  i = 1 , 2 , … , ⌊ N 2 ⌋ a n d j = 1 , 2 , … , m . (4) X_i^{P 1}: x_{i, j}^{P 1}=x_{i, j}+r \cdot\left(\text { Iguana }_j-I \cdot x_{i, j}\right), \text { for } i=1,2, \ldots,\left\lfloor\frac{N}{2}\right\rfloor \\and j=1,2, \ldots, m. \tag{4} XiP1​:xi,jP1​=xi,j​+r⋅( Iguana j​−I⋅xi,j​), for i=1,2,…,⌊2N​⌋andj=1,2,…,m.(4)
鬣蜥摔倒在地后,它被放置在搜索空间中的一个随机位置。基于这个随机位置,地面上的涂层在搜索空间中移动,这是使用等式(5)和(6)模拟的。

Iguana  G : Iguana  a j G = l b j + r ⋅ ( u b j − l b j ) , j = 1 , 2 , … , m ,  (5) \begin{aligned} & \text { Iguana }^G: \text { Iguana } a_j^G=l b_j+r \cdot\left(u b_j-l b_j\right), j=1,2, \ldots, m \text {, } \end{aligned}\tag{5} ​ Iguana G: Iguana ajG​=lbj​+r⋅(ubj​−lbj​),j=1,2,…,m, ​(5)

X i p 1 : x i , j P 1 = { x i , j + r ⋅ ( Iguana  j j G − I ⋅ x i , j ) , F Iguana  G < F i , x i , j + r ⋅ ( x i , j − Iguana  j G ) , else,  for  i = ⌊ N 2 ⌋ + 1 , ⌊ N 2 ⌋ + 2 , … , N and  j = 1 , 2 , … , m .  (6) \begin{aligned} & X_i^{p 1}: x_{i, j}^{P 1}=\left\{\begin{array}{cl} x_{i, j}+r \cdot\left(\text { Iguana } j_j^G-I \cdot x_{i, j}\right), & F_{\text {Iguana }}^G<F_i, \\ x_{i, j}+r \cdot\left(x_{i, j}-\text { Iguana }_j^G\right), & \text { else, } \end{array}\right. \\ & \text { for } i=\left\lfloor\frac{N}{2}\right\rfloor+1,\left\lfloor\frac{N}{2}\right\rfloor+2, \ldots, N \text { and } j=1,2, \ldots, m \text {. } \\ & \end{aligned}\tag{6} ​Xip1​:xi,jP1​={xi,j​+r⋅( Iguana jjG​−I⋅xi,j​),xi,j​+r⋅(xi,j​− Iguana jG​),​FIguana G​<Fi​, else, ​ for i=⌊2N​⌋+1,⌊2N​⌋+2,…,N and j=1,2,…,m. ​(6)

如果更新后的个体更优则更新当前个体,否则保持原状:
X i = { X i P 1 , F i P 1 < F i X i , else.  (7) X_i=\left\{\begin{aligned} X_i^{P 1}, & F_i^{P 1}<F_i \\ X_i, & \text { else. } \end{aligned}\right. \tag{7} Xi​={XiP1​,Xi​,​FiP1​<Fi​ else. ​(7)
这里 X i P 1 X_i^{P1} XiP1​是更新后的新位置, I g u a n a Iguana Iguana为猎物鬣蜥的位置, r r r为[0,1]之间的随机数。I为随机选择的1或者2。

1.3 阶段二:逃离捕食者(开发阶段)

更新coatis在搜索空间中的位置的过程的第二阶段是基于coatis遇到捕食者和逃离捕食者时的自然行为进行数学建模的。当捕食者攻击一只coatis时,它会从自己的位置逃跑。Coati在这一战略中的举措使其处于接近当前位置的安全位置,这表明了COA在本地搜索中的局部搜索能力。

为了模拟这种行为,基于等式(8)和(9),在每个coatis所在的位置附近生成随机位置。
l b j local  = l b j t , u b j local  = u b j t , where  t = 1 , 2 , … , T (8) \begin{gathered} l b_j^{\text {local }}=\frac{l b_j}{t}, u b_j^{\text {local }}=\frac{u b_j}{t}, \text { where } t=1,2, \ldots, T \end{gathered}\tag{8} lbjlocal ​=tlbj​​,ubjlocal ​=tubj​​, where t=1,2,…,T​(8)

X i P 2 : x i , j P 2 = x i , j + ( 1 − 2 r ) ⋅ ( l b j local  + r ⋅ ( u b j local  − l b j local  ) ) , i = 1 , 2 , … , N , j = 1 , 2 , … , m (9) \begin{gathered} X_i^{P 2}: x_{i, j}^{P 2}=x_{i, j}+(1-2 r) \cdot\left(l b_j^{\text {local }}+r \cdot\left(u b_j^{\text {local }}-l b_j^{\text {local }}\right)\right), \\ i=1,2, \ldots, N, j=1,2, \ldots, m \end{gathered}\tag{9} XiP2​:xi,jP2​=xi,j​+(1−2r)⋅(lbjlocal ​+r⋅(ubjlocal ​−lbjlocal ​)),i=1,2,…,N,j=1,2,…,m​(9)

其中t 为迭代次数,如果更新后的个体更优则更新当前个体,否则保持原状:
X i = { X i P 2 , F i P 2 < F i X i , else  (10) X_i=\left\{\begin{aligned} X_i^{P 2}, & F_i^{P 2}<F_i \\ X_i, & \text { else } \end{aligned}\right.\tag{10} Xi​={XiP2​,Xi​,​FiP2​<Fi​ else ​(10)

算法流程图如下:

2.实验结果

3.参考文献

[1]Dehghani Mohammad,Montazeri Zeinab,Trojovská Eva,Trojovský Pavel. Coati Optimization Algorithm: A new bio-inspired metaheuristic algorithm for solving optimization problems[J]. Knowledge-Based Systems,2023,259.

uristic algorithm for solving optimization problems[J]. Knowledge-Based Systems,2023,259.

4. Matlab

5.python

智能优化算法:浣熊优化算法-附代码相关推荐

  1. 智能优化算法:闪电搜索算法-附代码

    智能优化算法:闪电搜索算法-附代码 文章目录 智能优化算法:闪电搜索算法-附代码 1.算法原理 1.1 过渡放电体 1.2 空间放电体 1.3 引导放电体 2.算法结果 3.参考文献 4.Matlab ...

  2. 智能优化算法:布谷鸟搜索算法-附代码

    智能优化算法:布谷鸟搜索算法-附代码 文章目录 智能优化算法:布谷鸟搜索算法-附代码 1.算法原理 2.算法结果 3.参考文献 4.Matlab代码 摘要:谷鸟搜索算法(cuckoo search , ...

  3. 基于蝙蝠算法优化BP神经网络的数据分类算法及其MATLAB实现-附代码

    基于蝙蝠算法优化BP神经网络的数据分类算法及其MATLAB实现-附代码 文章目录 基于蝙蝠算法优化BP神经网络的数据分类算法及其MATLAB实现-附代码 1 蝙蝠算法与BP神经网络分类模型 1.1 蝙 ...

  4. 基于灰狼算法优化支持向量机的数据分类算法及其MATLAB实现-附代码

    基于灰狼算法优化支持向量机的数据分类算法及其MATLAB实现-附代码 文章目录 基于灰狼算法优化支持向量机的数据分类算法及其MATLAB实现-附代码 1 GWO-SVM 模型 1.1 灰狼优化器GWO ...

  5. 相位 unwrap 与 wrap 算法详解(附代码)

    相位 unwrap 与 wrap 算法详解(附代码) 最近接手了一个项目,光通信方面的,我负责编写初测结果的数据处理算法,其中有一个算法叫做 unwrap 与 wrap,之前没有听说过.通过询问同事与 ...

  6. 数据挖掘领域十大经典算法之—SVM算法(超详细附代码)

    相关文章: 数据挖掘领域十大经典算法之-C4.5算法(超详细附代码) 数据挖掘领域十大经典算法之-K-Means算法(超详细附代码) 数据挖掘领域十大经典算法之-Apriori算法 数据挖掘领域十大经 ...

  7. 二分查找算法详解(附代码)

    二分查找算法详解(附代码) 注: 现有一个升序 不重复的数组 查询target是否在此数组中并返回序号 使用条件 使用二分算法的两个条件: 有序 不重复 混淆处 二分算法两种方式容易弄混淆的地方:就是 ...

  8. 数据挖掘领域十大经典算法之—AdaBoost算法(超详细附代码)

    相关文章: 数据挖掘领域十大经典算法之-C4.5算法(超详细附代码) 数据挖掘领域十大经典算法之-K-Means算法(超详细附代码) 数据挖掘领域十大经典算法之-SVM算法(超详细附代码) 数据挖掘领 ...

  9. 麻雀优化算法_多种智能优化算法应用案例分享-附代码

    1.智能优化算法应用:基于灰狼算法的Otsu图像多阈值分割 智能优化算法应用:基于灰狼算法的Otsu图像多阈值分割-附代码_Jack旭的博客-CSDN博客​blog.csdn.net 2.智能优化算法 ...

  10. 智能优化算法:麻雀搜索算法-附代码

    2020智能优化算法:麻雀搜索算法 文章目录 2020智能优化算法:麻雀搜索算法 1.算法原理 2.算法结果 3.参考文献 4.Matlab代码 5.Python代码 摘要:麻雀搜索算法(Sparro ...

最新文章

  1. 类似 Google Tips 页面的卡片式提示和翻转特效
  2. 【bzoj2434】[Noi2011]阿狸的打字机 AC自动机+Dfs序+树状数组
  3. 我对CSS选择器的认识
  4. php dao类设计,DAO数据访问对象设计 - GoFrame官网 - 类似PHP-Laravel, Java-SpringBoot的Go企业级开发框架...
  5. maven ssm框架 mysql_SSM框架(IDEA+Spring+SpringMVC+Maven+Mybatis+MySQL)
  6. Spring AOP AspectJ
  7. Unity开发《一起来捉妖》教程 | 2.用摄像头图像做背景
  8. C++学习笔记39:进程概念
  9. js中addEventListener第三个参数涉及到的事件捕获与冒泡
  10. [转]Repeate分页
  11. CentOS7部署k8s集群
  12. php 计算今天周几,php如何计算当前日期是周几
  13. python阴阳师自动狗粮脚本_用Python实现阴阳师自动抽卡
  14. UltraVNC源码编译流程
  15. 死区特性函数以及MATLAB验算
  16. 计算机病毒通常隐藏在 中 2分,计算机考试题
  17. android手机用户,2011年Android手机用户使用行为研究报告
  18. 你觉得自己真的有好好吃早餐吗
  19. 微信小程序云开发学习指南(一)
  20. cgroups的实现

热门文章

  1. MediaPipe基础(4)Hands(手)
  2. 记一次Powershell反混淆 (1)
  3. 简单的图片上传和下载
  4. SVN更换地址报错-UUID不一致-解决方案
  5. linux中ftok的作用,Unix/Linux编程之ftok函数用法
  6. Android 高德地图对于城市定位做地理编码+逆地理编码处理
  7. 风口喧嚣,AI产品应该坚守的三大战略
  8. 用java实现微信支付,退款,部分退款服务端
  9. 量化投资的正确姿势应该是这样的
  10. 超级产品:刚需、高频、痛点,可激发用户对企业产品的消费热情