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

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

相关文章

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.