- 在线时间
- 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 刘润佳,转载请注明出处。, g, Y; l% @5 @, n; l. ]
# c2 M/ U6 z* N
文件http://www.cnblogs.com/growing/archive/2010/12/16/1908255.html
# E d* E, h T. B D! V2 }由于在做一些Sat(可满足性问题)的事情,所以也尝试了多种方法来求解,其中模拟退火算法是一种不完全方法。首先看看模拟退火算法的思想:
- {+ r- z5 t# U6 j6 O一、模拟退火算法的起源
F+ d1 e% `; W, ]1)它受益于物理退火过程
$ S$ K- ^; K) E( M7 v: T* C' B; _, e 加温过程
" [* w" C+ p7 o+ A C; i 等温过程' D1 h2 g) U |4 _; X% d; P
冷却(退火)过程6 k4 x5 O8 a1 E5 H: b3 d
2)等温下热平衡过程可用Monte Carlo方法模拟,计算量大。
. ~. P# D/ n8 L' \ F3)1953年,Metropolis提出重要性采样法,即以概率接受新状态,称Metropolis准则,计算量相对Monte Carlo方法显著减少。# [! D z) N6 {& P$ B9 e% x- D
5 a! F L; Q5 I
4)1983年,Kirkpatrick等提出模拟退火算法,并将其应用于组合优化问题的求解。0 n# W, h% Y! I, n, O
二、模拟退火的基本思想1 T( D" q2 C) ? \
它可以分解为解空间、目标函数和初始解三部分。 6 V0 D3 ?7 m( H
- (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步。
2 P4 Q$ D% R6 i( Y' s1 F1 `7 V 三、模拟退火算法的流程
% H6 X, w6 ^7 R! n9 G2 B ( ]; q' @! h$ `" b8 S5 g# s& W
四、需注意因素
! j- D' R, i/ N5 X% W ) j2 y- S' U1 d, E# l8 V7 m' H) G3 `
8 y# r3 G( p" c
# O/ D: R, h$ u: j
}: m, M5 R; `) E2 _ _& F
6 P: b% S" H* A# ~" C! X, j9 u1 @0 s4 Z( ~
![]()
& F' K( G# K" m2 f![]()
& _4 C# Q3 _" o1 f5 D7 ` ; R. ?) T: u+ z. j+ u, s1 x
五、本人的心得
' f) X6 q% \! e9 E( Z% z 在使用模拟退火算法求解Sat问题时,遇到了几个问题,觉得有必要提出来探讨一下,这也是模拟退火算法需要注意的地方:& n0 i6 i6 A0 f# R
1)温度的设定及其变化函数;
' D {( `+ y S5 h0 X" m 2)在每个温度值下,进行尝试的次数;/ {. C, k5 P9 Z2 G! R/ \0 J [
3)评估函数选取问题。
: R* a! n4 ?; H1 X; S3 e 这三个问题我觉得需要经过不断的实验得出一个最优值,目前本人的研究及实验都很有限,得出这几个结论未必正确,如果有新的建议可以提出,谢谢。同时,由于本人目前还没有找到自认为比较合理的解决方案,所以具体算法及所列三个问题将在后期发布,有兴趣者可以留意。/ F/ j, ~& F( j: w- {
6 n0 V6 O8 }1 C5 e
/ c2 b2 q( u0 p' k
; [7 g5 G }* V2 Q: |% ^
/ q7 a; i- X9 |( s8 s, j1 E3 N1 |4 V/ c$ \8 R4 n. p3 B
% Y! H; p" O+ g% o+ f. T
|
zan
|