贪心法 , W5 @, a3 a. D4 {, q% I- Q( Q ( L i. z3 w! e; V! U8 W8 |1 N在枚举所有解时,当遇到的解在当前情况下是最优时,就认为它是最优解。如图一,当从A点到B点时,由于B点比A点的解更优,所以会认为B点是最优解。5 S O }0 _, Y) Y, I F
1 b: S6 y9 Q2 `0 r- s2 w1 \" W$ I显然这样的效率很高,但得到的最优解质量也很差。" g3 o M' ^4 Q8 ~& ~. ~
! p6 [- ~& Y3 R# R
爬山法% c/ G2 {- b; H: c# d4 y m
% k& C8 U2 {% W, l, I
贪心法是只和前面的一个比较,为了提高最优解的质量,可以不仅和前一个解比较,也和后一个解比较,如果比前面和后面的解都优,那么就认为它是最优解。如图一,当到C点时,发现它比前面的B和后面的D点的解都好,所以认为它是最优解。. s. f# x* W( [2 ~9 T3 z
: O! A0 e I. W( ?9 l
. s5 u' T, \, u" G5 e7 v* P
- v* j" e; q; E3 T- c模拟退火算法 ' c# Q, T8 ]. a6 ` 6 D& J9 D; f) m2 }1 Z# F1 G爬山算法实现很简单,其主要缺点是会陷入局部最优解,而不一定能搜索到全局最优解。& U/ J, v' u( e# A4 z7 j) `) L
* I8 p& Q) t3 u8 n4 X, O% E. Y# f
如图一,搜索到A点后就停止了搜索。如果能跳出局部最优解,那么得到的最优解的质量相对就会好很多。如当搜索到A点时以一定的概率跳转到另外一个地方。这样就有可能跳出局部最优解A。如果经过一定次数的跳跃,跳到了E点,那么就会找到全局的最优解了。. Q" g7 N( U; D/ ^1 z9 S
T% S3 z; A" }$ ~2 J1 s6 ^如果这个概率不变,那么就会一直跳跃下去,不会结束。可以让这个概率逐渐变小,到最后趋于稳定。这里的概率逐渐减小类似于金属冶炼的退火过程,所以称之为模拟退火算法。 % w. H: M2 o% `$ q, j5 q9 H - j- Z R" n% S, H% \$ | + Z7 i( i7 A# ^3 `5 f. N - u: w3 H( z, n' K0 Y模拟退火算法(Simulated Annealing,SA)最早由Kirkpatrick等应用于组合优化领域,它是基于Mente-Carlo迭代求解策略的一种随机寻优算法,其出发点是基于物理中固体物质的退火过程与一般组合优化问题之间的相似性。模拟退火算法从某一较高初温出发,伴随温度参数的不断下降,结合概率突跳特性在解空间中随机寻找目标函数的全局最优解,即在局部最优解能概率性地跳出并最终趋于全局最优。 & \% P* s6 s G* k" B& I, T ^3 d- R! c* |
模拟退火算法的关键在于控制温度(概率)降低快慢的参数r,这个参数范围是0<r<1。如果参数r过大,则搜索到全局最优解的可能会较高,但搜索的过程也就较长。若r过小,则搜索的过程会很快,但最终可能会达到一个局部最优值。 , N$ ~) \# [+ W R ) E* G9 ~! d! Y+ B1 Y模拟退火算法不能保证得到真正的最优解,但它能在效率不错的情况下得到质量较高的最优解。6 M+ i4 p1 D7 p4 {
8 E E6 E( A# Y' n# _
: h- G! m2 a- {: V0 @% g- a# ?: J- G1 ?6 W% b4 J
遗传算法; U' {2 [, [: Z7 k" F& P0 o
" ^% r9 h/ Z( i& Z* l
: R* D4 M2 b, X5 B0 e
% w* K c( h- a0 V W' r& I. m
遗传算法是计算数学中用于解决最优化的搜索算法,是进化算法的一种。进化算法最初是借鉴了进化生物学中的一些现象而发展起来的,生物在繁衍发展的过程,会通过繁殖,发生基因交叉,基因突变,适应度低的个体会被逐步淘汰,而适应度高的个体会越来越多。那么经过N代的自然选择后,保存下来的个体都是适应度很高的。 ! l+ ~/ K$ f3 e5 Y0 p$ ^, I& Z/ z9 D7 H9 Q
遗传算法初始是一个较差解的解集种群,通过遗传交叉繁殖出下一代的解集种群。在交叉的过程中,有一定的概率发生基因突变。在下一代的解集种群中,通过适者生存的自然选择,淘汰那些较差的解(个体),只让较好的解(个体)繁殖后代,这样产生出代表新的解集的种群。这个过程将导致种群像自然进化一样的后生代种群比前代更加适应于环境。经过许多代的繁殖和自然选择后,就能得到接近于真正最优解的解。 * m# w+ |( ]' M# E: N$ U ( d2 V i V5 p5 q4 h , D! M- N& R" |( d3 r
0 T6 Y) q' O2 S* c
可以用精英主义原则来对基本遗传算法进行优化。所谓精英主义原则,就是为了防止进化过程中产生的最优解被交叉和变异所破坏,可以将每一代中的最优解原封不动的复制到下一代中。: O# r: F K0 |" ]( w! O
) C' l$ X' w% G% l3 D5 i
F/ v: p% P* ^
' ^; l4 ]( {3 c& _( f
蚁群算法: K: Q* R, o* q$ v2 s
7 z0 u _( D1 k5 m# Q7 F蚁群算法(Ant Colony Optimization, ACO),又称蚂蚁算法,是一种用来在图中寻找优化路径的机率型算法。它由Marco Dorigo于1992年在他的博士论文中提出,其灵感来源于蚂蚁在寻找食物过程中发现路径的行为。8 r, }* ~- K6 f9 D2 o( W4 a
$ [, S5 K1 c2 a/ ]1 ?3 n, i8 m
蚂蚁在路径上前进时会根据前边走过的蚂蚁所留下的分泌物选择其要走的路径。其选择一条路径的概率与该路径上分泌物的强度成正比。因此,由大量蚂蚁组成的群体的集体行为实际上构成一种学习信息的正反馈现象:某一条路径走过的蚂蚁越多,后面的蚂蚁选择该路径的可能性就越大。蚂蚁的个体间通过这种信息的交流寻求通向食物的最短路径。" Q/ U# x6 x% t4 H. Z# L
?% t Q8 f! H% A" O2 l + o5 R8 ~7 M0 [ + c0 u8 }4 U% E& }蚁群算法就是根据这一特点,通过模仿蚂蚁的行为,从而实现寻优。当程序最开始找到目标的时候,路径几乎不可能是最优的,甚至可能是包含了无数错误的选择而极度冗长的。但是,程序可以通过蚂蚁寻找食物的时候的信息素原理,不断地去修正原来的路线,使整个路线越来越短,最终找到最佳路线。9 {; n8 c4 a) d
7 x3 A3 x4 Z- F4 {
7 X! d2 }) R: Q% L' p( o7 Z7 B" M
) Q& l( |8 t: |4 l( _ ^ ) A( S/ o J: p- Y/ x选择机制:信息素越多的路径,被选择的概率越大。 - z0 [. p6 U e- U- j; T/ |- S+ P f' T
更新机制:路径上面的信息素会随蚂蚁的经过而增长,而且同时也随时间的推移逐渐挥发消失。, h/ g8 a( O3 S. S% q
+ O0 }7 x5 [' Q$ Q4 H I# A! x( r( z. N+ k
4 d! O1 R q: i协调机制:蚂蚁间实际上是通过分泌物来互相通信、协同工作的。通过个体之间的信息交流与相互协作最终找到最优解,使它具有很强的发现较优解的能力。 ) Z; ] e6 \3 B* _7 G 9 U6 D: k6 V! p # ]- \, g) W. Q' d j
- d/ [- G. r7 O' c$ d出错机制:显然如果蚂蚁都往信息素多的地方移动,会导致局部最优解的问题。可是,总有些具有叛逆精神的蚂蚁,会不往信息素较多的地方移动,从而可以跳出局部最优解,找到全局的最优解。- L K; w+ Y! J N
% ?+ _( z& B4 v) R0 t, g, X+ {* P# M
# z3 ~5 B, f w