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

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

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、