智能优化算法:群居蜘蛛优化算法

智能优化算法:群居蜘蛛优化算法-附代码

@[toc]
摘要:群居蜘蛛优化(Social Spider Optimization,SSO) 算法是一种群体智能进化算法,该算法基于群居蜘蛛中个体与群体协作行为的模拟,考虑两个不同的搜索动因:雄性和雌性。按照性别,个体分属于两种不同的进化算子,并在群体内模仿不同的协作行为。该算法具有较好的收敛速度和全局搜索能力。

1.算法原理

群居蜘蛛(Social Spider)是一类倾向群居的蜘蛛物种,个体间保持有复杂的协作行为准则,根据雌雄执行多种任务,如捕食,交配,蜘蛛网设计及群体协作等。群居蜘蛛由个体和蜘蛛网络组成,个体分为雄性和雌性两种类别。种群依据个体雌雄分配不同的任务,个体之间通过直接或间接的协作将有用信息通过蜘蛛网络传递给群居中的其他个体,并将此信息编码成振动的强弱在个体间进行协作。振动的强弱可被群居中个体解码成不同的信息,如猎物的大小,相邻个体特征等,而振动的强度取决于蜘蛛的重量和距离。SSO 算法在真实模拟群居蜘蛛群体内不同协作行为的基础上,引入新的计算机制,有效避免了目前常规群算法中存在的早熟收敛和局部极值问题在解决连续变量优化问题时,SSO 算法是以迭代的方式不断地寻找最优值,最重个体蜘蛛所处的位置即优化问题的解。假设整个搜索空间为蜘蛛网络,每个潜在解即为搜索空间中蜘蛛所处的位置。依据雄性和雌性的搜索机制,每个个体分属于两种不同的进化算子,并在群体内模仿不同的协作行为。
SSO 算法步骤可归纳如下:

Step1 设搜索空间的维度n,雌性蜘蛛N_f ,雄性蜘蛛N_m 以及总种群数量 N。定义N_fN_m 为:
N_f = floor[(0.9 - rand\cdot 0.25)\cdot N] \tag{1}

N_m=N-N_f \tag{2}

式中: rand 为[0,1]上的随机数; floor(·)为实数到整数的映射。

Step2 设种群 SN个蜘蛛个体组成,N由两个子群的 FM 组成。随机初始化雌性蜘蛛(F=\{f_1,...,f_{N_f}\}) 和雄性蜘蛛,则(M = {m_1,m_2,...,m_{N_m}}),定义交配半径 r 由下式表示:
r = \frac{\sum_{j=1}^{n} (p_{jhigh} - p_{jlow})}{2n}\tag{3}
式中: p_{jhigh}p_{jlow}分别为第 j 个变量雌性蜘蛛上下限值。

Step3 计算每一个蜘蛛的重量 w_i :
w_i = \frac{J(s_i)-worst_s}{best_s - worst_s}\tag{4}
式中: J(s_i)是蜘蛛 i 所在位置对应的目标函数适应度值;
best_s = max_{k\in{1,2,...,N}}(J(sk))

worst_s =min_{k\in{1,2,...,N}}(J(sk))

Step4 根据协作机制按式(11) 移动雌性蜘蛛:
\begin{cases} f_i^{k+1} = f_i^k + \alpha \cdot Vibc \cdot(s_c-f_i^k) \beta\cdot Vibb_i \cdot(s_b-f_i^k) + \delta \cdot(rand-0.5),if \, r_m<PF\\ f_i^{k+1} = f_i^{k} - \alpha \cdot Vibc \cdot (s_c -f_i^k) - \beta \cdot Vibb_i \cdot (s_b - f_i^k)+ \delta \cdot (rand - 0.5) , else\ \end{cases} \tag{5}
式中: α、β 、δrand 均为[0,1]上的随机数; k 为当前迭代次数; s_c 、s_b 分别为最近个体 i 的较好重量和最佳重量;振动因子Vibc_i 、Bibb_i 分别由式(6)、式(7) 表示:
Vibc_i = w_c\cdot e^{-d_{i,c}^2} \tag{6}

Vibb_i = w_b\cdot e^{-d_{t,b}^2} \tag{7}

式中:w_c >w_i;w_b = max_{k\in {1,2,...,N}(w_k)};d_{i,j}=||s_i - s_j||

Step5 根据协作机制按式(8) 移动雄性蜘蛛:
\begin{cases} m_i^{k+1}=m_i^k + \alpha \cdot Vibf_i \cdot(s_f - m_i^k)+\delta \cdot (rand-0.5),if \, w_{N_{f+i}}>w_{N_{f+m}} \\ m_i^{k+1}=m_i^k + \alpha \cdot (\frac{\sum_{h=1}^{N_m}m_h^k \cdot w_{N_{f+h}}}{\sum_{h=1}^{N_m} w_{N_{f+h}}}-m_i^k),else\\ \end{cases} \tag{8}
式中: s_f 为最近雌蜘蛛个体重量;振动因子 Vibf_i可由式(9) 表示:
Vibf_i = w_f \cdot e^{-d_{i,f}^2} \tag{9}
式中: w_f 为常量。

Step6 在交配过程中,以每个个体重量定义交配概率,越重的蜘蛛个体具有获得繁育后代更大的概率。本文按轮盘赌法确定概率 ps_i :
ps_i = \frac{w_i}{\sum_{j\in Tg}w_j} \tag{10}
Step7 判断是否满足停止条件,若满足则算法结
束;否则,返回 step3。

2.算法结果

算法结果

3.参考文献

[1] Cuevas E,Cienfuegos M,Zaldívar D,et al. A swarm optimization algorithm inspired in the behavior of the social-spider[J].Expert Systems with Applications,2013,40(16):6374 -6384.

4.Matlab代码

https://mianbaoduo.com/o/bread/aJaclZ4=

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容