数学建模社区-数学中国

标题: 关于蒙特卡洛方法 [打印本页]

作者: wqjxyf    时间: 2009-7-10 00:14
标题: 关于蒙特卡洛方法
什麽是蒙特卡洛方法
作者: ychexingwuji    时间: 2009-7-10 07:13
我也不懂 你去百度搜一下有很多结果
作者: loveyoddo    时间: 2009-7-10 14:10
(参考百度:http://baike.baidu.com/view/7775.htm)0 w, W* {9 G- t; j, H& P8 X1 b( _& V
蒙特卡罗(Monte Carlo)方法,或称计算机随机模拟方法,是一种基于“随机数”的计算方法。这一方法源于美国在第二次世界大战中研制原子弹的“曼哈顿计划”。该计划的主持人之一、数学家冯·诺伊曼用驰名世界的赌城—摩纳哥的Monte Carlo—来命名这种方法,为它蒙上了一层神秘色彩
作者: ykl126    时间: 2009-7-11 16:56
有见解啊,楼上的。
作者: duguyixiaono1    时间: 2009-7-18 22:13
三个月前听说这个算法~~~~
作者: xieyu1232001    时间: 2009-7-18 22:37
基本思想- V( V5 x- K7 m- R1 w
* R  _& m, I9 R8 b# }: b
  & O+ z# w) B; D- R) t( E4 A
  当所求解问题是某种随机事件出现的概率,或者是某个随机变量的期望值时,通过某种“实验”的方法,以这种事件出现的频率估计这一随机事件的概率,或者得到这个随机变量的某些数字特征,并将其作为问题的解。 有一个例子可以使你比较直观地了解蒙特卡罗方法:假设我们要计算一个不规则图形的面积,那么图形的不规则程度和分析性计算(比如,积分)的复杂程度是成正比的。蒙特卡罗方法是怎么计算的呢?假想你有一袋豆子,把豆子均匀地朝这个图形上撒,然后数这个图形之中有多少颗豆子,这个豆子的数目就是图形的面积。当你的豆子越小,撒的越多的时候,结果就越精确。在这里我们要假定豆子都在一个平面上,相互之间没有重叠。
6 D) |7 B' |9 [9 E' E    g& T' }2 D& K* {9 l  c
工作过程" }4 ^" W2 ]( w9 L
0 O4 z! B/ M+ M# a6 l* h
  * T6 L; u! V: ~9 j6 P
  在解决实际问题的时候应用蒙特卡罗方法主要有两部分工作:
) l( d) l7 z- }3 {1 U  用蒙特卡罗方法模拟某一过程时,需要产生各种概率分布的随机变量。 8 C3 l. s" [6 V9 j/ x( x# n
  用统计方法把模型的数字特征估计出来,从而得到实际问题的数值解。 ) N3 K$ J# o6 n1 h" f4 c
  
2 a1 ?6 S0 c1 ^# g: l3 t" j+ u1 J计算步骤$ A$ x/ i) r2 z# L1 B" d: R# r

  y# W' R5 P* i( O1 [' H9 Y  ) y& f  z/ g5 `1 m( k/ @
  使用蒙特卡罗方法进行分子模拟计算是按照以下步骤进行的:
$ z, q1 v) N' ]) f% F  ① 使用随机数发生器产生一个随机的分子构型。 7 h0 s5 H- a( t1 m8 E* Y
  ②对此分子构型的其中粒子坐标做无规则的改变,产生一个新的分子构型。
/ M# n! _5 H" j; G3 G) W  ③计算新的分子构型的能量。 ) ^% W3 r3 m6 Q6 ^1 A, w; J" }% z& L
  ④比较新的分子构型于改变前的分子构型的能量变化,判断是否接受该构型。 - ^3 A/ Y5 v+ y4 C! h
  若新的分子构型能量低于原分子构型的能量,则接受新的构型,使用这个构型重复再做下一次迭代。 : ^! L* k* ]* `: I' P% p* ]
  若新的分子构型能量高于原分子构型的能量,则计算玻尔兹曼常数,同时产生一个随机数。 , D6 B: p; a% g4 g
  若这个随机数大于所计算出的玻尔兹曼因子,则放弃这个构型,重新计算。 ! U7 @: e) |" i/ Y( G
  若这个随机数小于所计算出的玻尔兹曼因子,则接受这个构型,使用这个构型重复再做下一次迭代。 # f: e0 a! V- G! w4 A- a+ w* x" k
  ⑤如此进行迭代计算,直至最后搜索出低于所给能量条件的分子构型结束。0 a$ e! u) B! O( f
  
2 [% O: H& X2 K* c* I8 q4 j) W3 X在数学中的应用
* X/ X1 ~: L6 \; v3 G# k- ?+ W) f2 a7 j
  通常蒙特·卡罗方法通过构造符合一定规则的随机数来解决数学上的各种问题。对于那些由于计算过于复杂而难以得到解析解或者根本没有解析解的问题,蒙特·卡罗方法是一种有效的求出数值解的方法。一般蒙特·卡罗方法在数学中最常见的应用就是蒙特·卡罗积分。5 @2 J# R" ?$ |+ z# r3 J
  积分/ F) k/ y# A/ t" ~8 i$ F: [' f' A( M
  非权重蒙特卡罗积分,也称确定性抽样,是对被积函数变量区间进行随机均匀抽样,然后对被抽样点的函数值求平均,从而可以得到函数积分的近似值。此种方法的正确性是基于概率论的中心极限定理。当抽样点数为m时,使用此种方法所得近似解的统计误差恒为,不随积分维数的改变而改变。因此当积分维度较高时,蒙特卡罗方法相对于其他数值解法更优。
作者: xieyu1232001    时间: 2009-7-18 22:37
基本思想
+ ^4 L* f1 U- ]/ O" W
, t# B% p2 c" T/ {3 y2 V  
" R6 v/ Z+ K, Y! Y! h  当所求解问题是某种随机事件出现的概率,或者是某个随机变量的期望值时,通过某种“实验”的方法,以这种事件出现的频率估计这一随机事件的概率,或者得到这个随机变量的某些数字特征,并将其作为问题的解。 有一个例子可以使你比较直观地了解蒙特卡罗方法:假设我们要计算一个不规则图形的面积,那么图形的不规则程度和分析性计算(比如,积分)的复杂程度是成正比的。蒙特卡罗方法是怎么计算的呢?假想你有一袋豆子,把豆子均匀地朝这个图形上撒,然后数这个图形之中有多少颗豆子,这个豆子的数目就是图形的面积。当你的豆子越小,撒的越多的时候,结果就越精确。在这里我们要假定豆子都在一个平面上,相互之间没有重叠。$ |9 P& ?8 {3 m" c  B' L( s9 t
  9 G! Z. B+ Z4 |( i. C8 w% ~) N# Z
工作过程
5 p/ w4 W, R) F
4 Q5 h. \1 L% x7 W  
! \, O& M; s+ Z; U  在解决实际问题的时候应用蒙特卡罗方法主要有两部分工作:
* G1 v* B% k$ K4 s* Z% O  B# H- f8 P  用蒙特卡罗方法模拟某一过程时,需要产生各种概率分布的随机变量。 7 Q- F/ B* X2 E$ s& i, I
  用统计方法把模型的数字特征估计出来,从而得到实际问题的数值解。
8 B+ A5 W0 ~4 D6 T# R6 V/ R7 A  , t6 P( c3 `$ W" a
计算步骤
- Q5 v! x# |6 Q! }  o3 w" d) D( C5 z3 n" ^: P5 i0 E
  
1 h- W( W' Q# [0 W$ f4 |0 \8 L  使用蒙特卡罗方法进行分子模拟计算是按照以下步骤进行的:
# S0 }$ j$ Q8 Z$ W6 }, L7 f1 e  ① 使用随机数发生器产生一个随机的分子构型。 . O  W7 q+ B$ z2 y$ c- x  F
  ②对此分子构型的其中粒子坐标做无规则的改变,产生一个新的分子构型。
3 a8 N/ ?6 C% H$ E  w* W3 C% `  ③计算新的分子构型的能量。 9 u! F& q$ l9 L2 l
  ④比较新的分子构型于改变前的分子构型的能量变化,判断是否接受该构型。
# z3 o- w/ }  E8 g0 q& l- d& u  若新的分子构型能量低于原分子构型的能量,则接受新的构型,使用这个构型重复再做下一次迭代。
2 m) R: F; U6 F0 T2 }- P( V  若新的分子构型能量高于原分子构型的能量,则计算玻尔兹曼常数,同时产生一个随机数。
1 o8 K1 H3 p8 _4 H" o6 ], M  若这个随机数大于所计算出的玻尔兹曼因子,则放弃这个构型,重新计算。
) X0 V9 y$ z* S4 \' o  若这个随机数小于所计算出的玻尔兹曼因子,则接受这个构型,使用这个构型重复再做下一次迭代。
. {5 R/ P6 f! h# T- C! `2 u  ⑤如此进行迭代计算,直至最后搜索出低于所给能量条件的分子构型结束。! P" i6 O; r8 u9 F4 B+ \/ K
  4 \5 I; H% ?- D7 |! `! V+ v
在数学中的应用1 j8 ~8 j9 i! h5 q+ _; |3 A8 ]

  P2 o2 {, ~9 E- q, z  通常蒙特·卡罗方法通过构造符合一定规则的随机数来解决数学上的各种问题。对于那些由于计算过于复杂而难以得到解析解或者根本没有解析解的问题,蒙特·卡罗方法是一种有效的求出数值解的方法。一般蒙特·卡罗方法在数学中最常见的应用就是蒙特·卡罗积分。
, A1 }$ z9 n2 G3 c  积分
0 W" _- u6 v: T4 @7 [/ ~3 F  非权重蒙特卡罗积分,也称确定性抽样,是对被积函数变量区间进行随机均匀抽样,然后对被抽样点的函数值求平均,从而可以得到函数积分的近似值。此种方法的正确性是基于概率论的中心极限定理。当抽样点数为m时,使用此种方法所得近似解的统计误差恒为,不随积分维数的改变而改变。因此当积分维度较高时,蒙特卡罗方法相对于其他数值解法更优。
作者: gsj5201314    时间: 2009-7-19 15:12
学习了!
作者: asdfjkwxwx    时间: 2009-7-19 19:02
能不能有个实例演示一下算法?
作者: sunnym    时间: 2009-7-26 10:34
一种随机方法吧 =百度一下
作者: cherry_s1218    时间: 2009-8-29 21:09
模拟仿真的
作者: ryansering    时间: 2009-9-3 20:41
百度之就好了
作者: 飘散云间    时间: 2010-8-30 15:14
一种随机仿真方法~~csdn上有完整代码
作者: yeppy    时间: 2010-9-4 10:17
还是迷糊啊
作者: 星星天铃鸟    时间: 2012-2-2 17:08
ddddddddddddddddddddddddddddddddd
作者: chensyyang    时间: 2013-8-31 17:36
同求例子~~光看文字看不懂啊~~




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