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

一句话,我必须计算卫星的通过,基于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 = npPyEphem中有什么东西可以计算仰角吗?(我看过文件(不是全部),但没有找到)
在2d投影中,应该很容易用正弦来计算它,因为我们有一个直角三角形(卫星的仰角)和一个已知的低音值(观测器和卫星之间的距离)。但我们是3d的,所以这很复杂。
你有一个简单的方法来计算它吗?
发布于 2015-10-04 01:01:03
如果您将使用satellite向.alt询问其高度角,那么您应该得到在您的图表中称为“高程”的值:
print 'angle above the horizon:', satellite.alt高度alt是一对坐标中的一个,另一个是az的方位角。高度和方位角一起告诉观察者在他们上面的天空中的位置。有些望远镜使用这个系统,被称为“方位角”望远镜。
令人困惑的是,地球卫星的工程师们选择了“高度”这个词来表示一颗卫星在地平线上的高度,也许并不知道在科学上,天文学家已经为这个角度取了一个名字“高度”。
有关天文高度和方位的更多细节,请参见:
https://stackoverflow.com/questions/32905998
复制相似问题