astro/basic/sun.go

195 lines
4.7 KiB
Go
Raw Normal View History

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 {
return planet.SunLo(jd)
2019-10-24 10:44:21 +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
*/
func Earthe(jd float64) float64 { //'地球偏心率
return planet.Earthe(jd)
2019-10-24 10:44:21 +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
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
func SunTrueLo(jd float64) float64 { // '太阳真黄经
return planet.SunTrueLo(jd)
2019-10-24 10:44:21 +08:00
}
func SunApparentLo(jd float64) float64 { //'太阳视黄经
return planet.SunApparentLo(jd)
2019-10-24 10:44:21 +08:00
}
func SunApparentRa(jd float64) float64 { // '太阳视赤经
return LoToRa(jd, SunApparentLo(jd), 0)
2019-10-24 10:44:21 +08:00
}
func SunApparentRaDec(jd float64) (float64, float64) {
return LoBoToRaDec(jd, SunApparentLo(jd), 0)
2024-01-15 17:05:18 +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)
sunTrueLo := SunTrueLo(jd)
if sunTrueLo >= 90 && sunTrueLo < 180 {
2025-09-18 13:16:04 +08:00
sunTrueRa = 180 + sunTrueRa
} else if sunTrueLo >= 180 && sunTrueLo < 270 {
2025-09-18 13:16:04 +08:00
sunTrueRa = 180 + sunTrueRa
} 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
}
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
}
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
}
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
}
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
return lo + pk
2019-10-24 10:44:21 +08:00
}
2025-09-18 13:16:04 +08:00
// 高精度使用VSOP87
func HSunTrueLo(jd float64) float64 {
return HSunTrueLoN(jd, -1)
2019-10-24 10:44:21 +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
}
func HSunTrueBo(jd float64) float64 {
return HSunTrueBoN(jd, -1)
2019-10-24 10:44:21 +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
}
func HSunApparentLo(jd float64) float64 {
return HSunApparentLoN(jd, -1)
2019-10-24 10:44:21 +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
}
func SunLoGXC(jd float64) float64 {
return SunLoGXCN(jd, -1)
2019-10-24 10:44:21 +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
}
func EarthAway(jd float64) float64 {
return EarthAwayN(jd, -1)
2019-10-24 10:44:21 +08:00
}
func EarthAwayN(jd float64, n int) float64 {
return planet.WherePlanetN(0, 2, jd, n)
2019-10-24 10:44:21 +08:00
}
func HSunApparentRaDec(jd float64) (float64, float64) {
return HSunApparentRaDecN(jd, -1)
2019-10-24 10:44:21 +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
}
func HSunApparentRa(jd float64) float64 { // '太阳视赤经
return HSunApparentRaN(jd, -1)
2019-10-24 10:44:21 +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
}
func HSunTrueRa(jd float64) float64 {
return HSunTrueRaN(jd, -1)
2019-10-24 10:44:21 +08:00
}
func HSunTrueRaN(jd float64, n int) float64 {
sunTrueLo := HSunTrueLoN(jd, n)
eps := TrueObliquity(jd)
2025-09-18 13:16:04 +08:00
numerator := Cos(eps) * Sin(sunTrueLo)
denominator := Cos(sunTrueLo)
2025-09-18 13:16:04 +08:00
return ArcTan2(numerator, denominator)
2019-10-24 10:44:21 +08:00
}
func HSunApparentDec(jd float64) float64 { // '太阳视赤纬
return HSunApparentDecN(jd, -1)
2019-10-24 10:44:21 +08:00
}
func HSunApparentDecN(jd float64, n int) float64 { // '太阳视赤纬
return ArcSin(Sin(EclipticObliquity(jd, true)) * Sin(HSunApparentLoN(jd, n)))
}
func HSunTrueDec(jd float64) float64 { // '太阳真赤纬
return HSunTrueDecN(jd, -1)
}
func HSunTrueDecN(jd float64, n int) float64 { // '太阳真赤纬
return ArcSin(Sin(EclipticObliquity(jd, false)) * Sin(HSunTrueLoN(jd, n)))
}
func Distance(jd float64) float64 { //ri di ju li
return planet.Distance(jd)
2019-10-24 10:44:21 +08:00
}