如何从enu向量获得方位角和高程

问题描述 投票:1回答:1

你如何从一个enu向量到另一个enu向量得到方位角和高程?

指向公式或代码段的链接会很有帮助。我在搜索时根本没有得到太多信息。

gis data-conversion elevation azimuth
1个回答
0
投票

您可以使用以下方法计算East-North-Up向量(x,y,z)(u,v,w)之间的方位角和仰角:

  1. 减去向量:(x,y,z) - (u,v,w) = (x-u,y-v,z-w) = (x',y',z')
  2. 计算方位角:a = arctan(x'/y') = arctan((x-u)/(y-v))
  3. 计算仰角:e = arctan(z'/y') = arctan((z-w)/(y-v))

在Python中:

v1 = np.array([3,4,4])
v2 = np.array([1,2,6])
v = v1 - v2

a = np.degrees(np.arctan(v[0]/v[1]))
e = np.degrees(np.arctan(v[2]/v[1]))

print('azimuth = '+str(a)+', elevation = '+str(e))

输出:

azimuth = 45.0, elevation = -45.0

Azimuth and Elevation

(Image Source)

© www.soinside.com 2019 - 2024. All rights reserved.