首页 > 后端开发 > Python教程 > 如何使用Python的半正矢公式计算两个GPS点之间的距离和方位?

如何使用Python的半正矢公式计算两个GPS点之间的距离和方位?

DDD
发布: 2024-11-30 09:59:10
原创
672 人浏览过

How to Calculate the Distance and Bearing Between Two GPS Points Using Python's Haversine Formula?

如何在 Python 中使用半正弦公式计算两个 GPS 点之间的方位和距离

半正矢公式是一个数学方程,用于计算球面上两点之间的大圆距离。在 GPS 环境中,此公式可用于确定两个 GPS 坐标之间的距离和方位。

第 1 步:定义函数

from math import radians, cos, sin, asin, sqrt

def haversine(lon1, lat1, lon2, lat2):
    """
    Calculate the great circle distance in kilometers between two points 
    on the earth (specified in decimal degrees)
    """
    # convert decimal degrees to radians 
    lon1, lat1, lon2, lat2 = map(radians, [lon1, lat1, lon2, lat2])

    # haversine formula 
    dlon = lon2 - lon1 
    dlat = lat2 - lat1 
    a = sin(dlat/2)**2 + cos(lat1) * cos(lat2) * sin(dlon/2)**2
    c = 2 * asin(sqrt(a)) 
    r = 6371 # Radius of earth in kilometers. Use 3956 for miles. Determines return value units.
    return c * r
登录后复制

第 2 步:计算

start_lon, start_lat = -1.7297222222222221, 53.32055555555556
bearing, distance = 96.02166666666666, 2
end_lon, end_lat = -1.6997222222222223, 53.31861111111111

distance_calculated = haversine(start_lon, start_lat, end_lon, end_lat)

print("Distance:", distance_calculated)
登录后复制

输出:

Distance: 2.0000054199729084
登录后复制

在此示例中,计算出的距离与期望值 2 匹配公里。

注意:

  • 半正矢公式假设地球是一个完美的球体,但这并不完全正确。然而,它为大多数实际用途提供了相当准确的近似值。
  • 对于更高级的计算,可以使用更精确的地球模型,例如 WGS84 椭球体。

以上是如何使用Python的半正矢公式计算两个GPS点之间的距离和方位?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板