pyephem恒星时间给出意想不到的结果

时间:2012-11-19 23:04:35

标签: python astronomy pyephem

我第一次使用ephem,并且无法理解oberver.sidereal_time()的输出

我写了几个脚本来确定从小时角度开始的太阳时间。第一个使用ephem来计算正确的提升,并使用Meeus的天文算法来获得格林威治的平均恒星时间,可以用经度转换为局部平均值。

import sys
from datetime import datetime, time, timedelta
import ephem

def hour_angle(dt, longit, latit, elev):
    obs = ephem.Observer()
    obs.date = dt.strftime('%Y/%m/%d %H:%M:%S')
    obs.lon = longit
    obs.lat = latit
    obs.elevation = elev
    sun = ephem.Sun()
    sun.compute(obs)
    # get right ascention
    ra = ephem.degrees(sun.g_ra)

    # get sidereal time at greenwich (AA ch12)
    jd = ephem.julian_date(dt)
    t = (jd - 2451545.0) / 36525
    theta = 280.46061837 + 360.98564736629 * (jd - 2451545) \
            + .000387933 * t**2 - t**3 / 38710000

    # hour angle (AA ch13)
    ha = (theta + longit - ra * 180 / ephem.pi) % 360
    return ha

def main():
    if len(sys.argv) != 6:
        print 'Usage: hour_angle.py [YYYY/MM/DD] [HH:MM:SS] [longitude] [latitude] [elev]'
        sys.exit()
    else:
        dt = datetime.strptime(sys.argv[1] + ' ' + sys.argv[2], '%Y/%m/%d %H:%M:%S')
        longit = float(sys.argv[3])
        latit = float(sys.argv[4])
        elev = float(sys.argv[5])

    # get hour angle
    ha = hour_angle(dt, longit, latit, elev)

    # convert hour angle to timedelta from noon
    days = ha / 360
    if days > 0.5:
        days -= 0.5
    td = timedelta(days=days)

    # make solar time
    solar_time = datetime.combine(dt.date(), time(12)) + td
    print solar_time

if __name__ == '__main__':
    main()

当我插入一些数据时,这会给出我期望的输出:

> python hour_angle_ephem.py 2012/11/16 20:34:56 -122.2697 37.8044 3.0
2012-11-16 12:40:54.697115

我编写的第二个脚本以相同的方式计算右上角,但使用ephem的sidereal_time()来获得当地明显的恒星时间。

import sys
from datetime import datetime, time, timedelta
import math
import ephem

def solartime(observer, sun=ephem.Sun()):
    sun.compute(observer)
    # sidereal time == ra (right ascension) is the highest point (noon)
    t = observer.sidereal_time() - sun.ra
    return ephem.hours(t + ephem.hours('12:00')).norm  # .norm for 0..24

def main():
    if len(sys.argv) != 6:
        print 'Usage: hour_angle.py [YYYY/MM/DD] [HH:MM:SS] [longitude] [latitude] [elev]'
        sys.exit()
    else:
        dt = datetime.strptime(sys.argv[1] + ' ' + sys.argv[2], '%Y/%m/%d %H:%M:%S')
        longit = float(sys.argv[3])
        latit = float(sys.argv[4])
        elev = float(sys.argv[5])

    obs = ephem.Observer()
    obs.date = dt.strftime('%Y/%m/%d %H:%M:%S')
    obs.lon = longit
    obs.lat = latit
    obs.elevation = elev
    solar_time = solartime(obs)
    print solar_time

if __name__ == '__main__':
    main()

这并没有让我得到我期望的输出。

python hour_angle_ephem2.py 2012/11/16 20:34:56 -122.2697 37.8044 3.0
9:47:50.83

AFAIK,这两个剧本之间的唯一区别是,当地平均恒星时间的第一个基准小时角度,而当地明显恒星时间的第二个基准小时角度,考虑到地球的章动,我认为应该是一个非常小的因素。相反,我看到差异大约三个小时。任何人都可以向我解释发生了什么事吗?

1 个答案:

答案 0 :(得分:2)

当你为PyEphem提供一个希望有一个角度的原始浮点数时,它会相信你已经将角度首先转换为弧度 - 因为它总是将浮点角度视为弧度,以保持一致。但是在你的第二个剧本中,你得到的是以度数表示的经度和纬度,并将它们提供给PyEphem,就好像它们是弧度一样。如果您添加print一两个语句,可以看到结果,以查看.lon的{​​{1}}和.lat属性的外观:

Observer

我认为你想要做的只是向PyEphem提供你的原始经度和纬度字符串,这样它就可以通过删除print observer.lon #--> -7005:32:16.0 print observer.lat #--> 2166:01:57.2 周围的float()调用将它们解释为人类可读的度数而不是机器可读的弧度。第二个脚本中的argv[3]argv[4]。然后,您应该发现它返回的值更接近您的预期:

$ python tmp11.py 2012/11/16 20:34:56 -122.2697 37.8044 3.0
12:40:55.59