在线时间 43 小时 最后登录 2017-3-7 注册时间 2016-3-17 听众数 13 收听数 0 能力 0 分 体力 308 点 威望 0 点 阅读权限 30 积分 160 相册 0 日志 0 记录 0 帖子 131 主题 86 精华 0 分享 0 好友 21
升级 30%
TA的每日心情 怒 2016-4-25 17:12
签到天数: 22 天
[LV.4]偶尔看看III
自我介绍 萌萌哒
群组 : 2015国赛优秀论文解析
群组 : 2015年国赛优秀论文解
模拟退火算法心得 本文属于原创,make by 刘润佳,转载请注明出处。0 @+ r. c7 M {. K1 a% k$ M
7 V% }0 `; ]0 ^, @6 t/ o
文件http://www.cnblogs.com/growing/archive/2010/12/16/1908255.html
1 o0 M" v# Z) Y# K/ a5 Z0 E4 G: ? 由于在做一些Sat(可满足性问题)的事情,所以也尝试了多种方法来求解,其中模拟退火算法是一种不完全方法。首先看看模拟退火算法的思想:
0 T9 A/ V' v: }% ]1 G1 ^% P! A 一、模拟退火算法的起源' V; G$ F; s/ o3 z
1)它受益于物理退火过程
0 F* o$ ^ ~/ F$ T) A: U; ` 加温过程
! F- ?2 f# [: v4 r 等温过程
# V8 a% g2 Y* x; W7 _ 冷却(退火)过程
\9 A1 u( Y6 }0 j 2)等温下热平衡过程可用Monte Carlo方法模拟,计算量大。
3 l7 T3 M6 l2 ^8 v0 T; z 3)1953年,Metropolis提出重要性采样法,即以概率接受新状态,称Metropolis准则,计算量相对Monte Carlo方法显著减少。
) s2 P3 w% P9 u1 _9 u: H6 C; Z p 6 M2 g; o; X& Y# m6 n
4)1983年,Kirkpatrick等提出模拟退火算法,并将其应用于组合优化问题 的求解。
. T& U: A/ W& W4 e% q6 s 二、模拟退火的基本思想
/ o0 T0 [ Z7 K1 Q( A! s% k9 l 它可以分解为解空间、目标函数和初始解三部分。
5 H& `$ {$ R: r1 X/ U (1) 初始化:初始温度T(充分大),初始解状态S(是算法迭代的起点), 每个T值的迭代次数L (2) 对k=1,……,L做第(3)至第6步: (3) 产生新解S′ (4) 计算增量Δt′=C(S′)-C(S),其中C(S)为评价函数 (5) 若Δt′<0则接受S′作为新的当前解,否则以概率exp(-Δt′/T)接受S′作为新的当前解. (6) 如果满足终止条件则输出当前解作为最优解,结束程序。终止条件通常取为连续若干个新解都没有被接受时终止算法。 (7) T逐渐减少,且T->0,然后转第2步。% `: D/ |5 P/ K7 r. h- k
三、模拟退火算法的流程, I% t. u& P A' l1 n, n' Y
# L, U0 Z1 |! E+ C ^2 f
四、需注意因素( t) u. m3 n- Q1 w/ w- f) h. T
% g u' A% K$ N& E7 \ j+ J k9 o. |
4 a/ u# c! {3 A! P D, ?3 w6 f # I7 u; q: I, _. @ Z
% U$ G) g$ V( G7 X& n) I7 v
- A" }; p: W) {' E
% e1 j/ T( j4 H3 n : Z" T3 J2 P: q$ ?' Q( d$ k# G5 p
! l% v- o, Q+ R- K: ?3 Q4 D
6 m8 o7 d% r; U2 n- ? ^( N 五、本人的心得- {) b8 h, c# @1 [8 t+ E! _
在使用模拟退火算法求解Sat问题时,遇到了几个问题,觉得有必要提出来探讨一下,这也是模拟退火算法需要注意的地方:1 d# K0 X, `/ W9 X. `
1)温度的设定及其变化函数;
: H: e/ s; G3 r5 C* Q 2)在每个温度值下,进行尝试的次数;
* N# F) i. W& W* h/ q 3)评估函数选取问题。6 P* M0 A8 {" n' {+ m* ?' R; \
这三个问题我觉得需要经过不断的实验得出一个最优值,目前本人的研究及实验都很有限,得出这几个结论未必正确,如果有新的建议可以提出,谢谢。同时,由于本人目前还没有找到自认为比较合理的解决方案,所以具体算法及所列三个问题将在后期发布,有兴趣者可以留意。
, s- X, V* D$ n7 n ( G8 s6 j( @8 a7 s& V4 x. Q
$ p9 o: Z$ ]" \* Z0 {% w+ }
4 `1 d/ y& n) V6 J3 c$ @. U
/ [" {2 j- u. [& _8 n) G
% }/ v Z: {* `9 @& n
( s8 Q* J7 t3 f1 U; l; T
zan