使用scala计算两个Gps点之间的距离

通常进行轨迹数据的挖掘,都会用到经纬度转换距离。特别是Spark需要scala语言编写,这方面的轮子比较少。
 
object getDistance{ def main(args: Array[String]) { val lon1 = 108.956769;val lat1 = 34.229644 val lon2 = 108.958830;val lat2 =34.229701 def getDistance(lon1: Double, lat1: Double, lon2: Double, lat2: Double): Double ={ //pi为π,r为地球半径 val pi = 3.1415926 val r: Double = 6370.99681 //a1、a2、b1、b2分别为上面数据的经纬度转换为弧度 val a1 = lat1 * pi /180.0 val a2 = lon1 * pi /180.0 val b1 = lat2 * pi /180.0 val b2 = lon2 * pi /180.0 var t1: Double = Math.cos(a1) * Math.cos(a2) * Math.cos(b1)* Math.cos(b2) var t2: Double = Math.cos(a1) * Math.sin(a2) * Math.cos(b1)* Math.sin(b2) var t3: Double = Math.sin(a1) * Math.sin(b1) val distance = Math.acos(t1 + t2 + t3) * r distance } println(getDistance(lon1,lat1,lon2,lat2)) } }

下面是该程序的打印结果
0.18958348454499852

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值