python怎么用蒙特·卡罗方法求圆周率
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,这篇文章主要介绍了python怎么用蒙特·卡罗方法求圆周率的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python怎么用蒙特·卡罗方法求圆周率文章都会有所收获,下面我们
千家信息网最后更新 2025年12月01日python怎么用蒙特·卡罗方法求圆周率
这篇文章主要介绍了python怎么用蒙特·卡罗方法求圆周率的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python怎么用蒙特·卡罗方法求圆周率文章都会有所收获,下面我们一起来看看吧。
蒙特·卡罗方法求圆周率
介绍:
蒙特·卡罗方法(Monte Carlo method),也称统计模拟方法,是二十世纪四十年代中期由于科学技术的发展和电子计算机的发明,而被提出的一种以概率统计理论为指导的一类非常重要的数值计算方法。是指使用随机数(或更常见的伪随机数)来解决很多计算问题的方法。与它对应的是确定性算法。蒙特·卡罗方法在金融工程学,宏观经济学,计算物理学(如粒子输运计算、量子热力学计算、空气动力学计算)等领域应用广泛。
其实,高中数学里的几何概型(P=阴影部分面积(或区间或体积)/总面积(或区间或体积))就是一种蒙特·卡罗方法。
import numpy as npimport matplotlib.pyplot as pltfrom matplotlib.patches import Circle# 投点次数n = 10000# 圆的信息r = 1.0 # 半径a, b = (0., 0.) # 圆心# 正方形区域边界x_min, x_max = a-r, a+ry_min, y_max = b-r, b+r# 在正方形区域内随机投点x = np.random.uniform(x_min, x_max, n) # 均匀分布y = np.random.uniform(y_min, y_max, n)# 计算 点到圆心的距离d = np.sqrt((x-a)**2 + (y-b)**2)# 统计 落在圆内的点的数目res = sum(np.where(d < r, 1, 0))# 计算 pi 的近似值(Monte Carlo方法的精髓:用统计值去近似真实值)pi = 4 * res / nprint('pi: ', pi)spi = 3.1415926535print('这里近似的圆周率与10位的圆周率精确度是: ', (spi - pi)/spi )# 画个图看看fig = plt.figure()axes = fig.add_subplot(111)axes.plot(x, y,'ro',markersize = 1)plt.axis('equal') # 防止图像变形circle = Circle(xy=(a,b), radius=r, alpha=0.5)axes.add_patch(circle)plt.show()
执行结果:
pi: 3.1224这里近似的圆周率与10位的圆周率精确度是: 0.006109211351324613
关于"python怎么用蒙特·卡罗方法求圆周率"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"python怎么用蒙特·卡罗方法求圆周率"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
方法
圆周
圆周率
卡罗
蒙特
统计
知识
精确
体积
内容
区域
区间
圆心
正方
正方形
篇文章
精确度
随机数
中期
几何
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
怎样修改发票上的数据库
遂宁软件开发工程师
宇视服务器崩溃怎么维修
用腾讯云服务器搭建自己的网站
数据库可以改路径吗
开源空间数据库有哪些
旭实互联网科技怎么样
普安软件开发
网络安全自查简报
云服务器管理员的账号
将txt数据导入数据库中
传奇世界上最强服务器
部队网络安全常识测试
安装设备时显示服务器错误
云平台网络安全的防范措施
软件开发需要办外经证吗
重启光大网络技术有限公司
数据库数据建模的流程
武汉大学网络安全硕士难度
phpcms切换数据库
dns本地代理服务器
徐汇区合格软件开发排名靠前
万方数据库的检索方法ppt
软件开发者真的需要文凭吗
人群变异数据库的是
软件开发配合服务费
服务器可以用什么替代
服务器也能使用的指令
物美集团网络安全
开普蓝网络技术