Matlab群体智能优化算法之苍鹰优化算法(NGO)

Northern Goshawk Optimization:A New Swarm-Based Algorithm for Solving Optimization Problems
参考文献:Dehghani M, Hubálovský Š, Trojovský P. Northern Goshawk Optimization: A New Swarm-Based Algorithm for Solving Optimization Problems[J]. IEEE Access, 2021, 9: 162059-162080.

注:仅记录学习,如有侵权,联系删除

1、初始化
  X代表整个鹈鹕种群,每个 X i X_{i} Xi都是都是给定问题的一个候选解。
  F代表适应度函数值。
X = [ X 1 ⋮ X i ⋮ X N ] N × m = [ x 1 , 1 ⋯ x 1 , j ⋯ x 1 , m ⋮ ⋱ ⋮ ⋮ x i , 1 ⋯ x i , j ⋯ x i , m ⋮ ⋮ ⋱ ⋮ x N , 1 ⋯ x N , j ⋯ x N , m ] N × m X=\left[\begin{array}{c} X_{1} \\ \vdots \\ X_{i} \\ \vdots \\ X_{N} \end{array}\right]_{N \times m}=\left[\begin{array}{ccccc} x_{1,1} & \cdots & x_{1, j} & \cdots & x_{1, m} \\ \vdots & \ddots & \vdots & & \vdots \\ x_{i, 1} & \cdots & x_{i, j} & \cdots & x_{i, m} \\ \vdots & & \vdots & \ddots & \vdots \\ x_{N, 1} & \cdots & x_{N, j} & \cdots & x_{N, m} \end{array}\right]_{N \times m} X=X1XiXNN×m=x1,1xi,1xN,1x1,jxi,jxN,jx1,mxi,mxN,mN×m
F = [ F 1 ⋮ F i ⋮ F N ] N × 1 = [ F ( X 1 ) ⋮ F ( X i ) ⋮ F ( X N ) ] N × 1 F=\left[\begin{array}{c} F_{1} \\ \vdots \\ F_{i} \\ \vdots \\ F_{N} \end{array}\right]_{N \times 1}=\left[\begin{array}{c} F\left(X_{1}\right) \\ \vdots \\ F\left(X_{i}\right) \\ \vdots \\ F\left(X_{N}\right) \end{array}\right]_{N \times 1} F=F1FiFNN×1=F(X1)F(Xi)F(XN)N×1
x i , j = l j +  rand  ⋅ ( u j − l j ) , i = 1 , 2 , … , N , j = 1 , 2 , … , m x_{i, j}=l_{j}+\text { rand } \cdot\left(u_{j}-l_{j}\right), i=1,2, \ldots, N, j=1,2, \ldots, m xi,j=lj+ rand (ujlj),i=1,2,,N,j=1,2,,m
  式中: x i , j x_{i, j} xi,j代表第i个苍鹰的第j个变量的值;N是种群大小;m是维度;rand代表[0,1]之间的随机数; l j l_{ j} lj代表下限; u j u_{ j} uj代表上限。

2、位置更新方式
在这里插入图片描述
2.1 第一阶段
                  在这里插入图片描述
第一阶段,随机选择一个猎物,然后迅速攻击它。这个阶段由于在搜索空间中随机选择猎物,增加了搜索能力,确定最佳地区。

P i = X k , i = 1 , 2 , … , N , k = 1 , 2 , … , i − 1 , i + 1 , … , N x i , j n e w , P 1 = { x i , j + r ( p i , j − I x i , j ) , F P i < F i , x i , j + r ( x i , j − p i , j ) , F P i ≥ F i , X i = { X i n e w , P 1 , F i n e w , P 1 < F i , X i , F i n e w , P 1 ≥ F i , \begin{aligned} &P_{i}=X_{k}, i=1,2, \ldots, N, k=1,2, \ldots, i-1, i+1, \ldots, N\\ &\begin{aligned} x_{i, j}^{n e w, P 1} &= \begin{cases}x_{i, j}+r\left(p_{i, j}-I x_{i, j}\right), \quad F_{P_{i}}<F_{i}, \\ x_{i, j}+r\left(x_{i, j}-p_{i, j}\right), \quad F_{P_{i}} \geq F_{i},\end{cases} \\ X_{i} &= \begin{cases}X_{i}^{n e w, P 1}, & F_{i}^{n e w, P 1}<F_{i}, \\ X_{i}, & F_{i}^{n e w, P 1} \geq F_{i},\end{cases} \end{aligned} \end{aligned} Pi=Xk,i=1,2,,N,k=1,2,,i1,i+1,,Nxi,jnew,P1Xi={xi,j+r(pi,jIxi,j),FPi<Fi,xi,j+r(xi,jpi,j),FPiFi,={Xinew,P1,Xi,Finew,P1<Fi,Finew,P1Fi,
  式中: r r r是属于[0,1]的随机数,; I I I是随机数字,可以取1或2,当 I I I=2时,可以增加每个个体的位移,使得其进入搜索空间的新区域。

2.2第二阶段
                  在这里插入图片描述
x i , j n e w , P 2 = x i , j + R ( 2 r − 1 ) x i , j , R = 0.02 ( 1 − t T ) , X i = { X i n e w , P 2 , F i n e w , P 2 < F i , X i , F i n e w , P 2 ≥ F i . \begin{aligned} x_{i, j}^{n e w, P 2} &=x_{i, j}+R(2 r-1) x_{i, j}, \\ R &=0.02\left(1-\frac{t}{T}\right), \\ X_{i} &= \begin{cases}X_{i}^{n e w, P 2}, & F_{i}^{n e w, P 2}<F_{i}, \\ X_{i}, & F_{i}^{n e w, P 2} \geq F_{i} .\end{cases} \end{aligned} xi,jnew,P2RXi=xi,j+R(2r1)xi,j,=0.02(1Tt),={Xinew,P2,Xi,Finew,P2<Fi,Finew,P2Fi.
  式中:无特殊含义。

3、流程图
                  在这里插入图片描述
4、伪代码
                  在这里插入图片描述
5、测试
                  在这里插入图片描述
原文测试结果:
                  在这里插入图片描述
  花里胡哨,我不会。想发高水平的论文,还得看看高水平的是怎么画图的吧。卑微,有哪位同学会嘛,求分享。

    在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

勉为其难免免

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值