ALO 算法核心思想是模拟蚁狮捕猎蚂蚁的狩猎机制以实现全局寻优。蚁狮在捕猎前会在在沙质土中利用其巨大的下颚挖出一个漏斗状的陷阱,并藏在陷阱底部等待猎物到来。一旦随机游走的蚂蚁落入陷阱时,蚁狮迅速将其捕食,随后重新修缮陷阱等待下一次捕猎。ALO 算法通过数值模拟实现蚂蚁和蚁狮之间的相互作用将问题优化:引入蚂蚁的随机游走实现全局搜索,通过轮盘赌策略和精英策略保证种群的多样性和算法的寻优性能。蚁狮相当于优化问题的解,通过猎捕高适应度的蚂蚁实现对近似最优解的更新和保存。
蚂蚁在自然界中随机游走寻找食物的过程可以看作各搜索代理搜寻可行域的过程。随机游走的过程在数学上可以表示为:
X ( t ) = [ 0 , c u s s u m ( 2 r ( t 1 ) − 1 ) , . . . , c u s s u m ( 2 r ( t n ) − 1 ) ] (1) X(t)=[0,cussum(2r(t_{1})-1),...,cussum(2r(t_{n})-1)]\tag{1} X(t)=[0,cussum(2r(t1)−1),...,cussum(2r(tn)−1)](1)
式中: X ( t ) X(t) X(t)为蚂蚁随机游走的步数集; c u m s u m cumsum cumsum 为计算累加和; t t t 为随机游走的步数(本文取最大迭代次数); r ( t ) r(t) r(t)为一个随机函数,定义为
r ( t ) = { 1 , r a n d > 0.5 0 , r a n d ≤ 0.5 (2) r(t)=\begin{cases} 1,rand>0.5\\0,rand\leq0.5\end{cases} \tag{2} r(t)={1,rand>0.50,rand≤0.5(2)
式中: r a n d rand rand为[0,1]的随机数。
由于可行域存在边界,不能直接用式(1)更新蚂蚁的位置。为确保蚂蚁在可行域范围内随机游走,需根据式(3)对其进行归一化
X i t = ( X i t − a i ) ∗ ( d i t − c i t ) ( b i − a i ) + c i t (3) X_{i}^{t}=\frac {(X_{i}^{t}-a_{i})*(d_{i}^{t}-c_{i}^{t})}{(b_{i}-a_{i})}+c_{i}t\tag{3} Xit=(bi−ai)(Xit−ai)∗(dit−cit)+cit(3)
式中: a i a_{i} ai 为第$ i$ 维变量随机游走的最小值; b i b_{i} bi为第 i i i 维变量随机游走的最大值; c t i c_{t}^{i} cti为第 i i i维变量再第 t t t次迭代的最小值; d i t d_{i}^{t} dit为第 i i i 维变量在第$ t$ 次迭代最大值。
蚁狮制造的陷阱会影响蚂蚁随机游走的路线,为对此假设进行数学建模,提出
{ c i t = A l i t + C t d i t = A l j t − d t (4) \begin{cases} c_{i}^{t}=Al_{i}^{t} + C^{t}\\d_{i}^{t}=Al_{j}^{t}-d^{t}\end{cases}\tag{4} {cit=Alit+Ctdit=Aljt−dt(4)
式中: c t c^{t} ct为所有变量在第 t t t 次迭代的最小值; d t d^{t} dt为所有变量在第 t t t 次迭代的最大值; A l j t Al_{j}^{t} Aljt 为被选定的第 j j j 只蚁狮在第 t t t 次迭代的位置。
通过轮盘赌策略选择某只蚂蚁具体被哪只蚁狮捕食,每只蚂蚁只能被一只蚁狮捕食,而适应度越高的蚁狮捕获蚂蚁的概率越大。另外,蚂蚁一旦落入蚁狮制造的陷阱,蚁狮就会向陷阱边缘抛沙以防止蚂蚁逃脱。此时,蚂蚁随机游走的范围将急剧缩小。通过下列方程模拟这种现象
c t = c t I , d t = d t I (5) c^{t}=\frac {c^{t}}{I},d^{t}=\frac {d^{t}}{I}\tag{5} ct=Ict,dt=Idt(5)
I = { 1 , t ≤ 0.1 T 1 0 v ∗ t T , t > 0.1 T (6) I=\begin{cases}1,t\leq0.1T\\10^{v}*\frac{t}{T},t>0.1T \end{cases}\tag{6} I={1,t≤0.1T10v∗Tt,t>0.1T(6)
式中: I I I 为比例系数; T T T为最大迭代次数; v v v 为一个随着迭代次数增大而变化的数。当蚂蚁的适应度值比蚁狮小时,则认为蚁狮将其捕获,此时蚁狮会根据蚂蚁的位置来更新位置
A l j t = A n t i t , i f f ( A n t i t ) < f ( A l j t ) (7) Al_{j}^{t}=Ant_{i}^{t},if\quad f(Ant_{i}^{t})
式中: A n t i t Ant_{i}^{t} Antit 为第 i i i只蚂蚁在第 t t t次迭代的位置; f f f 为适应度函数。
每次迭代后,选择适应度最好的蚁狮作为精英蚁狮。第 t t t只蚂蚁在第 t + 1 t +1 t+1次迭代的位置由式(8)确定
A n t i t + 1 = R A t ( l ) + R E t ( l ) 2 (8) Ant_{i}^{t+1}=\frac {R_{A}^{t}(l)+R_{E}^{t}(l)}{2}\tag{8} Antit+1=2RAt(l)+REt(l)(8)
式中: R A t ( l ) R_{A}^{t}(l) RAt(l)为蚂蚁在一只由轮盘赌在第 t t t 次迭代选择到的蚁狮周围随机游走第 l l l 步产生的值; R E t ( l ) R_{E}^{t}(l) REt(l)为蚂蚁在第 t t t代的精英蚁狮周围随机游走第 l l l步产生的值。 l l l为蚂蚁随机游走步数内的任何值。
(1)数据初始化。确定蚂蚁和蚁狮的数量以及变量维数,在可行域内随机初始化它们的位置,并计算相应的适应度值。
(2)确定精英蚁狮。选择初始化后蚁狮种群中适应度最好的作为精英蚁狮。
(3)通过轮盘赌为每只蚂蚁选择一只蚁狮,根据蚁狮位置更新 c t , d t , c i t , d i t c_{t},d_{t},c_{i}^{t},d_{i}^{t} ct,dt,cit,dit 的值,并使该蚂蚁按照式(1)、式(3)在蚁狮及精英蚁狮附近随机游走,最后按式(8)取平均值作为蚂蚁的位置。
(4) 每次迭代后重新计算蚂蚁和蚁狮适应度值,根据蚂蚁的位置和适应度更新蚁狮位置,适应度最好的位置为新精英蚁狮的位置。
(5)判断是否到达最大迭代次数,若到达则输出结果并结束迭代,否则重复步骤 (3)
[1]Seyedali Mirjalili. The Ant Lion Optimizer[J]. Advances in Engineering Software,2015,83.
[2]陈承滨,余岭,潘楚东,陈泽鹏.基于蚁狮优化算法与迹稀疏正则化的结构损伤识别[J].振动与冲击,2019,38(16):71-76+99.
https://mianbaoduo.com/o/bread/Z5iUk5c=