erlang蒙特卡洛方法求Pi
来源:互联网 发布:淘宝上的白酒是真的吗 编辑:程序博客网 时间:2024/05/16 11:56
两个参数R,N分别代表范围和试验次数。思想是正方形内接圆,往正方形上扔飞镖,落在圆内计数加一,最终拿计数和总试验次数作比。
R=1M,N=1M 结果3.143856,3.140464,3.141572,取平均为3.141964
代码如下
-module(ex7).-import(math,[sqrt/1,pow/2]).-import(rand,[uniform/1]).-compile([export_all]).index(0,[H|_T])->H;index(N,[_H|T])->index(N-1,T).distance(A,B)->sqrt(pow(index(0,A)-index(0,B),2)+pow(index(1,A)-index(1,B),2)).count(N,R)->count(N-1,R,distance([0,0],[uniform(R),uniform(R)])).count(0,R,D)when D<R ->1;count(0,_R,_D)->0;count(N,R,D)when D<R ->1+count(N-1,R,distance([0,0],[uniform(R),uniform(R)]));count(N,R,_caD)->count(N-1,R,distance([0,0],[uniform(R),uniform(R)])).calPi(R,N)->io:format("~w~n",[4*count(N,R)/N]).
0 0
- Erlang-蒙特卡洛方法求Pi
- erlang蒙特卡洛方法求Pi
- 求PI
- 求PI
- 蓝桥杯 求圆面积+注意求pi的方法
- 【多核程序设计】蒙特卡洛算法求pi
- 蒙特·卡罗方法求PI
- matlab数值积分方法求pi的近似值及其比较
- PHP实现简单高精度的求PI方法
- 求pi值
- 多线程求PI
- 概率算法求PI
- 求PI的值
- 近似求pi
- 近似求PI
- 近似求PI
- 求pi的值
- 求 PI(1)
- 成为Java顶尖高手要看的11本书
- python中的下划线是啥意思?
- Java 算法之冒泡排序
- Ubuntu14.04设置Terminator为默认Terminal
- Set,List,Map的区别
- erlang蒙特卡洛方法求Pi
- UIButton加视图/文字
- 算法学习之路(插入排序)
- 学习笔记-java按值传递
- java中的Checked Exception和Unchecked Exception的区别
- MFC--LIB
- 阿谀并不是没有优点
- 《C++ Primer》读书笔记-第一章 入门
- 2015中国和世界十大科技进展