查看原文
其他

一分钟了解蒙特卡洛方法。

ikeguang.com 大数据技术派 2022-10-15


蒙特卡罗方法是一种计算方法。原理是通过大量随机样本,去了解一个系统,进而得到所要计算的值。最经典的莫过于圆周率π的计算了。


圆周率π的计算

单位圆面积为π,并且内切与边长为2的正方形,用随机数,10000个点往下面投,落到圆里面的概率乘以4就是π的值

说明:等式左边,是圆与正方形面积之比;等式右边,是落在单位圆内的点与落在正方形内的点的比值。二者相等。


分析

1、以圆心为原点,建立二维坐标系;

2、随便投一个点,这个记为(x, y),落在圆内,则到圆心的距离 x*2 + y*2 <= 1;

3、投点10000次,落入圆内次数n,π值为n / 10000 * 4;


Python代码


分析好了,代码就很容易实现了,coding。


import random

def run():
    n = 10**4
    n_pai = 0
    for i in range(1, n + 1):
        x = random.random()
        y = random.random()

        # 落在单位圆内部
        if x**2 + y**2 <= 1:
            n_pai = n_pai + 1

    pai = n_pai / float(n) * 4

    print(pai)


if __name__ == '__main__':
    run()


4次模拟结果

3.142

3.1424

3.1368

3.156


代码Github地址https://github.com/ddxygq/PyCode


猜你可能喜欢

分类与聚类的本质区别

MNIST机器学习入门——Tensorflow手写字识别

使用tensorflow做梯度下降的线性回归

交了3年的女朋友不理我了,她说我连SVM都不会?


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存