蒙特卡洛法模拟计算圆周率π

article/2025/9/17 8:58:13

一、蒙特卡洛法介绍
蒙特·卡罗方法(Monte Carlo method),也称统计模拟方法,是一种以概率统计理论为基础的数值计算方法,常用于特定条件下的概率计算问题。蒙特卡罗是摩纳哥的著名赌城,该法为表明其随机抽样的本质而命名。
算法思路简单也好理解:比如抛一枚硬币,假设我们开始不知道正面朝上的概率是多少,却有大量的时间来将硬币抛一万次,那么在一万次试验后,会发现正面朝上的次数接近一半,当然,抛的次数越多,概率越接近50%,蒙特卡洛方法是大数定律在实际应用问题上的体现。其优点十分明显,基本可以绕开问题本身的“黑盒”,不必考虑问题内部的结构而只关注问题的输入与输出,利用输出的结果来分析问题,适用于对离散系统进行计算仿真试验。
例如上例中,我们不用考虑硬币在空中停留多长时间,不用考虑抛出力度、硬币大小、空气阻力、风速等乱七八糟的问题,在大量的试验后只关注最后硬币哪面朝上,就能正确估算出硬币正面朝上的概率。同样的,例如我们不知道走到某个路口需要等红绿灯的概率,不知道某个产品线的合格率,蒙特卡洛法告诉你:模拟一万次试验后你就知道了O(∩_∩)O~
二、利用蒙特卡洛方法计算圆周率π
采用蒙特卡洛思想,首先在一个正方形区域内随机生成若干个均匀分布的点,随后判断哪些点在正方形的内切圆范围内。如果点的数量足够多,那么圆内点的数量与点的总数量的比值,就是圆的面积与正方形面积之比。利用点数量的比值与正方形面积就可以推出圆的面积,进而得出圆周率π。
在这里插入图片描述
上代码:

import numpy as np
import matplotlib.pyplot as plt
import math
from tqdm import tqdm
from numpy import meancenter_x = 0.0  #圆心横坐标
center_y = 0.0  #圆心纵坐标
r = 1.0         #半径class Caculate_Pi:def __init__(self,dot_num):self.dot_num = dot_num   #初始化点的数量self.count = 0   #圆内点的计数器self.x = np.random.uniform(center_x - r,center_x + r,self.dot_num)   #点均匀分布的横轴范围self.y = np.random.uniform(center_y - r,center_y + r,self.dot_num)   #点均匀分布的纵轴范围def Judge(self,x,y,r):      #判断点是否在圆内return np.sqrt(x ** 2 + y ** 2) <= rdef Count(self):            #计算圆内点的个数result = [self.Judge(self.x[i], self.y[i], r) for i in range(self.dot_num)]for i in result:if i:self.count += 1dot_num = []
Pi = []
for i in tqdm(range(1,1000)):   #考虑从100到1000000个点模拟的π值如何变化dot_num.append(100 * i)demo = Caculate_Pi(100 *i)demo.Count()pi = demo.count * 4 /(100 * i)Pi.append(pi)
#可视化随着点数量增多模拟π的变化
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.xlabel('模拟次数')
plt.ylabel('模拟的Pi值')
plt.axhline(y = math.pi,c = "red")
plt.annotate('y=π',xy=(0,3.1415926),xytext=(-8000,3.14))
plt.plot(dot_num,Pi)
print('模拟得到的π均值:',mean(Pi[100:]))

运行结果:
在这里插入图片描述
可以看出模拟次数越多(从100到100000),模拟的π值越来越趋近于真实的π(3.141592654)。本次计算最终模拟的平均值为

模拟得到的π均值:3.1414679762608873

已经比较接近了,以上就是利用蒙特卡洛法计算圆周率的小练习。
当然,计算的方法还包括经典的精确算法——割圆法、无穷级数法,其同样可以用代码实现,下次无聊的时候再写吧。


http://chatgpt.dhexx.cn/article/i0vySrsO.shtml

相关文章

蒙特卡洛法之MATLAB实现

by WC 1.7.2016蒙特卡洛法&#xff08;随机取样法&#xff09;也称为计算机随机模拟方法&#xff0c;它源于世界著名的赌城——Monte Carlo。它是基于对大量事件的统计结果来实现一些确定性问题的计算。使用蒙特卡洛法必须使用计算机生成相关分布的随机数。 eg&#xff1a; y…

C语言文件打开关闭和读写

文件在进行读写操作之前要先打开&#xff0c;使用完毕要关闭。在C语言中&#xff0c;文件操作都是由库函数来完成的。在本节内将介绍主要的文件操作函数。 文件的打开(fopen函数) fopen函数用来打开一个文件&#xff0c;其调用的一般形式为&#xff1a; 文件指针名 fopen( 文…

C语言文件详解(一)文件介绍,文件打开和关闭

文章目录 一、文件介绍1.1为什么使用文件1.2什么是文件1.3文件名 二、文件的打开和关闭2.1文件指针2.2文件的打开和关闭 一、文件介绍 1.1为什么使用文件 文件属于文件的一种&#xff0c;与普通文件载体不同&#xff0c;文件是以硬盘为载体存储在计算机上的信息集合。那么为什…

C语言fopen打开文件失败了,原来是这个原因~~~~

大家好&#xff0c;我是疯狂的比特&#xff0c;一个每天在互联网上种菜和砍柴的程序员 今天给大家分享一个C语言初学者常见的一个问题。 问题 经常有人问我&#xff0c;我的C语言代码好好的&#xff0c;怎么就打开文件失败了呢&#xff1f; 我们先来看看代码吧 #include <s…

【C】C语言打开,读取文件

文章目录 C语言打开&#xff0c;读取文件一、明明白白我的心二、代码飞起来三、过程不重要&#xff0c;重点看结果 C语言打开&#xff0c;读取文件 一、明明白白我的心 1、gcc编译C语言代码 2、winds10操作系统 3、VS Code编辑器(强推&#xff0c;最近博主用这个…

C语言<文件的打开与关闭>

目录 一.为什么使用文件 二.什么是文件 1.程序文件 2.数据文件 3.文件名 三.文件的打开与关闭 1.文件指针 2.文件的打开与关闭 结语 一.为什么使用文件 我们前面学习结构体时&#xff0c;写了通讯录的程序&#xff0c;当通讯录运行起来的时候&#xff0c;可以给通讯录…

C语言文件打开方式

使用文件的方式共有12种&#xff0c;下面给出了它们的符号和意义。 文件打开方式 意义 rt 只读打开一个文本文件&#xff0c;只允许读数据 wt 只写打开或建立一个文本文件&#xff0c;只允许写数据 at 追加打开一个文本文件&#xff0c;并在文件末尾写数据 rb 只…

C语言————文件的打开(知识点总结+举例)

fopen函数用来打开一个文件&#xff0c;其调用的一般形式为&#xff1a; 文件指针名fopen(文件名,使用文件方式); 其中&#xff1a; “文件指针名”必须是被说明为FILE 类型的指针变量&#xff1b; “文件名”是被打开文件的文件名&#xff1b; “使用文件方式”是指文件的类型…

【C语言】文件的打开和关闭,文件的顺序读写

文章目录 1、为什么使用文件 2、什么是文件 3、文件的打开和关闭 文件的打开 文件的关闭 4、文件的顺序读写 4.1文件读写的特点 4.2fputc、fgetc函数 4.3fgets、fputs函数 4.4fscanf、fprintf函数 5、标准输入输出流stdin、stdout 1、为什么使用文件 在编写例如通讯…

C语言-文件操作

当程序的生命周期结束&#xff0c;在内存中存放的数据就会随着内存的释放而清除&#xff0c;这并不满足我们日常生活中的记录需求&#xff0c;所以C语言开发了文件操作模式&#xff0c;通过将数据存放在硬盘&#xff0c;数据库等方式&#xff0c;实现数据的持久化。 文件存在于…

C语言打开文件详解

C语言中操作文件之前必须先打开文件&#xff1b;所谓“打开文件”&#xff0c;就是让程序和文件建立连接的过程。 打开文件之后&#xff0c;程序可以得到文件的相关信息&#xff0c;例如大小、类型、权限、创建者、更新时间等。在后续读写文件的过程中&#xff0c;程序还可以记…

一 形参与实参

1 实际参数&#xff08;实参&#xff09; 真实传给函数的参数&#xff0c;叫实参。即在函数调用时写入的实际参数。 实参可以是&#xff1a;常量、变量、表达式、函数等。无论实参是何种类型的量&#xff0c;在进行函数调用时&#xff0c;它们必须有确定的值&#xff0c;以便把…

【C语言函数参数详解】——实际参数(实参)形式参数(形参)

文章目录 一.什么是实际参数&#xff08;实参&#xff09;二.什么是形式参数&#xff08;形参&#xff09;三.形参与实参的关系 这篇文章我们一起学习一下函数的参数&#xff0c;函数的参数分为实参和形参。 一.什么是实际参数&#xff08;实参&#xff09; 首先我们来学习实…

java 静态工厂_高效Java第一条考虑用静态工厂代替构造函数

获得类的实例&#xff1a; 1.提供一个公有的构造函数&#xff1b; 2.提供一个公有的静态工厂方法&#xff0c;该方法只是一个返回类的实例的静态方法。 静态工厂方法与设计模式中的工厂方法模式不同。 提供静态工厂方法的优势——静态工厂方法与构造函数不同的第一大优势在于&a…

【算法之高效求素数】浅析求素数算法

注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度 1. 根据概念判断: 如果一个正整数只有两个因子, 1和p&#xff0c;则称p为素数. 代码: bool isPrime(int n) {if(n < 2) return false;for(int i 2; i < n; i)if(n%i 0) return false;return true;…

求素数算法

注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度 1. 根据概念判断: 如果一个正整数只有两个因子, 1和p&#xff0c;则称p为素数. 代码: bool isPrime(int n) {if(n < 2) return false;for(int i 2; i < n; i)if(n%i 0) return false;return true;…

求素数算法-网摘

摘自&#xff1a;http://www.cnblogs.com/luluping/archive/2010/03/03/1677552.html 浅析求素数算法注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度1. 根据概念判断:如果一个正整数只有两个因子, 1和p&#xff0c;则称p为素数. 代码: bool isPrime(int n) …

用JAVA编写50以内的素数_java求50以内的素数

java求50以内的素数 [2021-02-01 12:46:22] 简介: python求100内的所有素数的方法&#xff1a;使用判断该数除了1和它本身以外不再有其他因数即可&#xff0c;代码为【i2 for i in range(2,100): if(i%j0):break else:num.append(i)】。相关免费学 php去除nbsp的方法&#xff…

浅析求素数算法

原文地址为&#xff1a; 浅析求素数算法 2009-12-05 16:15:31 阅读18 评论0 字号&#xff1a;大中小 浅析求素数算法时间: 2006-10-27注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度1. 根据概念判断:如果一个正整数只有两个因子, 1和p&#xff0c;则称p为…

Python中的所有运算符以及运算符的优先级

文章目录 前言一、算术运算符二、赋值运算符三、比较运算符四、逻辑运算符五、位运算符六、运算符的优先级案例实战总结 前言 运算符是一些人为定义的特殊符号&#xff0c;比如我们生活当中最常见的 、-、、&#xff0c;它们主要用于数学计算、比较大小和逻辑运算等等。那这些…