找回密码
 立即注册
查看: 3934|回复: 1

蒙特卡洛方法求圆面积的R代码

[复制链接]
发表于 2013-6-6 10:43:20 | 显示全部楼层 |阅读模式
有人问了一个蒙特卡洛求解问题,为了帮助理解蒙特卡洛方法思想,做了个例子,希望有所帮助。

问题:半径是1的圆,写个程序,不许用pi,结果接近3.14

思想就是:
半径为1的圆可以放到边长为2的正方形里面
边长为2的正方形面积是(2*圆的半径)^2
我随机在正方形里面均匀选10000个点,看看有多少个点可以落在圆里,也就是圆面积和正方形面积的比例就算出来了


如果手动试验可以这样做:找张边长为2的纸,然后上面画个内切圆,然后拿一粒沙子,往纸上扔,扔1000次,查查多少次落到了圆内,就把pi求出来了

求解代码如下:
  1. area<-function(radius=1,MonteCarlo_point_num=1000){
  2. randpoint_x=runif(MonteCarlo_point_num,0,2*radius)
  3. randpoint_y=runif(MonteCarlo_point_num,0,2*radius)
  4. point_num_in_circle=0
  5. for (i in 1:MonteCarlo_point_num){
  6. distance_randpoint_circlecenter=sqrt((randpoint_x[i]-radius)^2+(randpoint_y[i]-radius)^2)
  7. if(distance_randpoint_circlecenter<radius){
  8. point_num_in_circle=point_num_in_circle+1
  9. }
  10. }
  11. percent=point_num_in_circle/MonteCarlo_point_num
  12. area=percent*(2*radius)^2
  13. return(area)
  14. }
  15. area(1,100000)
复制代码
回复

使用道具 举报

发表于 2013-6-6 12:45:43 | 显示全部楼层
改进下运算速度
  1. area<-function(radius=1,MonteCarlo_point_num=1000){
  2. randpoint_x=runif(MonteCarlo_point_num,0,2*radius)
  3. randpoint_y=runif(MonteCarlo_point_num,0,2*radius)
  4. distance_randpoint_circlecenter<-sapply(1:MonteCarlo_point_num,function(x) sqrt((randpoint_x[x]-radius)^2+(randpoint_y[x]-radius)^2))
  5. point_num_in_circle<-length(distance_randpoint_circlecenter[distance_randpoint_circlecenter<radius])
  6. percent=point_num_in_circle/MonteCarlo_point_num
  7. area=percent*(2*radius)^2
  8. return(area)
  9. }
  10. area(1,100000)
复制代码
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|R语言中文网

GMT+8, 2024-11-25 07:33 , Processed in 0.024175 second(s), 18 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表