astro/moon/moon.go

204 lines
5.4 KiB
Go
Raw Normal View History

2019-10-24 10:44:21 +08:00
package moon
import (
"errors"
2020-07-14 15:38:51 +08:00
"time"
2019-10-24 10:44:21 +08:00
"b612.me/astro/basic"
)
2020-07-14 15:38:51 +08:00
var (
ERR_MOON_NEVER_RISE = errors.New("ERROR:极夜,月亮在今日永远在地平线下!")
ERR_MOON_NEVER_DOWN = errors.New("ERROR:极昼,月亮在今日永远在地平线上!")
ERR_NOT_TODAY = errors.New("ERROR:月亮已在(昨日/明日)(升起/降下)")
)
// TrueLo 月亮真黄经
func TrueLo(date time.Time) float64 {
jde := basic.Date2JDE(date.UTC())
2019-10-24 10:44:21 +08:00
return basic.HMoonTrueLo(basic.TD2UT(jde, true))
}
2020-07-14 15:38:51 +08:00
// TrueBo 月亮真黄纬
func TrueBo(date time.Time) float64 {
jde := basic.Date2JDE(date.UTC())
return basic.HMoonTrueBo(basic.TD2UT(jde, true))
}
// SeeLo 月亮视黄经(地心)
// 传入UTC对应的儒略日时间
func SeeLo(date time.Time) float64 {
jde := basic.Date2JDE(date.UTC())
2019-10-24 10:44:21 +08:00
return basic.HMoonSeeLo(basic.TD2UT(jde, true))
}
2020-07-14 15:38:51 +08:00
// SeeRa 月亮视赤经(站心)
2020-12-31 09:07:54 +08:00
// date, 时间
2020-07-14 15:38:51 +08:00
// lon, 经度
// lat, 纬度
// 返回站心坐标
2020-12-31 09:07:54 +08:00
func SeeRa(date time.Time, lon, lat float64) float64 {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.HMoonSeeRa(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// SeeDec 月亮视赤纬(站心)
2020-12-31 09:07:54 +08:00
// date, 时间
2020-07-14 15:38:51 +08:00
// lon, 经度
// lat, 纬度
// 返回站心坐标
2020-12-31 09:07:54 +08:00
func SeeDec(date time.Time, lon, lat float64) float64 {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.HMoonSeeDec(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// SeeRaDec 月亮视赤纬(站心)
2020-12-31 09:07:54 +08:00
// date, 本地时间
2020-07-14 15:38:51 +08:00
// lon, 经度
// lat, 纬度
// 返回站心坐标
2020-12-31 09:07:54 +08:00
func SeeRaDec(date time.Time, lon, lat float64) (float64, float64) {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.HMoonSeeRaDec(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// HourAngle 月亮时角
// date, 世界时(忽略此处时区)
// lon经度东正西负
// lat纬度北正南负
2020-12-31 09:07:54 +08:00
func HourAngle(date time.Time, lon, lat float64) float64 {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.MoonTimeAngle(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// Azimuth 月亮方位角
// date, 世界时(忽略此处时区)
// lon经度东正西负
// lat纬度北正南负
2020-12-31 09:07:54 +08:00
func Azimuth(date time.Time, lon, lat float64) float64 {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.HMoonAngle(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// Zenith 月亮高度角
// date, 世界时(忽略此处时区)
// lon经度东正西负
// lat纬度北正南负
2020-12-31 10:08:00 +08:00
func Zenith(date time.Time, lon, lat float64) float64 {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.HMoonHeight(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// CulminationTime 月亮中天时间
// date, 世界时(忽略此处时区)
// lon经度东正西负
// lat纬度北正南负
2020-12-31 09:07:54 +08:00
func CulminationTime(date time.Time, lon, lat float64) float64 {
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
return basic.GetMoonTZTime(jde, lon, lat, float64(loc)/3600.0)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// RiseTime 月亮升起时间
// date, 世界时(忽略此处时区)
// lon经度东正西负
// lat纬度北正南负
2020-12-31 09:07:54 +08:00
func RiseTime(date time.Time, lon, lat float64, aero bool) (time.Time, error) {
2020-07-14 15:38:51 +08:00
var err error
2021-03-04 17:27:33 +08:00
if date.Hour() > 12 {
date = date.Add(time.Hour * -12)
}
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
timezone := float64(loc) / 3600.0
2020-07-14 15:38:51 +08:00
aeroFloat := 0.00
2019-10-24 10:44:21 +08:00
if aero {
2020-07-14 15:38:51 +08:00
aeroFloat = 1
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
riseJde := basic.GetMoonRiseTime(jde, lon, lat, timezone, aeroFloat)
if riseJde == -3 {
err = ERR_NOT_TODAY
2019-11-04 19:18:45 +08:00
}
2020-07-14 15:38:51 +08:00
if riseJde == -2 {
err = ERR_MOON_NEVER_RISE
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
if riseJde == -1 {
err = ERR_MOON_NEVER_DOWN
2019-10-24 10:44:21 +08:00
}
2021-03-04 17:27:33 +08:00
return basic.JDE2DateByZone(riseJde, date.Location(), true), err
2020-07-14 15:38:51 +08:00
}
// DownTime 月亮降下时间
// date, 世界时(忽略此处时区)
// lon经度东正西负
// lat纬度北正南负
2020-12-31 09:07:54 +08:00
func DownTime(date time.Time, lon, lat float64, aero bool) (time.Time, error) {
2020-07-14 15:38:51 +08:00
var err error
2021-03-04 17:27:33 +08:00
if date.Hour() > 12 {
date = date.Add(time.Hour * -12)
}
2020-07-14 15:38:51 +08:00
jde := basic.Date2JDE(date)
2020-12-31 09:07:54 +08:00
_, loc := date.Zone()
timezone := float64(loc) / 3600.0
2020-07-14 15:38:51 +08:00
aeroFloat := 0.00
2019-10-24 10:44:21 +08:00
if aero {
2020-07-14 15:38:51 +08:00
aeroFloat = 1
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
downJde := basic.GetMoonDownTime(jde, lon, lat, timezone, aeroFloat)
if downJde == -3 {
err = ERR_NOT_TODAY
2019-11-04 19:18:45 +08:00
}
2020-07-14 15:38:51 +08:00
if downJde == -2 {
err = ERR_MOON_NEVER_RISE
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
if downJde == -1 {
err = ERR_MOON_NEVER_DOWN
2019-10-24 10:44:21 +08:00
}
2021-03-04 17:27:33 +08:00
return basic.JDE2DateByZone(downJde, date.Location(), true), err
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// Phase 月相
// 返回Date对应UTC世界时的月相大小
func Phase(date time.Time) float64 {
jde := basic.Date2JDE(date.UTC())
2019-10-24 10:44:21 +08:00
return basic.MoonLight(basic.TD2UT(jde, true))
}
2020-07-14 15:38:51 +08:00
// ShuoYue 朔月
2020-12-31 09:07:54 +08:00
func ShuoYue(year float64) time.Time {
jde := basic.TD2UT(basic.CalcMoonSH(year, 0), false)
2021-03-04 17:27:33 +08:00
return basic.JDE2DateByZone(jde, time.UTC, false)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// WangYue 望月
2020-12-31 09:07:54 +08:00
func WangYue(year float64) time.Time {
jde := basic.TD2UT(basic.CalcMoonSH(year, 1), false)
2021-03-04 17:27:33 +08:00
return basic.JDE2DateByZone(jde, time.UTC, false)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// ShangXianYue 上弦月
2020-12-31 09:07:54 +08:00
func ShangXianYue(year float64) time.Time {
jde := basic.TD2UT(basic.CalcMoonXH(year, 0), false)
2021-03-04 17:27:33 +08:00
return basic.JDE2DateByZone(jde, time.UTC, false)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// XiaXianYue 下弦月
2020-12-31 09:07:54 +08:00
func XiaXianYue(year float64) time.Time {
jde := basic.TD2UT(basic.CalcMoonXH(year, 1), false)
2021-03-04 17:27:33 +08:00
return basic.JDE2DateByZone(jde, time.UTC, false)
2019-10-24 10:44:21 +08:00
}
2020-07-14 15:38:51 +08:00
// EarthDistance 日地距离
// 返回date对应UTC世界时日地距离
func EarthDistance(date time.Time) float64 {
jde := basic.Date2JDE(date)
jde = basic.TD2UT(jde, true)
return basic.MoonAway(jde)
}