Pi的计算方式有很多,本文主要是通过Spark在概论统计的方法对Pi进行求解:

算法说明:

  在边长为R的正方形中,其面积为R^2,而其内接圆的面积为pi * R^2 /4 ,圆的面积与正方形的面积比为 Pi / 4 .

存在一个点,随机的往这个正方形中掉落,而且这个点掉落到正方形的每个位置的概率是相同的,当无数多个点掉落在这个正方形时,那么这个点在圆的个数x与在正方形上的个数y应该为圆的面积与正方形的面积之比Pi /4。

scala编程算法:

  

import org.apache.spark.sql.SparkSession

import scala.math.random

object SparkPi {
def main(args: Array[String]): Unit = {
//step1:创建spark线程
val spark= SparkSession.builder.appName("Spark Pi").getOrCreate()
//step2: 设置参数
val slices = if(args.length>0) args(0).toInt else 2 //通过输入的值判断分片的个数,主要是设定线程数
val n = math.min(100000L * slices, Int.MaxValue).toInt //设定投递的次数,也就是设定点的个数。当点的个数越大,求出的pi值越精确
//step3: 逻辑判断 ,并统计落在圆这个面积中的次数
val count: Int = spark.sparkContext.parallelize(1 until n, slices).map {
i =>
val x = random * 2 - 1
val y = random * 2 - 1
if (x * x + y * y <= 1) 1 else 0 //定义随机点,判断点是否落在圆内,若不在,则为0,否则则取1
}.reduce(_ + _)

//通过公式pi = 4.0 * (圆中的次数)/ 总的次数
println(s"Pi is roughly ${4.0 * count/(n-1)}")
spark.stop()
}

最新文章

  1. java stopwatch 功能
  2. find
  3. js 经典正则判断 一个字符串是否包含另一个字符串
  4. 快速入门系列--Log4net日志组件
  5. 【转】Maven实战(六)--- dependencies与dependencyManagement的区别
  6. Shiro 缓存失效以后的一个问题
  7. (一)学习MVC之制作验证码
  8. Linux 的使用基础---Shell程序设计
  9. java.lang.ClassCastException: java.math.BigDecimal cannot be cast to java.lang.String
  10. ACM竞赛常用STL(一)
  11. hadoop job执行完的统计信息
  12. PHP按值合并数组
  13. django模板引擎自定义变量
  14. [Swift]LeetCode122. 买卖股票的最佳时机 II | Best Time to Buy and Sell Stock II
  15. 「学习笔记」min_25筛
  16. CodeForces666E Forensic Examination
  17. vue2.0获取自定义属性的值
  18. ZooKeeper是什么
  19. Unity3D之主菜单
  20. HDU 2073 无限的路 (模拟)

热门文章

  1. Use Emacs as Personal Knowledge Base
  2. MyBatis-Plus QueryWrapper及LambdaQueryWrapper的使用
  3. MySQL-04-SQL简单介绍
  4. DVWA-全等级命令行注入
  5. VLAN-5 利用三层交换机实现vlan间的路由
  6. 11-SpringCloud Hystrix
  7. CNN卷积神经网络详解
  8. 【转】Java 开发必会的 Linux 命令
  9. 12.SpringMVC之拦截器
  10. Java环境变量(Env)和系统属性(Property)详解