gpt4 book ai didi

python - 如何对可观察坐标列表进行排序?

转载 作者:行者123 更新时间:2023-12-01 04:03:56 24 4
gpt4 key购买 nike

我正在努力寻找从坐标列表中删除不需要的目标的最佳方法。我的坐标(Ra,Dec)是使用 astropy.coordinates.SkyCoord 形成的,但我有大量无法观测的目标,它们的磁偏角太低,所以我想做的是对我的坐标进行排序例如,列出并删除所有偏角低于 -10 度的目标(因为我的望远镜位于北半球)。

这是我生成列表的代码行,为了简化起见,它被称为 radecs 并从天球坐标获取 Ra 和 Dec。

radecs = astropy.coordinates.SkyCoord(ra=phi*u.rad, dec=(0.5*np.pi - theta)*u.rad)

这是一个如何在 Python 中输出我的坐标列表的示例。

<SkyCoord (ICRS): (ra, dec) in deg
[(45.0, 60.0), (135.0, 45.0), (225.0, 25.0), ...,
(135.0, 55.0), (225.0, 70.0), (315.0, -20.0)]>

最佳答案

我将说明如何在某些任意坐标上使用带有 bool 掩码的 numpy 索引:

from astropy.coordinates import SkyCoord
import astropy.units as u
import numpy as np
phi = np.linspace(0,2*np.pi,20)
theta = np.linspace(0, np.pi, 20)
radecs = SkyCoord(ra=phi*u.rad, dec=(0.5*np.pi - theta)*u.rad)
radecs

给我radecs:

<SkyCoord (ICRS): (ra, dec) in deg
[(0.0, 90.0), (18.94736842, 80.52631579), (37.89473684, 71.05263158),
(56.84210526, 61.57894737), (75.78947368, 52.10526316),
(94.73684211, 42.63157895), (113.68421053, 33.15789474),
(132.63157895, 23.68421053), (151.57894737, 14.21052632),
(170.52631579, 4.73684211), (189.47368421, -4.73684211),
(208.42105263, -14.21052632), (227.36842105, -23.68421053),
(246.31578947, -33.15789474), (265.26315789, -42.63157895),
(284.21052632, -52.10526316), (303.15789474, -61.57894737),
(322.10526316, -71.05263158), (341.05263158, -80.52631579),
(0.0, -90.0)]>

要获取radecsdec(赤纬),您可以访问该属性:

radecs.dec

[90, 80.526316, 71.052632, 61.578947, 52.105263, 42.631579, 33.157895, 23.684211, 14.210526, 4.7368421, −4.7368421, −14.210526, −23.684211, −33.157895, −42.631579, −52.105263, −61.578947, −71.052632, −80.526316, −90]

因此我们可以通过创建掩码来访问偏角高于 -10 度的所有目标:

radecs.dec > - 10 * u.degree

然后索引满足此掩码的所有目标:

radecs2 = radecs[radecs.dec > - 10 * u.degree]

给我以下radecs2:

<SkyCoord (ICRS): (ra, dec) in deg
[(0.0, 90.0), (18.94736842, 80.52631579), (37.89473684, 71.05263158),
(56.84210526, 61.57894737), (75.78947368, 52.10526316),
(94.73684211, 42.63157895), (113.68421053, 33.15789474),
(132.63157895, 23.68421053), (151.57894737, 14.21052632),
(170.52631579, 4.73684211), (189.47368421, -4.73684211)]>

本质上,您所做的只是最后一步 (radecs2 = radecs[radecs.dec > - 10 * u. Degree]),所有其他步骤都只是解释性的。

关于python - 如何对可观察坐标列表进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35991109/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com