总结
豆包 AI 助手文章总结
首页 > 常见问题 > 正文

【数学公式及推导】根据经纬度计算地面两点间的距离

藏色散人
发布: 2020-10-22 11:38:49
转载
4100人浏览过

1.假设:地球是正球体。地面两点a和b的经纬度坐标分别为(aj,aw)和(bj,bw),地球半径r取平均值6371km。

2.建立三维直角坐标系

地球球心为原点O,地轴为Z轴,北极方向为Z轴正方向,赤道平面为X轴和Y轴所在平面,在该平面上地心到零度经线的方向为X轴正方向,根据右手定则确定Y轴正方向。

设点A的三维坐标为(Ax,Ay,Az),点B的三维坐标为(Bx,By,Bz)

3.思路

A、B、O三点所在平面与地球相交形成一个半径为R的圆,求AB间的地面距离就是求该圆上圆弧AB的长度。可由弧长等于半径乘以圆心角公式求得。

由于R是确定的,只要获得OA与OB的夹角θ就可以获得弧AB的长度。弧AB=R*θ。
角θ可通过向量公式求得:

向量OA*向量OB=|OA||OB|cosθ。

cosθ=向量OA*向量OB/|OA||OB|
     =(Ax*Bx+Ay*By+Az*Bz)/R*R
登录后复制

4.用经纬度坐标表示三维直角坐标:

Ax=R*cosAw*cosAj
Ay=R*cosAw*sinAj
Az=R*sinAw
Bx=R*cosBw*cosBj
By=R*cosBw*sinBj
Bz=R*sinBw
登录后复制

代入可得

cosθ=cosAw*cosAj*cosBw*cosBj+cosAw*sinAj*cosBw*sinBj+sinAw*sinBw
     =cosAw*cosBw(cosAj*cosBj+sinAj*sinBj)+sinAw*sinBw
     =cosAw*cosBw*cos(Aj-Bj)+sinAw*sinBw
θ=arccos[cosAw*cosBw*cos(Aj-Bj)+sinAw*sinBw]
登录后复制

5.综上可得根据经纬度计算地面两点间距离的公式:

弧AB=R*arccos[cosAw*cosBw*cos(Aj-Bj)+sinAw*sinBw]
登录后复制

说明:

类似的公式推导大家以前都做过,时间久了可能会忘记一些东西,于是我把它记了下来,以备查阅。

由于三角函数变换多端,该公式的表现形式不止一种,只要前提假设是一样的,那么在数学上应该是等价并可相互推导的。
在实际程序代码中用的时候需要注意单位问题,比如从定位器获得的经纬度单位是度,而三角计算的方法很可能用的单位是弧度,再比如长度单位用的是km还是m等。

推荐:《编程视频

以上就是【数学公式及推导】根据经纬度计算地面两点间的距离的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:cnblogs网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
豆包 AI 助手文章总结
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号