QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8033|回复: 2
打印 上一主题 下一主题

使用python做蒙特卡罗模拟求pi

[复制链接]
字体大小: 正常 放大

7

主题

9

听众

496

积分

升级  65.33%

  • TA的每日心情

    2015-11-11 09:17
  • 签到天数: 234 天

    [LV.7]常住居民III

    社区QQ达人

    群组2013年电工杯B题讨论群

    群组2014年网络挑战赛交流

    跳转到指定楼层
    1#
    发表于 2014-9-18 17:12 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    神奇的随机,蒙特卡罗模拟求pi
    以下摘自百度百科:+ f* B; F( \- ]
    蒙特卡罗模拟因摩纳哥著名的赌场而得名。它能够帮助人们从数学上表述物理、化学、工程、经济学以及环境动力学中一些非常复杂的相互作用。数学家们称这种表述为“模式”, 而当一种模式足够精确时, 他能产生与实际操作中对同一条件相同的反应。但蒙特卡罗模拟有一个危险的缺陷: 如果必须输入一个模式中的随机数并不像设想的那样是随机数, 而却构成一些微妙的非随机模式, 那么整个的模拟(及其预测结果)都可能是错的。. p, K8 i. F1 X
    6 s4 T3 e0 G7 k0 \: ?' f
    鄙人谈几句话:
    ; B7 z5 o2 N3 i0 O. P8 p蒙特卡罗模拟的用处非常广,而且蒙特卡罗模拟听起来有点高端霸气上档次,其实蒙特卡罗模拟的原理很简单,就是利用“随机”去创造一个数学模型,从而模拟复杂的系统来解决问题。下面是蒙特卡罗模拟的一个简单应用例子,求解pi的近似解。我们知道pi的9位有效数字的近似值是3.14159265。然后我使用的蒙特卡罗原理是这样的:单位长度为1的正方形中,我们在其中的一条对角线画一条弧得出一个扇形,刚好是单位为1的圆的1/4。如graph1。
    ( {  f# {, I3 S5 F2 [
    9 y$ D8 a0 a. f2 L1 O
    然后我们在正方形内生成随机的点。然后统计点在弧线下方出现的次数。弧下方的点数/总点数=1/4倍的单位圆面积=(
    πr^2)/4,r=1。然后我们就可以得出pi的值。
    ' p- L# T* c% {7 w$ Y  J  q( S; E7 G/ C9 S: k! d
    以下是鄙人的蒙特卡罗模拟求pi的python程序: 5 M1 Z& q' a% J# w) }: }
    #Author : Naupio
    . N. T, X  o6 A$ S$ X- B  Oimport random as rd% R, g1 U0 m$ T  j9 }! ~% n

    + W$ t+ |  P$ A9 q  K
    : @* e6 n# q! W8 R, j9 C, A" [, ^2 [def findpi(times = 1000):
    % U6 n% C, E5 O( C5 Q2 ~9 q3 s' v    counts = 0.06 B3 R9 ], k; g4 s# G* I  a
        for i in range(times):3 G$ b* C! t( p* G$ d" B
            x = rd.random()- S1 F. \) p5 r+ y% o/ A
            y = rd.random()- Q7 K! L( f; ^  J. p
            if (x**2+y**2)<1:& h; \; T, e- P" v  ?
                counts+=1
    : @5 h4 E9 e# g; v    return (counts*4)/(times*1)' G4 H: t+ E' s0 q8 Q( @
    ( m6 T  Y+ q  ^: n, O, t. q4 E5 k

    3 J( _/ W) F  G9 X) vprint "蒙特卡罗模拟一千次得出的pi近似值为:",findpi(1000)+ l& q/ J# X5 S3 m, e$ {& f5 q# I
    print "蒙特卡罗模拟一万次得出的pi近似值为:",findpi(10000)+ X8 _& ^& J1 {8 q
    print "蒙特卡罗模拟十万次次得出的pi近似值为:",findpi(100000)' a5 b( t1 N: u( K8 b0 Y, n
    print "蒙特卡罗模拟一百万次得出的pi近似值为:",findpi(1000000)
    $ Z( V8 \3 M' h; ?; Wprint "蒙特卡罗模拟一千万次得出的pi近似值为:",findpi(10000000)# ?) j& T! o0 o6 t1 }
    print "蒙特卡罗模拟五千万次得出的pi近似值为:",findpi(50000000)
    5 P2 k5 Y+ j# Q0 v: E" v
    % o+ n9 `, F3 s# f以下是蒙特卡罗模拟的结果图: : x* Q5 K5 b2 k  I1 H
    3 W  A/ j& w+ `; S' G

    ; l! Y* I5 z% z' ?! P) M最后鄙人说几句:
    . w& W+ Y% Z; |5 c' d6 Q3 J+ `9 y+ s从模拟的结果来看,是非常成功的,随着模拟次数的增加,结果越来越接近pi的真实值 。蒙特卡罗模拟当然还有很多用法,下次有空时,鄙人会尝试用蒙特卡罗模拟来求解积分值。
    # F4 m# J1 q# F* o2 q@madio @百年孤独 @数学中国—罂粟 & l) U7 s$ w0 k5 O/ ?, |- {
    ps :鄙人无法保证绝对的正确性,如有误导之处,欢迎指正,同时也欢迎交流,转载请注明出去,版权所有。
    5 }0 c9 N( U/ H5 J# {) O
      G3 s0 w7 ?% @8 Y3 @1 D2 S% |8 }* l  z3 k
    $ [( n) @! ?# y) X1 |, B/ _

    7 O# n! \& _+ @" {
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    dazhou123        

    0

    主题

    12

    听众

    42

    积分

    升级  38.95%

  • TA的每日心情
    无聊
    2016-2-1 17:51
  • 签到天数: 11 天

    [LV.3]偶尔看看II

    社区QQ达人 邮箱绑定达人

    回复

    使用道具 举报

    0

    主题

    12

    听众

    115

    积分

    升级  7.5%

  • TA的每日心情
    慵懒
    2017-2-22 21:14
  • 签到天数: 45 天

    [LV.5]常住居民I

    自我介绍
    共同学习

    社区QQ达人

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-9-17 10:59 , Processed in 2.744418 second(s), 61 queries .

    回顶部