astro/moon/phase.go

35 lines
1.7 KiB
Go
Raw Normal View History

package moon
import (
"time"
"b612.me/astro/basic"
)
// BrightLimbPositionAngle 月亮明亮边缘位置角,单位度 / position angle of the Moon's bright limb in degrees.
func BrightLimbPositionAngle(date time.Time) float64 {
return BrightLimbPositionAngleN(date, -1)
}
// BrightLimbPositionAngleN 月亮明亮边缘位置角(截断版),单位度 / truncated position angle of the Moon's bright limb in degrees.
func BrightLimbPositionAngleN(date time.Time, n int) float64 {
return basic.MoonBrightLimbPositionAngleN(observationTT(date), n)
}
// TopocentricBrightLimbPositionAngle 月亮站心明亮边缘位置角,单位度 / topocentric position angle of the Moon's bright limb in degrees.
//
// date 为观测时刻observerLon/observerLat 为观测者经纬度东正西负、北正南负height 为海拔高度,单位米。
// date is the observing instant; observerLon/observerLat are east-positive and north-positive; height is observer elevation in meters.
func TopocentricBrightLimbPositionAngle(date time.Time, observerLon, observerLat, height float64) float64 {
return TopocentricBrightLimbPositionAngleN(date, observerLon, observerLat, height, -1)
}
// TopocentricBrightLimbPositionAngleN 月亮站心明亮边缘位置角(截断版),单位度 / truncated topocentric position angle of the Moon's bright limb in degrees.
func TopocentricBrightLimbPositionAngleN(date time.Time, observerLon, observerLat, height float64, n int) float64 {
return basic.MoonTopocentricBrightLimbPositionAngleN(observationTT(date), observerLon, observerLat, height, n)
}
func observationTT(date time.Time) float64 {
return basic.TD2UT(basic.Date2JDE(date.UTC()), true)
}