- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563297 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174212
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
详细资源下载附件
2 y. k1 A' L/ j$ q" e, ~) M' ?$ H3 x( n* b7 g# B- P
2-8、蒙特卡洛模拟
/ k% a% u% z( e5 Y: s0 q8 R; ?1 K一、背景7 V1 H* D# H& ~. {
# K' ? q' {+ D$ `) t! p* ^ 蒙特卡罗模拟方法 (Monte Carlo simulation) 诞生于上个世纪40年代美国的”曼哈顿计划”,名字来源于赌城蒙特卡罗。蒙特卡罗算法从某种意义上而言,就是一种赌博算法。
# a' r3 b; x% \4 J$ ` 它是一种基于随机试验和统计计算的数值方法,也称计算机随机模拟方法或统计模拟方法。蒙特卡罗方法的数学基础是概率论中的大数定律和中心极限定理。8 ~: X0 S3 P4 n& r% W* L5 N6 M
7 L* |8 P1 K. ?+ _$ `" u! \二、算法引入* k) C) }8 z3 C
1 \5 K* ^% N& `9 R' P1 Q& ? 最早接触到这类算法应该是在高中或者初中阶段,而且是一道送分题。即在一个正方形中有一个内接圆。现在在这个正方形内抛洒豆子。已知正方形面积为S,落在正方形内的豆子总数为 MM,其中落在内接圆内的豆子总数为 NN。请估算内接圆的面积。4 b6 e6 Z5 U, w/ @" V6 d
# B4 c% H/ m# [+ k- Y0 H& a" I
( r. m# q) L* ~" H
! ~4 N/ u1 A) g6 _7 f0 X; g 根据概率论中的大数定律可知,当随机事件发生的次数足够多的时候(趋向于正无穷),其发生频率就可作为此事件发生的概率。对于本题,当抛洒的豆子足够多的时候,落在圆中的豆子比值即可视为圆与正方形面积的比值。那么计算结果 S×N/MS×N/M 即为圆形面积。 7 @: L; X; \, Z$ h$ r
这种算法需要承担一定的风险,但是比起这种算法带给我们的收益,风险其实不足为惧,同时我们也可以运用合理恰当的方式来最小化这种风险。 + g( Q0 w% L {* M a- R k. U4 h. b
在建模和仿真中,应用蒙特卡罗方法主要有两部分工作:用蒙特卡罗方法模拟某一过程时,产生所需要的各种概率分布的随机变量;用统计方法把模型的数字特征估计出来,从而得到问题的数值解,即仿真结果。- q- h# o) u& n3 f1 y
1 j0 v6 f+ R6 t$ M. W/ A
解题步骤如下:
1 ]( }! b, s' @& m: \9 V. Q 1、根据提出的问题构造一个简单、适用的概率模型或随机模型,使问题的解对应于该模型中随机变量的某些特征(如概率、均值和方差等),所构造的模型在主要特征参量方面要与实际问题或系统相一致。 . d a; l1 h: ~4 ^" s' }1 \
2、根据模型中各个随机变量的分布,在计算机上产生随机数,实现一次模拟过程所需的足够数量的随机数。通常先产生均匀分布的随机数,然后生成服从某一分布的随机数,方可进行随机模拟试验。 & N6 S% l+ o+ H# j$ A( R/ M, K
3、根据概率模型的特点和随机变量的分布特性,设计和选取合适的抽样方法,并对每个随机变量进行抽样(包括直接抽样、分层抽样、相关抽样、重要抽样等)。
8 k* Z4 t0 `: B. ~ 4、按照所建立的模型进行仿真试验、计算,求出问题的随机解。
2 [; w, Q8 A. Y' H3 M* k( B" K 5、统计分析模拟试验结果,给出问题的概率解以及解的精度估计。8 B- x1 `% X# c2 e
1 a' ?2 [" A- E1 m2 k
三、算法应用
/ a% E" [ x/ V9 i1 B( q6 e, ^5 V, c; ]- |' J v% |3 w
蒙特卡罗算法的应用领域很多,这个算法在金融学、经济学、工程学等领域得到了广泛应用。适用于 Monte−CarloMonte−Carlo 算法的问题,比较常见的有两类。一类是问题的解等价于某事件的概率,如算法引入中提到的求解圆的面积问题。另一类是判定问题,即判定某个命题是否为真,例如主元素存在性判定和素数的测试问题。
6 X4 U1 N' k! p9 [8 h( D4 n 对于第一类算法所涉及到的问题,最多的就是定积分的求解。通常情况下我们有公式来求解各种图形的面积,当然也可以求解定积分。但是当我们遇到不规则图形以及极为复杂难以求解的定积分时,由于定积分的直观意义就是函数曲线与 xx 轴围成的图形中,y>0y>0 的面积减去 y<0y<0 的面积。同样是对于不规则面积的求解,最终我们都可以回到蒙特卡罗算法中来求解面积。
/ Y" Z+ l- [, a6 ^, j6 `: o
3 ~. E+ M" p* D K( W 对于蒙特卡罗算法,其优缺点也是比较明显的:
1 ~0 @$ v, n& z( x& f' y, R优点:
! H4 r; u# W4 ?: V. F# a 1、能够比较逼真的描述具有随机性质的事物的特点及物理实验过程 0 }" m6 I- o7 Z& V% B4 v0 {1 U
2、受几何条件限制小 ! |* {! k% ]" x/ h* {9 }6 B
3、收敛速度与问题的维数无关 ! x8 {; B, E. \0 \ V8 @
4、误差容易确定
9 F. t* b' n; L& o& G7 z. m5 ` 5、程序结构简单,易于实现 : B# z% V( e4 X6 ` v
缺点: + Q4 u7 Z8 v/ q: u
1、收敛速度慢
+ r t8 w$ r6 W9 t. _# P% f/ C) ~ 2、误差具有概率性 4 P$ r6 @2 A3 h3 n0 y8 h9 W
3、进行模拟的前提是各输入变量是相互独立的
8 m* M. ]& a3 r5 R0 E4 w: V3 n. n6 d2 K. y
四、算法实例% L' l; p) a" n- }! G+ W& w
, `. J2 }. Z$ X9 k$ B) w例1: 2 Y3 C7 D% s+ v$ ~/ r4 l3 H; ]
; e+ l" r( r0 a. Y: i1 y5 ~
7 P- v0 j3 p* m/ _) D# _
在不知道求解圆面积的公式的情况下,试用蒙特卡罗法求出圆面积。 E) a; q+ v# x- F) c' P
3 e1 j- j: C' U0 F: v解答:
4 v: j0 L/ v$ A- y 由上文介绍可知,可在matlab中生成大量在 [0;2][0;2] 上服从均匀分布的随机数,从而模拟上文中的抛撒豆子。通过计算落在圆中的点与总点数,就可算出圆与正方形面积之比。+ F$ H; F: X3 \: B1 v
+ Z t4 r8 z) ~- \, A |
zan
|