如何在天空中找到卫星相对速度?

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

我需要找到卫星相对于我移动的速度。我在考虑使用Python包'skyfield',但我不知道如何计算:

from skyfield.api import EarthSatellite, Topos
import skyfield.api

sat = EarthSatellite('1 43700U 18090A   18335.89431171 +.00000133 +00000-0 +00000-0 0  9993',
                 '2 43700 000.0858 245.4352 0001094 006.6237 164.6135 01.00274015000309')
time_scale = skyfield.api.load.timescale()
time0 = time_scale.utc(2018, 12, 1, 21, 0, 0)
position0 = sat.at(time0)
position0_ITRF = sat.ITRF_position_velocity_error(time0)[:2]

my_loc = Topos('39.0 N', '105.0 W')

我不知道如何将my_loc转换为相应的位置,以便我可以计算相对卫星速度。我应该使用具有更多功能的不同包吗?

python satellite skyfield satellite-navigation
1个回答
1
投票

如果你问“my_loc在哪里time0

position1 = my_loc.at(time0)

那么你将有另一个位置对象与.velocity,你应该能够与你的卫星的速度进行比较。你也可以事先做减法:

relative_position = (sat - my_loc).at(time0)

然后,生成的对象的.position.velocity都应该相对于您的位置,而不必自己减去它们。

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