2019-10-24 10:44:21 +08:00
|
|
|
|
package basic
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
"b612.me/astro/planet"
|
|
|
|
|
|
. "b612.me/astro/tools"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
2025-09-18 13:16:04 +08:00
|
|
|
|
// SunLo 太阳几何黄经
|
2019-10-24 10:44:21 +08:00
|
|
|
|
func SunLo(jd float64) float64 {
|
2026-05-01 22:38:44 +08:00
|
|
|
|
return planet.SunLo(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunM(jd float64) float64 {
|
|
|
|
|
|
return planet.SunM(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
2024-01-15 17:05:18 +08:00
|
|
|
|
@name 地球偏心率
|
2019-10-24 10:44:21 +08:00
|
|
|
|
*/
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func Earthe(jd float64) float64 { //'地球偏心率
|
|
|
|
|
|
return planet.Earthe(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func EarthPI(jd float64) float64 { //近日點經度
|
|
|
|
|
|
return planet.EarthPI(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
2025-09-18 13:16:04 +08:00
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunMidFun(jd float64) float64 { //'太阳中间方程
|
|
|
|
|
|
return planet.SunMidFun(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
2025-09-18 13:16:04 +08:00
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunTrueLo(jd float64) float64 { // '太阳真黄经
|
|
|
|
|
|
return planet.SunTrueLo(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunApparentLo(jd float64) float64 { //'太阳视黄经
|
|
|
|
|
|
return planet.SunApparentLo(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunApparentRa(jd float64) float64 { // '太阳视赤经
|
|
|
|
|
|
return LoToRa(jd, SunApparentLo(jd), 0)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunApparentRaDec(jd float64) (float64, float64) {
|
|
|
|
|
|
return LoBoToRaDec(jd, SunApparentLo(jd), 0)
|
2024-01-15 17:05:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunTrueRa(jd float64) float64 { //'太阳真赤经
|
|
|
|
|
|
eps := TrueObliquity(jd)
|
|
|
|
|
|
sunTrueRa := ArcTan(Cos(eps) * Sin(SunTrueLo(jd)) / Cos(SunTrueLo(jd)))
|
2019-10-24 10:44:21 +08:00
|
|
|
|
//Select Case SunTrueLo(JD)
|
2026-05-01 22:38:44 +08:00
|
|
|
|
sunTrueLo := SunTrueLo(jd)
|
|
|
|
|
|
if sunTrueLo >= 90 && sunTrueLo < 180 {
|
2025-09-18 13:16:04 +08:00
|
|
|
|
sunTrueRa = 180 + sunTrueRa
|
2026-05-01 22:38:44 +08:00
|
|
|
|
} else if sunTrueLo >= 180 && sunTrueLo < 270 {
|
2025-09-18 13:16:04 +08:00
|
|
|
|
sunTrueRa = 180 + sunTrueRa
|
2026-05-01 22:38:44 +08:00
|
|
|
|
} else if sunTrueLo >= 270 && sunTrueLo <= 360 {
|
2025-09-18 13:16:04 +08:00
|
|
|
|
sunTrueRa = 360 + sunTrueRa
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
2025-09-18 13:16:04 +08:00
|
|
|
|
return sunTrueRa
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunApparentDec(jd float64) float64 { // '太阳视赤纬
|
|
|
|
|
|
t := (jd - 2451545) / 36525
|
|
|
|
|
|
eps := TrueObliquity(jd) + 0.00256*Cos(125.04-1934.136*t)
|
|
|
|
|
|
sunApparentDec := ArcSin(Sin(eps) * Sin(SunApparentLo(jd)))
|
|
|
|
|
|
return sunApparentDec
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func SunTrueDec(jd float64) float64 { // '太阳真赤纬
|
|
|
|
|
|
eps := TrueObliquity(jd)
|
|
|
|
|
|
sunTrueDec := ArcSin(Sin(eps) * Sin(SunTrueLo(jd)))
|
|
|
|
|
|
return sunTrueDec
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunTime(jd float64) float64 { //均时差
|
|
|
|
|
|
tm := (SunLo(jd) - 0.0057183 - (HSunApparentRa(jd)) + (Nutation2000Bi(jd))*Cos(TrueObliquity(jd))) / 15
|
|
|
|
|
|
if tm > 23 {
|
|
|
|
|
|
tm = -24 + tm
|
|
|
|
|
|
}
|
|
|
|
|
|
return tm
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunTimeN(jd float64, n int) float64 { //均时差
|
|
|
|
|
|
tm := (SunLo(jd) - 0.0057183 - (HSunApparentRaN(jd, n)) + (Nutation2000Bi(jd))*Cos(TrueObliquity(jd))) / 15
|
2019-10-24 10:44:21 +08:00
|
|
|
|
if tm > 23 {
|
|
|
|
|
|
tm = -24 + tm
|
|
|
|
|
|
}
|
|
|
|
|
|
return tm
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunSC(lo, jd float64) float64 { //黄道上的岁差,仅黄纬=0时
|
|
|
|
|
|
t := (jd - 2451545) / 36525
|
2019-10-24 10:44:21 +08:00
|
|
|
|
//n := 47.0029/3600*t - 0.03302/3600*t*t + 0.000060/3600*t*t*t
|
|
|
|
|
|
//m := 174.876384/3600 - 869.8089/3600*t + 0.03536/3600*t*t
|
|
|
|
|
|
pk := 5029.0966/3600.00*t + 1.11113/3600.00*t*t - 0.000006/3600.00*t*t*t
|
2026-05-01 22:38:44 +08:00
|
|
|
|
return lo + pk
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-09-18 13:16:04 +08:00
|
|
|
|
// 高精度,使用VSOP87
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunTrueLo(jd float64) float64 {
|
|
|
|
|
|
return HSunTrueLoN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
// HSunTrueLoN 高精度太阳真黄经,n<0 时取全量 VSOP 项。
|
|
|
|
|
|
func HSunTrueLoN(jd float64, n int) float64 {
|
|
|
|
|
|
return planet.WherePlanetN(0, 0, jd, n)
|
2020-07-14 15:38:51 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunTrueBo(jd float64) float64 {
|
|
|
|
|
|
return HSunTrueBoN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
// HSunTrueBoN 高精度太阳真黄纬,n<0 时取全量 VSOP 项。
|
|
|
|
|
|
func HSunTrueBoN(jd float64, n int) float64 {
|
|
|
|
|
|
return planet.WherePlanetN(0, 1, jd, n)
|
2020-07-14 15:38:51 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentLo(jd float64) float64 {
|
|
|
|
|
|
return HSunApparentLoN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentLoN(jd float64, n int) float64 {
|
|
|
|
|
|
lo := HSunTrueLoN(jd, n)
|
|
|
|
|
|
lo = lo + Nutation2000Bi(jd) + SunLoGXCN(jd, n)
|
|
|
|
|
|
return lo
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunLoGXC(jd float64) float64 {
|
|
|
|
|
|
return SunLoGXCN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func SunLoGXCN(jd float64, n int) float64 {
|
|
|
|
|
|
radius := EarthAwayN(jd, n)
|
|
|
|
|
|
return -20.49552 / radius / 3600
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func EarthAway(jd float64) float64 {
|
|
|
|
|
|
return EarthAwayN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func EarthAwayN(jd float64, n int) float64 {
|
|
|
|
|
|
return planet.WherePlanetN(0, 2, jd, n)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentRaDec(jd float64) (float64, float64) {
|
|
|
|
|
|
return HSunApparentRaDecN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentRaDecN(jd float64, n int) (float64, float64) {
|
|
|
|
|
|
return LoBoToRaDec(jd, HSunApparentLoN(jd, n), HSunTrueBoN(jd, n))
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentRa(jd float64) float64 { // '太阳视赤经
|
|
|
|
|
|
return HSunApparentRaN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentRaN(jd float64, n int) float64 { // '太阳视赤经
|
|
|
|
|
|
return LoToRa(jd, HSunApparentLoN(jd, n), HSunTrueBoN(jd, n))
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunTrueRa(jd float64) float64 {
|
|
|
|
|
|
return HSunTrueRaN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunTrueRaN(jd float64, n int) float64 {
|
|
|
|
|
|
sunTrueLo := HSunTrueLoN(jd, n)
|
|
|
|
|
|
eps := TrueObliquity(jd)
|
2025-09-18 13:16:04 +08:00
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
numerator := Cos(eps) * Sin(sunTrueLo)
|
|
|
|
|
|
denominator := Cos(sunTrueLo)
|
2025-09-18 13:16:04 +08:00
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
return ArcTan2(numerator, denominator)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentDec(jd float64) float64 { // '太阳视赤纬
|
|
|
|
|
|
return HSunApparentDecN(jd, -1)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunApparentDecN(jd float64, n int) float64 { // '太阳视赤纬
|
|
|
|
|
|
return ArcSin(Sin(EclipticObliquity(jd, true)) * Sin(HSunApparentLoN(jd, n)))
|
2025-09-15 20:55:38 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunTrueDec(jd float64) float64 { // '太阳真赤纬
|
|
|
|
|
|
return HSunTrueDecN(jd, -1)
|
2025-09-15 20:55:38 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func HSunTrueDecN(jd float64, n int) float64 { // '太阳真赤纬
|
|
|
|
|
|
return ArcSin(Sin(EclipticObliquity(jd, false)) * Sin(HSunTrueLoN(jd, n)))
|
2025-09-15 20:55:38 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-05-01 22:38:44 +08:00
|
|
|
|
func Distance(jd float64) float64 { //ri di ju li
|
|
|
|
|
|
return planet.Distance(jd)
|
2019-10-24 10:44:21 +08:00
|
|
|
|
}
|