pyproj 库中 Geod 类讲解

geod.inv 是 pyproj 库中 Geod 类的一个核心方法,用于执行 ​逆地理问题(Inverse Geodetic Problem)​ 的计算,即根据两个地理坐标点(经纬度)计算它们之间的 ​前向方位角、后向方位角和测地线距离。以下是其详细解析

1. 函数签名

python 复制代码
from pyproj import Geod

# 创建 Geod 对象(需指定地球椭球模型)
geod = Geod(ellps="WGS84")  # 默认使用 WGS84 椭球体

# 调用方法
forward_azimuth, back_azimuth, distance = geod.inv(lon1, lat1, lon2, lat2)

2. 参数说明

参数 类型 说明
lon1 float 第一个点的经度(单位:度,范围:-180 到 180 或 0 到 360)
lat1 float 第一个点的纬度(单位:度,范围:-90 到 90)
lon2 float 第二个点的经度(单位:度,范围:-180 到 180 或 0 到 360)
lat2 float 第二个点的纬度(单位:度,范围:-90 到 90)

3.返回值

返回值 类型 说明
forward_azimuth float 从第一个点到第二个点的​前向方位角​(单位:度,范围:0° 到 360°)
back_azimuth float 从第二个点返回到第一个点的​后向方位角​(单位:度,范围:0° 到 360°
distance float 两点之间的​测地线距离​(单位:米)

4.方位角定义

  • ​前向方位角 (forward_azimuth):

    从第一个点出发,指向第二个点的方向角度。

    • 0° 表示正北方向,90° 为正东,180° 为正南,270° 为正西。
  • ​后向方位角 (back_azimuth):

    从第二个点返回第一个点的方向角度,与前向方位角互补(±180°)

5.使用示例

计算北京到上海的方位角和距离

python 复制代码
from pyproj import Geod

# 初始化 Geod 对象
geod = Geod(ellps="WGS84")

# 北京天安门的坐标 (lon1, lat1)
beijing = (116.3975, 39.9085)

# 上海东方明珠的坐标 (lon2, lat2)
shanghai = (121.4997, 31.2397)

# 计算逆解
forward_az, back_az, distance = geod.inv(beijing[0], beijing[1], shanghai[0], shanghai[1])

print(f"前向方位角: {forward_az:.2f}°")  # 输出: 约 109.39°
print(f"后向方位角: {back_az:.2f}°")     # 输出: 约 290.62°
print(f"距离: {distance / 1000:.2f} 公里")  # 输出: 约 1076.06 公里

6.关键注意事项

  • ​椭球模型的选择:

    不同椭球模型(如 WGS84、GRS80)会影响计算结果精度。默认使用 WGS84,适用于 GPS 数据。

  • ​输入顺序:

    ​第一个点是起点,​第二个点是终点,顺序颠倒会导致方位角反转。

  • ​坐标范围:

    • 经度(lon)可以是 **-180 到 180** 或 0 到 360,但建议统一范围。
    • 纬度(lat)必须是 **-90 到 90**,超出范围会抛出异常。
  • ​重合点的处理:

    如果两点重合,distance 为 0,但方位角可能为 NaN(需代码容错)

7.总结

  • 功能:geod.inv 是地理空间分析的核心工具,用于计算两点间的方位角和测地距离。
  • ​适用场景:导航系统、路径规划、地理围栏、距离估算等。
  • ​精度保障:使用合适的椭球模型(如 WGS84)可确保高精度结果
相关推荐
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
TomCode先生1 小时前
c#动态树形表达式详解
开发语言·c#
高-老师2 小时前
基于R语言的物种气候生态位动态量化与分布特征模拟
开发语言·r语言·物种气候
大翻哥哥2 小时前
Python 2025:量化金融与智能交易的新纪元
开发语言·python·金融
weixin_437830943 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
鹿鹿学长3 小时前
2025年全国大学生数学建模竞赛(C题) 建模解析|婴儿染色体数学建模|小鹿学长带队指引全代码文章与思路
c语言·开发语言·数学建模
zhousenshan4 小时前
Python爬虫常用框架
开发语言·爬虫·python
IMER SIMPLE4 小时前
人工智能-python-深度学习-经典神经网络AlexNet
人工智能·python·深度学习
CodeCraft Studio4 小时前
国产化Word处理组件Spire.DOC教程:使用 Python 将 Markdown 转换为 HTML 的详细教程
python·html·word·markdown·国产化·spire.doc·文档格式转换
DKPT5 小时前
Java内存区域与内存溢出
java·开发语言·jvm·笔记·学习