PHP计算地球上两点之间的距离(示例详解)
PHP计算地球上两点之间的距离(示例详解)
内容导读
收集整理的这篇技术教程文章主要介绍了PHP计算地球上两点之间的距离(示例详解),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2067字,纯文字阅读大概需要3分钟。
内容图文
给定经度和纬度,求地球上两点之间的距离。首先我们需要了解该问题的解决思路,然后再用PHP代码来实现计算。此问题可以用半正矢(haversine)公式
求解:
大圆距离或正交距离是球面(或地球表面)上两点之间最短的距离。为了使用这种方法,我们需要有点A和点B的坐标。大圆法优于其他方法。
首先,将纬度和经度值从十进制度转换为弧度。因此,将经度和纬度值同时除以180 / pi。pi圆周率的值是22/7。180/pi的值约为57.29577951。如果我们想计算两个地方之间的距离(以英里为单位),就用3,963,这是地球的半径。如果我们想计算两个地方之间的距离,单位是千米,用6,378.8,也就是地球的半径。
求纬度值(以弧度为单位):纬度值,单位为弧度,lat =纬度/ (180/pi)或纬度值,以弧度为单位,lat =纬度/ 57.29577951求经度的弧度值:经度值,单位为弧度,long =经度/ (180/pi)或经度值,单位为弧度,long =经度/ 57.29577951
求出点A的经纬度坐标。使用上述转换方法将经纬度值转换为弧度。我把它叫做lat1和long1。对点B的坐标做同样的处理,得到lat2和long2。
现在,为了得到点A和点B之间的距离,使用下面的公式:
距离,d = 3963.0 * arccos[(sin(lat1) * sin(lat2)) + cos(lat1) * cos(lat2) * cos(long2 - long1)]
得到的距离d的单位是英里。如果你想让你的值以千米为单位,则d乘以1.609344。
d(千米)= 1.609344 * d(英里)
因此,你可以用大圆距离法得到地球上两个地方之间最短的距离。
PHP计算地球上两点间距离的实现代码如下:
<?php function twopoints_on_earth($latitudeFrom, $longitudeFrom, $latitudeTo, $longitudeTo) { $long1 = deg2rad($longitudeFrom); $long2 = deg2rad($longitudeTo); $lat1 = deg2rad($latitudeFrom); $lat2 = deg2rad($latitudeTo); $dlong = $long2 - $long1; $dlati = $lat2 - $lat1; $val = pow(sin($dlati/2),2)+cos($lat1)*cos($lat2)*pow(sin($dlong/2),2); $res = 2 * asin(sqrt($val)); $radius = 3958.756; return ($res*$radius); } //经纬度两点 $latitudeFrom = 19.017656 ; $longitudeFrom = 72.856178; $latitudeTo = 40.7127; $longitudeTo = -74.0059; // 孟买和纽约之间的距离 print_r(twopoints_on_earth( $latitudeFrom, $longitudeFrom, $latitudeTo, $longitudeTo).' '.'miles');
输出:
2.0043678382716137 K.M
本篇文章就是关于PHP计算地球上两点之间的距离的方法介绍,希望对需要的朋友有所帮助!
以上就是PHP计算地球上两点之间的距离(示例详解)的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是为您收集整理的PHP计算地球上两点之间的距离(示例详解)全部内容,希望文章能够帮你解决PHP计算地球上两点之间的距离(示例详解)所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。