, V7 F- r4 m7 o: x; h$ E0 _, o一、背景 5 \7 ^+ _: v- M1 I4 t H" ] I 0 E( `5 {5 K y; u6 W 蒙特卡罗模拟方法 (Monte Carlo simulation) 诞生于上个世纪40年代美国的”曼哈顿计划”,名字来源于赌城蒙特卡罗。蒙特卡罗算法从某种意义上而言,就是一种赌博算法。 9 W% n9 t$ L/ g# n% _% Y6 x
它是一种基于随机试验和统计计算的数值方法,也称计算机随机模拟方法或统计模拟方法。蒙特卡罗方法的数学基础是概率论中的大数定律和中心极限定理。! l1 I: o. L7 W/ k: g
% K7 Y& ]+ [2 s5 w2 S k
二、算法引入 3 t; v5 N Q9 b; V- P ( q" R1 M& o7 G _0 Y. O 最早接触到这类算法应该是在高中或者初中阶段,而且是一道送分题。即在一个正方形中有一个内接圆。现在在这个正方形内抛洒豆子。已知正方形面积为S,落在正方形内的豆子总数为 MM,其中落在内接圆内的豆子总数为 NN。请估算内接圆的面积。6 H/ u2 o. I5 Q+ @
, U* b, k. m7 B
( [7 w# S q( s! [" C1 t2 N7 U9 o: S$ U* w
根据概率论中的大数定律可知,当随机事件发生的次数足够多的时候(趋向于正无穷),其发生频率就可作为此事件发生的概率。对于本题,当抛洒的豆子足够多的时候,落在圆中的豆子比值即可视为圆与正方形面积的比值。那么计算结果 S×N/MS×N/M 即为圆形面积。 9 Q& @2 u" o/ u0 u8 Y& U 这种算法需要承担一定的风险,但是比起这种算法带给我们的收益,风险其实不足为惧,同时我们也可以运用合理恰当的方式来最小化这种风险。 1 _# L% O/ z, g; J _( A 在建模和仿真中,应用蒙特卡罗方法主要有两部分工作:用蒙特卡罗方法模拟某一过程时,产生所需要的各种概率分布的随机变量;用统计方法把模型的数字特征估计出来,从而得到问题的数值解,即仿真结果。 2 U X1 V/ i3 d1 E ! B* O7 e7 l5 f1 ], l: l3 o& B解题步骤如下: 0 H9 k( o9 ?& L% e5 Q2 c8 |4 _+ } 1、根据提出的问题构造一个简单、适用的概率模型或随机模型,使问题的解对应于该模型中随机变量的某些特征(如概率、均值和方差等),所构造的模型在主要特征参量方面要与实际问题或系统相一致。 * g1 V2 V, X& n
2、根据模型中各个随机变量的分布,在计算机上产生随机数,实现一次模拟过程所需的足够数量的随机数。通常先产生均匀分布的随机数,然后生成服从某一分布的随机数,方可进行随机模拟试验。 & H) @3 l, S3 c7 z
3、根据概率模型的特点和随机变量的分布特性,设计和选取合适的抽样方法,并对每个随机变量进行抽样(包括直接抽样、分层抽样、相关抽样、重要抽样等)。 $ k0 j' d+ F' G B: f G% [ 4、按照所建立的模型进行仿真试验、计算,求出问题的随机解。 ! K& Q5 T2 f `1 r 5、统计分析模拟试验结果,给出问题的概率解以及解的精度估计。& Y$ q6 S; v# H/ {+ U3 x! }! p- X
5 m( g( h# T9 z D8 o三、算法应用6 }5 \" @ S3 f8 f
4 c, O2 E$ d5 A2 g) x" {" C
蒙特卡罗算法的应用领域很多,这个算法在金融学、经济学、工程学等领域得到了广泛应用。适用于 Monte−CarloMonte−Carlo 算法的问题,比较常见的有两类。一类是问题的解等价于某事件的概率,如算法引入中提到的求解圆的面积问题。另一类是判定问题,即判定某个命题是否为真,例如主元素存在性判定和素数的测试问题。 " m: w1 D. {2 _8 Z a! }
对于第一类算法所涉及到的问题,最多的就是定积分的求解。通常情况下我们有公式来求解各种图形的面积,当然也可以求解定积分。但是当我们遇到不规则图形以及极为复杂难以求解的定积分时,由于定积分的直观意义就是函数曲线与 xx 轴围成的图形中,y>0y>0 的面积减去 y<0y<0 的面积。同样是对于不规则面积的求解,最终我们都可以回到蒙特卡罗算法中来求解面积。8 r2 ?+ L8 d# w) G2 A- E- U
q7 D0 ]/ y" V, K, E 对于蒙特卡罗算法,其优缺点也是比较明显的: 9 m0 U. R, d: j/ T优点: 7 `& F7 s) d( A8 Q9 K- O 1、能够比较逼真的描述具有随机性质的事物的特点及物理实验过程 1 x, g9 F0 h& w4 q$ `7 ]: P
2、受几何条件限制小 $ `5 ]& H$ x3 N; y% `: a* G
3、收敛速度与问题的维数无关 - y1 w# |1 h( t- q' | 4、误差容易确定 : ]; }% X4 @! o1 Y8 j
5、程序结构简单,易于实现 & N( _( `7 t0 I缺点: ' A( _; w z5 c- [- v, j 1、收敛速度慢 / y! U6 W& z( J3 j! H
2、误差具有概率性 " u. l Y1 J: @* q2 e3 w. i
3、进行模拟的前提是各输入变量是相互独立的/ F- l4 L d5 K3 S' Y
+ q7 y/ I0 w. ~% `四、算法实例, s4 {2 X4 B. S' Z2 J. x$ K
8 ~+ x% P- \, k- b( D( A
例1: ' Z9 O& K* [3 W. p
! A/ e9 B7 u9 X3 z
3 ~ B$ t9 J7 Y$ B( k
在不知道求解圆面积的公式的情况下,试用蒙特卡罗法求出圆面积。 & H! e' p! B& Z* _, W* ?4 d7 ~4 c0 \9 f8 t" ~
解答: 6 @3 i3 I: b/ p0 G
由上文介绍可知,可在matlab中生成大量在 [0;2][0;2] 上服从均匀分布的随机数,从而模拟上文中的抛撒豆子。通过计算落在圆中的点与总点数,就可算出圆与正方形面积之比。) H5 ^. l, p2 S
- I/ N9 Y: {4 R* u/ |9 l