astro/neptune/physical.go

40 lines
1.4 KiB
Go
Raw Normal View History

package neptune
import (
"time"
"b612.me/astro/basic"
)
// PhysicalInfo 海王星物理观测参数 / physical observing parameters of Neptune.
type PhysicalInfo struct {
// SubEarthLongitude 子地经度,单位度;采用 Neptune 当前 IAU/Horizons 西经为正约定。
SubEarthLongitude float64
// SubEarthLatitude 子地纬度,单位度。
SubEarthLatitude float64
// SubSolarLongitude 子日经度,单位度;采用 Neptune 当前 IAU/Horizons 西经为正约定。
SubSolarLongitude float64
// SubSolarLatitude 子日纬度,单位度。
SubSolarLatitude float64
// NorthPolePositionAngle 海王星北极位置角,单位度。
NorthPolePositionAngle float64
}
// Physical 海王星物理观测参数 / physical observing parameters of Neptune.
func Physical(date time.Time) PhysicalInfo {
return PhysicalN(date, -1)
}
// PhysicalN 海王星物理观测参数(截断版) / truncated physical observing parameters of Neptune.
func PhysicalN(date time.Time, n int) PhysicalInfo {
jde := basic.Date2JDE(date.UTC())
info := basic.NeptunePhysicalN(basic.TD2UT(jde, true), n)
return PhysicalInfo{
SubEarthLongitude: info.SubEarthLongitude,
SubEarthLatitude: info.SubEarthLatitude,
SubSolarLongitude: info.SubSolarLongitude,
SubSolarLatitude: info.SubSolarLatitude,
NorthPolePositionAngle: info.NorthPolePositionAngle,
}
}