智能优化算法:斑点鬣狗优化算法-附代码

2024-06-18 07:49

本文主要是介绍智能优化算法:斑点鬣狗优化算法-附代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

斑点鬣狗优化算法-附代码

文章目录

  • 斑点鬣狗优化算法-附代码
    • 1.算法原理
      • 1.1包围机制
      • 1.2 狩猎机制
      • 1.3 攻击猎物(局部搜索)
      • 1.4 算法流程图
    • 2. 算法结果:
    • 3.参考文献:
    • 4.Matlab代码地址:
    • 5.Python代码地址:

摘要:斑点鬣狗优化是印度塔帕尔大学 Dhiman 等[1]提出的一种新的优化算法,它主要模拟了斑点鬣狗的狩猎行为。斑点鬣狗依靠可信赖的朋友网络和识别猎物的能力来捕食猎物,这种狩猎方法可以在更短的时间内找到更好的解决方案。斑点鬣狗优化极大地增强了算法的自适应性,同时可以扩展到更高的维度,在优化问题中得以广泛应
用。

1.算法原理

​ 斑点鬣狗是非常聪明的群体社交动物,它们通过多种感官来识别亲属和其他个体,并对同一种族的关系进行了排名,群体中具有高地位的个体优先获得信任。由于这种生活习性,斑点鬣狗在群体狩猎方面具有非常高的成功率。斑点鬣狗种群的捕食机制包括搜索、包围、狩猎和攻击猎物四个过程。斑点鬣狗算法的基本原理如下:

1.1包围机制

斑点鬣狗具有熟悉并判断猎物的位置,从而包围它们的能力。该行为的数学模型由具体描述为:
D h = ∣ B . P t − P ( t ) ∣ B = 2 r 1 D_{h}=|B.P_{t}-P(t)|\\ B=2r_{1} Dh=B.PtP(t)B=2r1
式中: D h D_{h} Dh为猎物与斑点鬣狗个体之间的距离; t t t
迭代次数; P p P_{p} Pp为猎物位置; P ( t ) P(t) P(t) 是斑点鬣狗个体位
置; B B B为摇摆因子。

斑点鬣狗的个体位置更新为:
P ( t + 1 ) = P t − E . D h E = 2 h . r 2 − h h = 5 − 5 I t e r a t i o n N I P(t+1)=P_{t}-E.D_{h}\\ E=2h.r_{2}-h\\ h=5-5\frac {Iteration}{NI} P(t+1)=PtE.DhE=2h.r2hh=55NIIteration

式中:E为收敛因子; r1,r2 表示[0,1] 间的随机数;h表示控制因子,随迭代次数的增加而线性减小,取值范围为[0,5] ; NI为最大迭代次数。

斑点鬣狗通过可以通过猎物的位置, 来调整自己的位置。设斑点鬣狗位置为( A A A B B B),猎物位置为( A ∗ A^{*} A B ∗ B^{*} B)。斑点鬣狗通过调整B和E来遍布猎物周围不同的位置。如下图所示:

在这里插入图片描述

图1斑点鬣狗的二维位置矢量

1.2 狩猎机制

斑点鬣狗通常依靠可信赖的种群网络及识别猎物位置的能力来生活和分组捕杀。该机制的具体描述为:
D h = ∣ B . P t ( t ) − P k ∣ P k = P h − E . D h C h = P k + P k + 1 + . . . P k + N D_{h}=|B.P_{t}(t)-P_{k}|\\ P_{k}=P_{h}-E.D_{h}\\ C_{h}=P_{k}+P_{k+1}+...P_{k+N} Dh=B.Pt(t)PkPk=PhE.DhCh=Pk+Pk+1+...Pk+N
式中: P h P_{h} Ph定义了第一个最佳斑点鬣狗的位置; P k P_{k} Pk
示其他斑点鬣狗的位置; N N N表示斑点鬣狗的数量; C h C_{h} Ch N N N个最优解的集群。其中 N N N计算如下:
N = C o u n t n o s ( P h , P h + 1 , . . . , ( P h + M ) N=Count_{nos}(P_{h},P_{h+1},...,(P_{h}+M) N=Countnos(Ph,Ph+1,...,(Ph+M)
式子中: M M M是[0.5,1]中的随机向量,在添加 M M M之后, n o s nos nos定义可行解的数量并计算所有候选解,其与给定搜索空间中的最优解相似。

1.3 攻击猎物(局部搜索)

斑点鬣狗在猎食的最后阶段开始攻击猎物,当收敛因子 ∣ E ∣ < 1 |E|<1 E<1 时,斑点鬣狗个体便会向猎物发动攻击。全局最优解通过求取当前最优解集的平均值来确定斑点鬣狗搜
索个体的更新趋势。攻击猎物的数学公式具体描述如下:
P h ( t + 1 ) = C h N P_{h}(t+1)=\frac {C_{h}}{N} Ph(t+1)=NCh
式子中: P h ( t + 1 ) P_{h}(t+1) Ph(t+1)保持最优解; C h C_{h} Ch表示最优解群集。
4) 搜索机制(全局探索):斑点鬣狗大多根据位于最优解群集 C h C_{h} Ch 中的斑点鬣狗群或群集的位置来搜寻猎物,当收敛因子 ∣ E ∣ > 1 |E|>1 E>1时,斑点鬣狗将分散 , 远 离 当 前 的 猎 物 , 并 寻 找 更 合 适 的 猎 物 位置。这种机制使得算法可在全局搜索。

用SHO 算法解决优化问题时需要注意以下几点:
(1)该算法保留了迭代过程中获得的所有最佳解。
(2)所提出的斑点鬣狗搜寻机制定义了一个圆形的邻域周围的解决方案,可以扩展到更高的维度作为一个超球体。
(3)随机向量B和E协助候选解具有不同随机位置的超
球体。
(4)建议的狩猎方法允许候选解确定猎物的可能位置。
(5)利用向量E和h的调整值可表示探险和开发的 可能性这一特点,使该算法可以 轻松地在探险和开发之间 进行转换。
(6)使用向量E,一半迭代用于搜索(探险)( ∣ E ∣ > 1 |E|>1 E>1),
另一半迭代用于打猎(开发)( ∣ E ∣ < 1 |E|<1 E<1)。

1.4 算法流程图

在这里插入图片描述

图2.流程图

2. 算法结果:

在这里插入图片描述

3.参考文献:

[1]DHIMAN G, KAUR A. Spotted hyena optimizer for solving engineering design problems[C]//2017 International.Conference on Machine learning and Data Science(MLDS). Greater Noida, India, IEEE, 2017.

[2]贾鹤鸣,姜子超,李瑶,孙康健,李金夺,彭晓旭.基于模拟退火斑点鬣狗优化算法的特征选择[J].应用科技,2020,47(01):74-79.

[3]钟文,张志浩,管鑫,陈波,黄泰相,付翊航.基于斑点鬣狗算法的风/光/抽水蓄能联合运行系统优化调度研究[J].电力学报,2020,35(02):113-122.

4.Matlab代码地址:

斑点鬣狗优化算法
算法相关应用matlab代码

名称说明或者参考文献
斑点鬣狗优化的BP神经网络(预测)https://blog.csdn.net/u011835903/article/details/112149776 (原理一样,只是优化算法用斑点鬣狗算法)

5.Python代码地址:

个人资料介绍

这篇关于智能优化算法:斑点鬣狗优化算法-附代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1071701

相关文章

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

jupyter代码块没有运行图标的解决方案

《jupyter代码块没有运行图标的解决方案》:本文主要介绍jupyter代码块没有运行图标的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录jupyter代码块没有运行图标的解决1.找到Jupyter notebook的系统配置文件2.这时候一般会搜索到

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N