编程语言
首页 > 编程语言> > python – pyephem计算仰角

python – pyephem计算仰角

作者:互联网

我想在特定观察者的作用下,使用库PyEphem轻松计算python中卫星的仰角.
这件事对我来说真的很新,所以我使用下面的图片来确定我们正在谈论同样的事情.

enter image description here

简而言之,我必须为不同的观察者计算基于TLE的卫星传递,因为他们必须与之通信.但是为了确保他们能够与卫星通信,他们可以指定他们想要的最小仰角.

直到现在,我能够计算卫星的下一次通过,卫星的高度(以米为单位)以及卫星和观察者之间的距离在这里是我的代码(我知道我不是在计算起点的距离)下一次通过,但只是从第二次到第二次):

#satellite
satellite = ephem.readtle(str1, str2, str3)

#observer
guy = ephem.Observer()
guy.lon, guy.lat = str(long), str(lat)
guy.date = datetime.datetime.now()

#next passes
next_pass = guy.next_pass(satellite)
print ("NEXT PASS: ", next_pass)
nb_passes = 250
previous_pass = next_pass

for i in range(0, nb_passes):
    #take satelite downset + 1 second and compute next pass
    guy.date = previous_pass[4].datetime() + datetime.timedelta(0, 1)
    np = guy.next_pass(satellite)
    print np
    #compute the satellite.range at the beginning of the pass
    guy.date = np[0].datetime()
    satellite.compute(guy)
    #elevation in meter
    print 'elevation satellite: ', satellite.elevation
    print 'distance staletlite to guy: ', satellite.range
    print 'elev guy: ', guy.elev
    print 'elevation guy: ', guy.elevation
    previous_pass = np

PyEphem中有什么东西来计算仰角吗? (我已经阅读了文档(不是全部),但我没有找到它)

在2d投影上,应该很容易用正弦计算它,因为我们有一个直角三角形,有一个已知的相对侧(卫星的高度)和一个已知的斜边(观察者和通道开始时卫星之间的距离) .但我们在3D上,所以它是最复杂的.

你有一个简单的计算方法吗?

解决方法:

如果您使用.alt询问卫星的高度角,那么您应该得到图中称为“高程”的值:

print 'angle above the horizon:', satellite.alt

高度alt是一对坐标中的一个,另一个是az方位角.高度和方位角一起告诉观察者在哪里可以看到它们上方的天空.一些望远镜使用这种系统,被称为“altazimuth”望远镜.

这里的混乱是地球卫星社区的工程师选择了“海拔”这个词来表示卫星在地平线上的高度,也许不知道在科学中,天文学家已经为这个角度命名了“高度”.

有关天文高度和方位角的更多详细信息,请参阅:

https://en.wikipedia.org/wiki/Horizontal_coordinate_system

标签:python,pyephem,satellite
来源: https://codeday.me/bug/20190702/1357755.html