白鹭群优化算法,原理详解,MATLAB代码免费获取
白鹭群优化算法(Egret Swarm Optimization Algorithm,ESOA)是一种受自然启发的群智能优化算法。该算法从白鹭和白鹭的捕食行为出发,由三个主要部分组成:坐等策略、主动策略和判别条件。将ESOA算法与粒子群算法(PSO)、遗传算法(GA)、差分进化算法(DE)、等算法在36个基准函数和3个工程问题上的性能进行了比较。结果证明了该方法的有效性和鲁棒性。

该成果于2022年发表在计算机领域三区期刊Biomimetics上,目前在谷歌学术上被引率39次。

大多数白鹭栖息在沿海岛屿、海岸、河口和河流,以及靠近海岸的湖泊、池塘、溪流、稻田和沼泽。白鹭通常是成对的,或者是成群的。由于飞行时能量消耗很大,决定捕食通常需要彻底检查飞行轨迹,以确保通过食物的位置获得的能量比飞行中消耗的能量要多。总体而言,采用积极搜索策略的大白鹭会平衡高能量消耗以获得更大的潜在回报,而采用坐等策略的雪白鹭则会平衡低能量消耗以获得更小但更可靠的利润。
1、算法原理
(1)数学模型与算法
ESOA受白鹭的守株待兔策略和大白鹭的攻击策略的启发,结合了这两种策略的优点,构建了相应的数学模型来量化行为。如图所示,ESOA是一个并行算法,有三个基本组成部分:坐等策略,积极策略和判别条件。一个白鹭小队中有三只白鹭,白鹭A采用引导前进机制,白鹭B和白鹭C分别采用随机行走和包围机制。每一部分的细节如下。
Egret Squad的各个角色和搜索首选项如图所示。白鹭A将估计下降平面并基于平面参数的梯度进行搜索,白鹭B执行全局随机漫游,白鹭C基于更好的白鹭的位置选择性地进行探索。通过这种方式,ESOA在开发和勘探方面将更加平衡,并能够快速搜索可行的解决方案。与梯度下降不同,ESOA在梯度估计中引用了历史信息和随机性,这意味着它不太可能落入优化问题的鞍点。ESOA也不同于其他的元启发式算法,通过估计优化问题的切平面,使快速下降到当前的最优点。
(2)坐等策略
观测方程:假设第i个白鹭小队的位置为Xi ∈ Rn,n为问题的维数,A(n)为白鹭对当前位置可能存在的猎物的估计方法。是对当前位置猎物的估计,
则估计方法可以被参数化为,
其中wi ∈ Rn是估计方法的权重。误差ei可以描述为,
同时,ω i的实际梯度ω gi ∈ Rn可以通过对误差方程(3)的wi进行偏导数来恢复,其方向为d ω i。
下图展示了白鹭的跟随行为,其中白鹭在捕食过程中参考了更好的白鹭,借鉴了它们估计猎物行为的经验并融入了自己的想法。dh,i ∈ Rn是小队最佳位置的方向修正,而dg,i ∈ Rn是所有小队最佳位置的方向修正。
积分梯度gi ∈ Rn可以表示如下,并且rh ∈ [0,0.5),rg ∈ [0,0.5):
这里应用自适应权重更新方法[76],β1为0.9,β2为0.99:
根据白鹭A对当前情况的判断,下一个采样位置xa,i可以描述为,
其中t和tmax是当前迭代时间和最大迭代时间,而hop是解空间的下界和上界之间的差距。stepa ∈(0,1]是白鹭A的步长因子。ya,i是xa,i的适合度。
(3)积极的战略
白鹭B倾向于随机搜索猎物,其行为可描述如下,
其中rb,i是(− π/2,π/2)中的随机数,xb,i是白鹭B的预期下一个位置,yb,i是适应度。
白鹭C喜欢攻击性地追逐猎物,因此使用包围机制作为其位置的更新方法:
(4)判别条件
在白鹭小队的每个成员都决定了自己的计划后,小队会选择最佳方案并一起采取行动。xs,i是第i个白鹭小队的解矩阵:

如果最小值ys,i优于当前适应度yi,则白鹭队接受该选择。或者随机数r∈(0,1)小于0.3,这意味着有30%的可能性接受更差的方案。
ESOA对应的算法的伪代码如下所示。

2、结果展示
3、MATLAB核心代码
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [y_global_best, x_global_best, Convergence_curve]=ESOA(SearchAgents_no, Max_iter, lb, ub, dim, fobj)
func = fobj;
beta1 = 0.9;
beta2 = 0.99;
x=initialization(SearchAgents_no, dim, ub, lb);
Convergence_curve=zeros(1,Max_iter);
w = random('Uniform', -1, 1, SearchAgents_no, dim);
%g = random('Uniform', -1, 1, SearchAgents_no, dim);
m = zeros(SearchAgents_no, dim);
v = zeros(SearchAgents_no, dim);
y = zeros(SearchAgents_no,1);
for i=1:SearchAgents_noy(i) = func(x(i,:));
end
p_y = y;
x_hist_best = x;
g_hist_best = x;
y_hist_best = ones(SearchAgents_no)*inf;
x_global_best = x(1, :);
g_global_best = zeros(1, dim);
y_global_best = func(x_global_best);
hop = ub - lb;
l=0;% Loop counter
% Main loop
while l<Max_iterfor i=1:SearchAgents_nop_y(i) = sum(w(i, :) .* x(i, :));p = p_y(i) - y(i);g_temp = p.*x(i, :);% Indivual Directionp_d = x_hist_best(i, :) - x(i, :);f_p_bias = y_hist_best(i) - y(i);p_d = p_d .* f_p_bias;p_d = p_d ./ ((sum(p_d)+eps).*(sum(p_d)+eps));d_p = p_d + g_hist_best(i, :);% Group Directionc_d = x_global_best - x(i, :);f_c_bias = y_global_best - y(i);c_d = c_d .* f_c_bias;c_d = c_d ./ ((sum(c_d)+eps).*(sum(c_d)+eps));d_g = c_d + g_global_best;% Gradient Estimationr1 = rand(1, dim);r2 = rand(1, dim);g = (1 - r1 - r2).*g_temp + r1 .* d_p + r2 .* d_g;g = g ./ (sum(g) + eps);m(i,:) = beta1.*m(i,:)+(1-beta1).*g;v(i,:) = beta2*v(i,:)+(1-beta2)*g.^2;w(i,:) = w(i,:) - m(i,:)/(sqrt(v(i,:))+eps);% Advice Forwardx_o = x(i, :) + exp(-l/(0.1*Max_iter)) * 0.1 .* hop .* g;Flag4ub=x_o>ub;Flag4lb=x_o<lb;x_o = (x_o.*(~(Flag4ub+Flag4lb)))+ub.*Flag4ub+lb.*Flag4lb;y_o = func(x_o);% Random Searchr = random('Uniform', -pi/2, pi/2, 1, dim);x_n = x(i, :) + tan(r) .* hop/(1 + l) * 0.5;Flag4ub=x_n>ub;Flag4lb=x_n<lb;x_n = (x_n.*(~(Flag4ub+Flag4lb)))+ub.*Flag4ub+lb.*Flag4lb;y_n = func(x_n);% Encircling Mechanismd = x_hist_best(i, :) - x(i, :);d_g = x_global_best - x(i, :);r1 = rand(1, dim);r2 = rand(1, dim);x_m = (1-r1-r2).*x(i, :) + r1.*d + r2.*d_g;Flag4ub=x_m>ub;Flag4lb=x_m<lb;x_m = (x_m.*(~(Flag4ub+Flag4lb)))+ub.*Flag4ub+lb.*Flag4lb;y_m = func(x_m);% Discriminant Conditionx_summary = [x_m; x_n; x_o];y_summary = [y_m, y_n, y_o];y_summary(isnan(y_summary)) = inf;ind = y_summary==min(y_summary);y_i = min(y_summary);x_i = x_summary(ind, :);x_i = x_i(1, :);if y_i < y(i)y(i) = y_i;x(i, :) = x_i;if y_i < y_hist_best(i)y_hist_best(i) = y_i;x_hist_best(i, :) = x_i;g_hist_best(i, :) = g_temp;if y_i < y_global_besty_global_best = y_i;x_global_best = x_i;g_global_best = g_temp;endendelseif rand()<0.3y(i) = y_i;x(i, :) = x_i;endendend
l=l+1;
fprintf("%d, %f\n", l, y_global_best)
Convergence_curve(l) = y_global_best;
end
end
参考文献
[1]Chen Z, Francis A, Li S, et al. Egret swarm optimization algorithm: an evolutionary computation approach for model free optimization[J]. Biomimetics, 2022, 7(4): 144.
完整代码获取
后台回复关键词:
TGDM833
相关文章:

白鹭群优化算法,原理详解,MATLAB代码免费获取
白鹭群优化算法(Egret Swarm Optimization Algorithm,ESOA)是一种受自然启发的群智能优化算法。该算法从白鹭和白鹭的捕食行为出发,由三个主要部分组成:坐等策略、主动策略和判别条件。将ESOA算法与粒子群算法(PSO)、遗传算法(GA)…...

【源码】2024完美运营版商城/拼团/团购/秒杀/积分/砍价/实物商品/虚拟商品等全功能商城
后台可以自由拖曳修改前端UI页面 还支持虚拟商品自动发货等功能 前端UNIAPP 后端PHP 一键部署版本 获取方式: 微:uucodes...

Java-数组内存解析
文章目录 1.内存的主要结构:栈、堆2.一维数组的内存解析3.二维数组的内存解析 1.内存的主要结构:栈、堆 2.一维数组的内存解析 举例1:基本使用 举例2:两个变量指向一个数组 3.二维数组的内存解析 举例1: 举例2&am…...

Spring Cache --学习笔记
一、概述 Spring Cache 是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。 Spring Cache 提供了一层抽象,底层可以切换不同的缓存实现,例如: EHCache Caffeine Redis(常…...

NTP服务的DDoS攻击:原理和防御
NTP协议作为一种关键的互联网基础设施组件,旨在确保全球网络设备间的时钟同步,对于维护数据一致性和安全性至关重要。然而,其设计上的某些特性也为恶意行为者提供了发动大规模分布式拒绝服务(DDoS)攻击的机会。以下是NTP服务DDoS攻击及其防御…...

【面试干货】事务的并发问题(脏读、不可重复读、幻读)与解决策略
【面试干货】事务的并发问题(脏读、不可重复读、幻读)与解决策略 一、脏读(Dirty Read)二、不可重复读(Non-repeatable Read)三、幻读(Phantom Read)四、总结 💖The Begi…...

函数式接口:现代编程的利器
1. 引言 在软件开发的演进过程中,函数式编程(Functional Programming, FP)逐渐显露头角,成为解决复杂问题的有效工具之一。函数式接口作为函数式编程的核心概念之一,其重要性不言而喻。本文将深入探讨函数式接口的概念…...

2022职称继续教育--深入实施新时代人才强国战略 加快建设世界重要人才中心和创新高地
单选题(共7题,每题5分) 1、()实行职位职级制工资为主。 D、中长线科研重要岗位人员 2、建设世界重要人才中心和创新高地有()个阶段目标。 B、三 3、综合国力竞争说到底是(…...

kube-prometheus-stack 识别 k8s 集群内所有的 ServiceMonitor 和 PrometheusRule
默认情况下,kube-prometheus-stack 只自己创建的 ServiceMonitor,如果 k8s 集群内有多个非 kube-prometheus-stack 创建的 ServiceMonitor,不会被识别到。PrometheusRule 同理。 要识别所有的 ServiceMonitor 和 PrometheusRule ,…...

Android 图片加载glide库 一次通关
前言 Glide是一个由Bumptech开发的开源图片加载库,专门用于Android平台。它被广泛应用于Android应用中,以简化图片加载过程,并提高性能和效率。 Glide能够快速加载图片,同时减少页面加载时间和内存消耗。Glide具有强大的缓存机制…...

Spring OAuth2:开发者的安全盾牌!(上)
何利用Spring OAuth2构建坚不可摧的安全体系?如何使用 OAuth2 从跨域挑战到性能优化,每一个环节都为你的应用保驾护航? 文章目录 Spring OAuth2 详解1. 引言简述OAuth2协议的重要性Spring Framework对OAuth2的支持概述 2. 背景介绍2.1 OAuth2…...

设计模式使用(成本扣除)
前言 名词解释 基础名词 订单金额:用户下单时支付的金额,这个最好理解 产品分成:也就是跟其他人合做以后我方能分到的金额,举个例子,比如用户订单金额是 100 块,我方的分成是 80%,那么也就是…...

输入输出(2)——C++的标准输出流
目录 一、C的标准输出流 (一)cout、cerr和clog流对象 1、cout 流对象 2、cerr 流对象 3、clog流对象 (二)用函数put输出字符 (三)用函数 write 输出字符 一、C的标准输出流 标准输出流——流向标准输…...

C语言序列化和反序列化--TPL(一)
TPL TPL说明网站 C语言中高效的序列化 您可以使用tpl快速轻松地存储和重新加载C数据。Tpl是一个用于序列化C数据的库。数据以自然二进制形式存储。该API很小,并试图保持“不碍事”。Tpl可以序列化许多C数据类型,包括结构。Tpl与文件、内存缓冲区和文件…...

Session + JWT + Cookie
00:HTTP无状态(为了保持状态,前端好麻烦,又要自己存,又要想办法带出去,于是使用cookie) 01:Cookie 将用户信息,在每次请求时候 带给后端(但是自己存储大小有…...

PaddleOCR2.7+Qt5
章节一:Windows 下的 PIP 安装 官网安装教程地址 按照里面的教程去安装 如果使用cuda版本的还要安装tensorrt,不然后面运行demo程序的程序会报如下错。 下载TensorRT 8版本,tensorrt下载地址 章节二:编译源码 进入官网源码地址 下…...

在Android中解析XML文件并在RecyclerView中显示
1. 引言 最近工作有解析外部xml文件在App中显示的需求,特来写篇文章记录一下,方便下次使用。 2. 准备工作 首先,在项目的AndroidManifest.xml文件中添加读取外部存储的权限声明。 <uses-permission android:name"android.permiss…...

Notes for video: EDC-Con 2022/01 - EDC Conceptual Overview and Architecture
Eclipse Dataspace Connector 中文概念 Eclipse Dataspace Connector (EDC) 是一个开源项目,旨在提供一种标准化的方法来连接和共享数据空间中的数据。它是 Eclipse Foundation 下的一个项目,目标是促进数据共享和数据交换的互操作性。以下是 EDC 的一些…...

windows下nginx配置https证书
1、制作证书 1.1 安装工具openSSL。下载地址:http://slproweb.com/products/Win32OpenSSL.html Win64OpenSSL_Light-3_1_0.exe安装(假定安装位置在 d:\openSSL\) 1.2 配置openSSL环境。 新建系统变量OpenSSL值为d:\openSSL\bin,相…...

Llama改进之——RoPE旋转位置编码
引言 旋转位置编码(Rotary Position Embedding, RoPE)将绝对相对位置依赖纳入自注意力机制中,以增强Transformer架构的性能。目前很火的大模型LLaMA、QWen等都应用了旋转位置编码。 之前在[论文笔记]ROFORMER中对旋转位置编码的原始论文进行了解析,重点…...

Python的解析网页
课前案例 通过requests模块爬取指定网站中的图片并保存到本地目录中。 上述案例采用的是同步方式下载图片,效率太低。异步方式如下(线程): # target为目标函数;args中传入的是download函数的参数url threading.Threa…...

VBA技术资料MF159:实现某个区域内的数据滚动
我给VBA的定义:VBA是个人小型自动化处理的有效工具。利用好了,可以大大提高自己的工作效率,而且可以提高数据的准确度。“VBA语言専攻”提供的教程一共九套,分为初级、中级、高级三大部分,教程是对VBA的系统讲解&#…...

开源DMS文档管理系统 Nuxeo Vs Alfresco对比及 API 使用概述
1. 文档管理系统是什么 文档管理系统(DMS:Document Management System)是一种软件系统,用于组织、存储、检索和管理电子文档和文件。这些文件可以是各种格式的电子文档,如文本文档、电子表格、图像、音频或视频文件等…...

lambda函数实践
文章目录 1.简单实例2.lambda函数使用3.捕获列表的使用4.lambda表达式的应用1.简单实例 2.lambda函数使用 3.捕获列表的使用 4.lambda表达式的应用 #include <iostream> #include <vector>using namespace std;/** 1.简单实例* 2.lambda函数使用* 3.捕获列表的…...

[leetcode hot 150]第一百九十一题,位1的个数
题目: 编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中设置位的个数(也被称为汉明重量)。 这道题比较简单,直接对最后一位进行与1的与操作,然…...

gitea的git库备份与恢复
文章目录 gitea库的备份与恢复概述笔记实验环境更新git for windows更新 TortoiseGit备份已经存在的gitea的git库目录使用gitea本身来备份所有git库目录将gitea库恢复到新目录m1m2m3启动gitea - 此时已经恢复完成FETCH_HEAD 中有硬写位置再查一下app.ini, 是否改漏了。m1m2 总结…...

【强化学习05】从Q学习到深度Q学习
深度Q学习(Deep Q-Learning, DQN)是将深度学习与Q学习结合起来的一种强化学习方法,利用神经网络来近似Q值函数,解决传统Q学习在大规模或连续状态空间中的局限性。下面详细解释DQN的机理。 背景知识 Q学习 Q学习是一种值函数法&…...

FPGA实现多路并行dds
目录 基本原理 verilog代码 仿真结果 基本原理 多路并行dds,传统DDS的局限性在于输出频率有限。根据奈奎斯特采样定理,单路DDS的输出频率应小于系统时钟频率的一半。但是在很多地方,要使采样率保持一致,所以,为了…...

ArcgisPro3.1.5安装手册
ArcgisPro3.1.5安装手册 一、目录介绍: 二、安装教程: (1)安装顺序:最先安装运行环境(runtime6.0.5),接着安装install里面的文件,最后复制path里面的文件替换到软件bin文件夹下即可。 (2)具体安装步骤ÿ…...

三大主流框架
Web前端开发领域中,三大主流框架通常指的是: React:由Facebook开发的一个用于构建用户界面的JavaScript库。React以其组件化、声明式编程和虚拟DOM等特点而广受欢迎,能够高效地更新和渲染大型应用。 Vue.js:由尤雨溪创…...