update moon

This commit is contained in:
2023-12-06 07:58:11 +08:00
parent 2db30bfd92
commit c2c79c3615
+31 -22
View File
@@ -91,9 +91,10 @@ func ApparentRaDec(date time.Time, lon, lat float64) (float64, float64) {
} }
// HourAngle 月亮时角 // HourAngle 月亮时角
// date, 世界时(忽略此处时区) //
// lon,经度,东正西负 // date, 世界时(忽略此处时区)
// lat,纬度,北正南 // lon,经度,东正西
// lat,纬度,北正南负
func HourAngle(date time.Time, lon, lat float64) float64 { func HourAngle(date time.Time, lon, lat float64) float64 {
jde := basic.Date2JDE(date) jde := basic.Date2JDE(date)
_, loc := date.Zone() _, loc := date.Zone()
@@ -101,9 +102,10 @@ func HourAngle(date time.Time, lon, lat float64) float64 {
} }
// Azimuth 月亮方位角 // Azimuth 月亮方位角
// date, 世界时(忽略此处时区) //
// lon,经度,东正西负 // date, 世界时(忽略此处时区)
// lat,纬度,北正南 // lon,经度,东正西
// lat,纬度,北正南负
func Azimuth(date time.Time, lon, lat float64) float64 { func Azimuth(date time.Time, lon, lat float64) float64 {
jde := basic.Date2JDE(date) jde := basic.Date2JDE(date)
_, loc := date.Zone() _, loc := date.Zone()
@@ -111,9 +113,10 @@ func Azimuth(date time.Time, lon, lat float64) float64 {
} }
// Zenith 月亮高度角 // Zenith 月亮高度角
// date, 世界时(忽略此处时区) //
// lon,经度,东正西负 // date, 世界时(忽略此处时区)
// lat,纬度,北正南 // lon,经度,东正西
// lat,纬度,北正南负
func Zenith(date time.Time, lon, lat float64) float64 { func Zenith(date time.Time, lon, lat float64) float64 {
jde := basic.Date2JDE(date) jde := basic.Date2JDE(date)
_, loc := date.Zone() _, loc := date.Zone()
@@ -121,21 +124,26 @@ func Zenith(date time.Time, lon, lat float64) float64 {
} }
// CulminationTime 月亮中天时间 // CulminationTime 月亮中天时间
// date, 世界时(忽略此处时区) //
// lon,经度,东正西负 // date, 世界时(忽略此处时区)
// lat,纬度,北正南 // lon,经度,东正西
// lat,纬度,北正南负
func CulminationTime(date time.Time, lon, lat float64) time.Time { func CulminationTime(date time.Time, lon, lat float64) time.Time {
if date.Hour() > 12 {
date = date.Add(time.Hour * -12)
}
jde := basic.Date2JDE(date) jde := basic.Date2JDE(date)
_, loc := date.Zone() _, loc := date.Zone()
return basic.JDE2DateByZone(basic.MoonCulminationTime(jde, lon, lat, float64(loc)/3600.0), date.Location(), true) return basic.JDE2DateByZone(basic.MoonCulminationTime(jde, lon, lat, float64(loc)/3600.0), date.Location(), true)
} }
// RiseTime 月亮升起时间 // RiseTime 月亮升起时间
// date, 世界时(忽略此处时区) //
// lon,经度,东正西负 // date, 世界时(忽略此处时区)
// lat,纬度,北正南 // lon,经度,东正西
// height,高度 // lat,纬度,北正南负
// aero,是否进行大气修正 // height,高度
// aero,是否进行大气修正
func RiseTime(date time.Time, lon, lat, height float64, aero bool) (time.Time, error) { func RiseTime(date time.Time, lon, lat, height float64, aero bool) (time.Time, error) {
var err error var err error
if date.Hour() > 12 { if date.Hour() > 12 {
@@ -162,11 +170,12 @@ func RiseTime(date time.Time, lon, lat, height float64, aero bool) (time.Time, e
} }
// DownTime 月亮降下时间 // DownTime 月亮降下时间
// date, 世界时(忽略此处时区) //
// lon,经度,东正西负 // date, 世界时(忽略此处时区)
// lat,纬度,北正南 // lon,经度,东正西
// height,高度 // lat,纬度,北正南负
// aero,大气修正 // height,高度
// aero,大气修正
func DownTime(date time.Time, lon, lat, height float64, aero bool) (time.Time, error) { func DownTime(date time.Time, lon, lat, height float64, aero bool) (time.Time, error) {
var err error var err error
if date.Hour() > 12 { if date.Hour() > 12 {