数学建模社区-数学中国

标题: 智能优化算法:麻雀搜索算法-附代码 [打印本页]

作者: 杨利霞    时间: 2021-8-6 16:56
标题: 智能优化算法:麻雀搜索算法-附代码
# y8 D6 `8 I6 q
智能优化算法:麻雀搜索算法-附代码/ a, \9 x* f' X& _
2020智能优化算法:麻雀搜索算法1 S% s" j/ v# U5 f/ N
文章目录! Q/ k. H- q: a0 T  v/ V
2020智能优化算法:麻雀搜索算法
; V1 _  n$ K4 y5 {6 f, a4 Z% k" N1.算法原理
5 o5 F, [9 S: C& j) g2.算法结果
4 k, B9 p* Q/ U3 l, K3.参考文献
+ R7 [' ~5 W" m, X$ O4.Matlab代码
9 B. I0 O% I  u5.Python代码
1 |+ @, o! E+ Y3 V( B/ w' O8 D: S: I' T0 E6 V" M3 y
7 U. W0 D6 k/ H6 _
摘要:麻雀搜索算法(Sparrow Search Algorithm, SSA)是于2020年提出的。SSA 主要是受麻雀的觅食行为和反捕食行为的启发而提出的。该算法比较新颖,具有寻优能力强,收敛速度快的优点3 D3 n+ k' N( H; t) k
1.算法原理! k! P& Z6 r! [3 T" S# \. m
建立麻雀搜索算法的数学模型,主要规则如下所述:) t3 }* N6 \, v/ `, _6 l

' u2 l( Q( r7 Z- @1 g

3 V. D6 g( D4 ~7 i" `, x发现者通常拥有较高的能源储备并且在整个种群中负责搜索到具有丰富食物的区域,为所有的加入者提供觅食的区域和方向。在模型建立中能量储备的高低取决于麻雀个体所对应的适应度值(Fitness Value)的好坏。3 R9 v. ^$ y9 k& P
一旦麻雀发现了捕食者,个体开始发出鸣叫作为报警信号。当报警值大于安全值时,发现者会将加入者带到其它安全区域进行觅食。  ^2 j) q# r" \/ i6 s6 P: T
发现者和加入者的身份是动态变化的。只要能够寻找到更好的食物来源,每只麻雀都可以成为发现者,但是发现者和加入者所占整个种群数量的比重是不变的。也就是说,有一只麻雀变成发现者必然有另一只麻雀变成加入者。, s' ]+ y9 S5 z! ^2 t, @
加入者的能量越低,它们在整个种群中所处的觅食位置就越差。一些饥肠辘辘的加入者更有可能飞往其它地方觅食,以获得更多的能量。
/ U& B+ J' l8 U2 d7 u' t在觅食过程中,加入者总是能够搜索到提供最好食物的发现者,然后从最好的食物中获取食物或者在该发现者周围觅食。与此同时,一些加入者为了增加自己的捕食率可能会不断地监控发现者进而去争夺食物资源。
* u' C8 Y  O) {) P当意识到危险时,群体边缘的麻雀会迅速向安全区域移动,以获得更好的位置,位于种群中间的麻雀则会随机走动,以靠近其它麻雀。" e, L1 _/ H3 _* m  s6 ]
在模拟实验中,我们需要使用虚拟麻雀进行食物的寻找,由n只麻雀组成的种群可表示为如下形式:9 F8 y2 z8 ]* D' P; M! z
! ?# b; R0 ]  c6 W
2.png ​       
. O5 z( }, y- d  M9 F. \ (1)
. L! I6 |1 J, @; L$ @, i) T
  Q: f% c4 s$ i( r9 ?

! W' `1 X9 P2 z其中,d dd 表示待优化问题变量的维数,n nn 则是麻雀的数量。那么,所有麻雀的适应度值可以表示为如下形式:& A( C' E' T( L$ g1 R
​        3.png 3 u, z. p" s/ \7 e9 F0 b2 [
(2)
# L9 ?* X  V& n5 A0 J3 h+ K' |0 x& [$ q. U9 G1 S" M$ p) }  M3 g5 r

, c( K$ t( l6 G9 Z7 E3 _其中,f 表示适应度值。
) L- A* m& {" a- b4 j* U
( c9 m- M8 J' W1 ]! ~* S+ \0 T6 m& t

0 A, t( |9 z3 U2 Z& ~% A在 SSA 中,具有较好适应度值的发现者在搜索过程中会优先获取食物。此外,因为发现者负责为整个麻雀种群寻找食物并为所有加入者提供觅食的方向。因此,发现者可以获得比加入者更大的觅食搜索范围。根据规则(1)和规则(2),在每次迭代的过程中,发现者的位置更新描述如下:+ b7 s4 u( c6 ~0 t1 _
(3) 4.png / F. V0 B- z, P/ h$ p; Q

2 c3 {0 K/ ~/ }
* x* Z& k: X6 m5 T
其中,t tt 代表当前迭代数,j = 1 , 2 , 3 , . . . , d j =1, 2, 3, . . . , dj=1,2,3,...,d。i t e m m a x item_{max}item
, v& r( D+ V2 k/ d! mmax; @% _3 }6 A5 F6 h' f. d9 D+ X- I9 q+ V
​        ' J! v$ H, K3 _; j0 c$ u

4 U" _  w0 x6 o是一个常数,表示最大的迭代次数。X i j X_{ij}X . t4 P5 k$ b$ G5 {" G9 F
ij
  `% O( H/ y8 N! w7 T, c​       
$ p  L1 B6 _" K  S 表示第 i ii 个麻雀在第j jj 维中的位置信息。α ∈ ( 0 , 1 ] α∈(0, 1]α∈(0,1]是一个随机数。R 2 ( R 2 ∈ [ 0 , 1 ] ) R_2(R_2∈[0,1])R 6 U5 M0 Z  u& ?- W& m7 W
20 \2 k4 s( L6 k. g* w; q. D
​       
3 Q0 r# d6 u- J+ V0 ~# g (R
( Q# Y1 v4 D- |  ~" `2
+ G! q: t0 O9 Y8 p& |​       
% g! O7 }# b+ j. p+ o ∈[0,1])和 S T ( S T ∈ [ 0.5 , 1 ] ) ST(ST∈[0.5,1])ST(ST∈[0.5,1])分别表示预警值和安全值。Q QQ 是服从正态分布的随机数。L LL 表示一个 1 × d 1×d1×d 的矩阵,其中该矩阵内每个元素全部为 1。
: ^9 ?0 E5 U9 b1 f( Z! ~7 n( m8 m" p; [$ f7 r6 b
# n/ Z- z0 ~- x) h8 J
当 R 2 < S T R2< STR2<ST 时,这意味着此时的觅食环境周围没有捕食者,发现者可以执行广泛的搜索操作。如果 R 2 ≥ S T R2≥ STR2≥ST,这表示种群中的一些麻雀已经发现了捕食者,并向种群中其它麻雀发出了警报,此时所有麻雀都需要迅速飞到其它安全的地方进行觅食。6 R  U2 f- u  x/ ?* ~- C4 ]
6 a7 R8 v: r. c* Z2 {0 U  i
8 f4 a4 B2 I1 p% g2 T6 k5 K! ]0 S! o- `
对于加入者,它们需要执行规则(3)和规则(4)。如前面所描述,在觅食过程中,一些加入者会时刻监视着发现者。一旦它们察觉到发现者已经找到了更好的食物,它们会立即离开现在的位置去争夺食物。如果它们赢了,它们可以立即获得该发现者的食物,否则需要继续执行规则(4)。加入者的位置更新描述如下:
$ h& \! }# A6 a. j3 g! n) o: q: K 5.png 6 `, H; K/ V: A
​       
) B# a$ q3 ?) v! i) v, ]" J 则表示当前全局最差的位置。A AA表示一个 1 × d 1×d1×d 的矩阵,其中每个元素随机赋值为 1 或-1,并且 A + = A T ( A A T ) − 1 A^+=A^T(AA^T)^{-1}A 2 T& M; O/ D9 b% P
+
% I2 \% V8 [0 V3 L6 d' N =A
, ~0 D+ Y* ^9 U# ~4 h/ u) LT
/ J* R( [/ b' }3 ~( t( B2 m. ? (AA
( }! F% R3 O+ Z  m, _T, \! v) k, z: `& C; V
) # n% S5 v6 Y0 h  M) o
−1- _' ~: L- K4 f/ I8 C9 A# x2 a  m
。当i >n/2 时,这表明,适应度值较低的第 i 个加入者没有获得食物,处于十分饥饿的状态,此时需要飞往其它地方觅食,以获得更多的能量。
# o% p5 r4 |/ B6 n9 m
3 Z, g. [- W7 j

3 {+ U4 i6 I$ e* [% o6 X在模拟实验中,我们假设这些意识到危险的麻雀占总数量的 10% 到 20%。这些麻雀的初始位置是在种群中随机产生的。根据规则(5),其数学表达式可以表示为如下形式:. Y1 `4 S$ w7 R1 K# w% u! S
6.png
/ J, k- u- x6 R" u" ^3 j$ ]& o' B# i (5)' ]* R0 |/ s) W5 _9 q( o  S
- [, P# @' E6 O8 `
' Q8 F3 T, S, x  n& w1 _: \
其中,其中 X b e s t X_{best}X
. L- P7 h) _& _# d4 Sbest
4 p7 s, R  P6 H. P​       
- S- g4 y  a" G' R* h! k  x5 t( f 是当前的全局最优位置。β ββ 作为步长控制参数,是服从均值为 0,方差为 1 的正态分布的随机数。K ∈ [ − 1 , 1 ] K∈[-1,1]K∈[−1,1]是一个随机数,fi则是当前麻雀个体的适应度值。f g f_gf
6 b5 U# Z# N4 u: h) |1 {2 kg* _2 Y9 f( @- U
​        " V3 m+ n: }' z; ]$ N  q+ l
和 f w f_wf   n" Q; S: F5 O8 e. _) I7 D
w, I/ y) w9 P3 ^& V. W. u
​       
; u( s" F3 _) F: G 分别是当前全局最佳和最差的适应度值。ε \varepsilonε 的常数,以避免分母出现零。, M3 R; u" G) M( F* A8 X& C

# G' k, s& _% b, V0 Y. j0 `% @
0 a$ T$ P' z4 a& J& P
为简单起见,当 f i > f g f_i >f_gf / l) n" S8 j/ R
i
/ J! I- ]5 k6 l& o9 M+ r​        * U0 n8 ^5 @. i1 t+ Z& Y
>f ; B% z8 j: }* P3 t0 e
g
. T/ X; }* a1 a8 I! K$ U​        ) Z/ e8 h$ d3 q( A* C
表示此时的麻雀正处于种群的边缘,极其容易受到捕食者的攻击。X b e s t X_{best}X , F2 a3 Z5 c7 S2 _- s1 e
best
4 x+ [, y/ s, ~6 V​       
& ^% P6 N  Z) ^& f 表示这个位置的麻雀是种群中最好的位置也是十分安全的。f i = f g f_i = f_gf
$ I7 Z3 S* @2 b# n6 C# D9 d# `% a1 I% `i* z# y1 x  V4 F* k  b  q* i
​       
3 P) i, ?8 C6 a7 {2 M0 g0 R =f . }4 W+ t5 ^0 c: R
g8 P* _; S2 J! J5 q! s
​        + H8 i6 l- m# V# r! u9 G
时,这表明处于种群中间的麻雀意识到了危险,需要靠近其它的麻雀以此尽量减少它们被捕食的风险。K KK 表示麻雀移动的方向同时也是步长控制参数。% c2 m1 J1 G# M# r' q1 a
  ]$ G& W# t+ X- T6 z
" q- x( m6 P' I* ]* M  a% W; o
算法流程) j5 j1 z3 F  {8 I, [
, \3 p; ?! a; l! V& g4 i2 {% X$ v+ w1 E6 _
' s" J& P: G1 i0 b4 q6 s& F) N: E
Step1: 初始化种群,迭代次数,初始化捕食者和加入者比列。# Y8 [7 f2 o) ~
" R( ]' N$ U0 F, ^

% h& b+ ^% [5 |4 ~Step2:计算适应度值,并排序。; ?7 m# J3 M  x. l# b

5 u; [1 ]9 g/ N* @1 ?1 k9 |( E

/ F6 [. }$ }3 ^" n% y4 z8 H9 P: BStep3:利用式(3)更新捕食者位置。+ ~8 y  {3 x7 b8 {/ t

. B" E! R0 V6 n$ q7 N
6 H# \4 y$ j* [$ X- u0 `5 q
Step4:利用式(4)更新加入者位置。
" h# O* P* _( u4 Q4 C
& ]( [  ]; f9 y) S. U' i" ~* y  Z3 g
( V3 F: o# q+ \7 B: G( J( a  a
Step5:利用式(5)更新警戒者位置。
. w# c# [8 v' i' l7 b) `) u4 Q1 T+ z9 }( P2 s
/ V& O8 _* x1 p- h3 E- k
Step6:计算适应度值并更新麻雀位置。
" ^2 p( |* \5 I0 [1 _; m6 g# m( ~
. Y9 N  t' g$ P. b7 g4 y
) G# F, z/ B$ }8 g5 Z! E1 B5 f) d
Step7:是否满足停止条件,满足则退出,输出结果,否则,重复执行Step2-6;2 B% ]0 ]% d2 @2 A1 d
0 N# s" ?# M$ w  e" s0 w3 J
& \, H4 b3 u/ M# R1 l" O0 L, p& _
2.算法结果
+ Y7 S0 K1 \0 N! R* L% O) `  a; H 1.png
3 t/ c( [: W4 w" N# Z
3 c3 F  Y. c: P. ^5 S6 z" ?
1 y9 U/ h9 C" i) L; s" V
3.参考文献
/ Q3 B$ v; A4 b7 M[1] Xue J , Shen B . A novel swarm intelligence optimization approach: sparrow search algorithm[J]. Systems ence & Control Engineering An Open Access Journal, 2020, 8(1):22-34.9 \4 Z+ V, B/ V( T) o% y

% ]9 a4 `& H* N- A! M
6 c7 {: V" \9 y" V5 C- e- ]
4.Matlab代码
- E. T2 f6 S9 F* ]$ i麻雀搜索算法; h  a$ s0 }8 e; T
改进算法:
: D; x/ z. U( ]2 Q1.基于反向策略的麻雀搜索算法
5 V5 J9 |, O- s/ Y6 q) F* V8 Y* t4 D2.基于Tent混沌映射的麻雀搜索算法
% z) }4 Q! _( n3.基于Logistic混沌映射的麻雀搜索算法, j; t$ X+ i. i, L7 J$ p
4.基于Circle混沌映射的麻雀搜索算法
. E' E) Q' c' K0 u" N2 y1 k5.基于Piecewise混沌映射的麻雀搜索算法
/ T- {( v$ E( ^3 E" ]4 t6.基于Chebyshev混沌映射的麻雀搜索算法
% F  n# O; Q6 u2 @( C" Y+ h* s4 N0 b" [7.基于Sine混沌映射的麻雀搜索算法" m9 t& y1 d; g) a' h# s
8.基于Singer混沌映射的麻雀搜索算法
/ E. O  p) S; }9 M# v, A9.基于迭代混沌映射的麻雀搜索算法. l$ i% u4 P9 a8 ^
10.基于Sinusoidal混沌映射的麻雀搜索算法
- D1 |2 \7 }* D9 U11.基于随机游走改进的麻雀搜索算法
+ c' n: J& s* D9 L% F12.基于萤火虫改进的麻雀搜索算法  m9 i6 t- i0 E7 e/ [
13.基于精英反向策略的麻雀搜索算法1
8 j+ D% @/ b* e+ c* J- a& f8 E14.基于levy飞行改进的麻雀搜索算法- P# }$ ?' ?( a* p
15.基于自适应t分布的麻雀算法$ T: R/ K8 l9 y& s
改进麻雀文献复现代码:
- ^' q/ f4 I+ }% p7 F( R1.混沌麻雀。
& Q( {/ d+ C3 t8 e  O' @参考文献:[1]吕鑫,慕晓冬,张钧,王震.混沌麻雀搜索优化算法[J/OL].北京航空航天大学学报:1-10[2020-11-16].https://doi.org/10.13700/j.bh.1001-5965.2020.0298.
/ q$ K; B) ]' [: D$ l
& a1 h5 q3 p4 h9 x9 M4 H
3 b6 {$ D8 J+ {
2.融合柯西变异和反向学习的改进麻雀算法
' e' B( ^( z0 S* {[1]毛清华,张强.融合柯西变异和反向学习的改进麻雀算法[J/OL].计算机科学与探索:1-12[2020-12-16].http://kns.cnki.net/kcms/detail/11.5602.tp.20201203.1601.006.html.
: J2 o8 q) [5 ?* T& T. I: Q% v3 C
: ?3 W- l# C  p7 F% r
[3. 混合正弦余弦算法和Lévy飞行的麻雀算法(ISSA)]
0 `! w5 v+ s6 S1 ][1]毛清华,张强,毛承成,柏嘉旋.混合正弦余弦算法和Lévy飞行的麻雀算法[J/OL].山西大学学报(自然科学版):1-6[2021-04-09].https://doi.org/10.13451/j.sxu.ns.2020135.) _6 K- x; {" P/ z' d9 B8 I

0 V1 ?( r" l6 w: I

/ j: q% i! h2 O  S0 k[4.基于 Sobol 序列和纵横交叉策略的麻雀搜索算法(SSASC)]
, `* Y6 Y! o) z* v2 N" ]9 m[1]段玉先,刘昌云.基于 Sobol 序列和纵横交叉策略的麻雀搜索算法[J/OL].计算机应用. https://kns.cnki.net/kcms/detail/51.1307.TP.20210525.1453.002.html
4 [5 Y: N7 @. S- W! E$ K" r4 Z/ o1 ^( g. D+ q' b
- R) e$ r0 p3 W: Q$ l" X$ C
5.Python代码
/ p! L0 l4 L  X* `麻雀搜索算法4 U3 I$ u/ ^. v. X+ g9 A% X
改进算法:9 H! I' B, O& E) c
基于Sinusoidal混沌映射的麻雀搜索算法 python 代码
, \9 l6 ~) R! u: G) a# Y基于迭代混沌映射的麻雀搜索算法 python 代码
3 e$ o; t# b1 M8 A6 n4 \5 c3 L基于Singer混沌映射的麻雀搜索算法 python 代码
! Y0 B+ s; Y+ O# h基于Sine混沌映射的麻雀搜索算法 python代码
! U* J7 G3 W: Y: E基于Piecewise混沌映射的麻雀搜索算法 python代码3 c  M# R+ n1 D  D  [/ |
基于Logistic混沌映射的麻雀搜索算法 python 代码
8 \9 }+ I) R$ c( F/ ?基于Circle混沌映射的麻雀搜索算法 python 代码- R: v7 ]2 S8 R, i, z4 _* F- |
基于Chebyshev混沌映射的麻雀搜索算法 python代码) a$ C! W# I9 Z. s( s
基于Tent混沌映射的麻雀搜索算法 python代码3 X) H# F7 D2 R
基于反向策略的麻雀搜索算法 python代码
+ t& t! Y; ?& }7 J# M% L基于精英反向策略的麻雀搜索算法1 python代码
; e6 l" U2 \+ }; t基于精英反向策略的麻雀搜索算法2 python 代码
# t: y2 G, p" n/ b基于萤火虫改进的麻雀搜索算法 python代码
) @' P( W! l' D2 {7 O基于levy飞行改进的麻雀搜索算法 python 代码
) X0 @4 ]" V0 e2 }" i基于随机游走改进的麻雀搜索算法5 A3 @: m8 N8 o( _% k) D
基于自适应t分布的麻雀搜索算法
* q  y7 R0 T; [$ |) M改进麻雀文献复现代码:& j. x$ v" b! i
1.混沌麻雀: O* Q8 n; l' }# a& Y1 q  y
参考文献:[1]吕鑫,慕晓冬,张钧,王震.混沌麻雀搜索优化算法[J/OL].北京航空航天大学学报:1-10[2020-11-16].https://doi.org/10.13700/j.bh.1001-5965.2020.0298.7 f! X( n3 \- o' z

! ]- q2 e: @! h2 S' F

& T* P. l: ?* U: v2.混合正弦余弦算法和Lévy飞行的麻雀算法(ISSA)8 _& b$ m/ K9 T% s0 W$ u* ~: c& N
[1]毛清华,张强,毛承成,柏嘉旋.混合正弦余弦算法和Lévy飞行的麻雀算法[J/OL].山西大学学报(自然科学版):1-6[2021-04-09].https://doi.org/10.13451/j.sxu.ns.2020135.2 }' Q9 ~+ K% ]# d
————————————————
* X" i& q  l" ^版权声明:本文为CSDN博主「Jack旭」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
$ y' M: K& ~  I( O原文链接:https://blog.csdn.net/u011835903/article/details/108830958
3 D  f/ s0 M: \1 {6 g
$ w; c- ]9 t1 \1 b9 I. r) Q; W* A& }9 z; }/ X

作者: 1051373629    时间: 2021-8-17 17:13
谢谢!
, D' V7 h) {  t+ }




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5