Files
astro/basic/sun.go
T
b612 3ffdbe0034 feat: 扩展天文计算能力
- 新增日食、月食、本地可见性、中心线、半影区域、SVG 图示与沙罗周期信息
- 新增行星冲合、留、方照、物理星历、视直径、相位、亮肢角、轨道节点等计算
- 新增木星伽利略卫星位置、现象与接触事件计算
- 新增恒星星表、星座判定、自行修正与观测辅助能力
- 新增 coord、formula、orbit、sundial、lite/sun、lite/moon 等扩展包
- 完善农历年号、月相英文别名、视差角、大气质量、折射、日晷与双星计算
- 增加 NASA、JPL Horizons、IMCCE 等回归测试数据与基线测试
- 重构基础算法文件组织,补充大量公开 API 注释和语义回归测试
- 更新中文和英文 README,补充示例、精度说明、SVG 配图
2026-05-01 22:38:44 +08:00

195 lines
4.7 KiB
Go

package basic
import (
"b612.me/astro/planet"
. "b612.me/astro/tools"
)
// SunLo 太阳几何黄经
func SunLo(jd float64) float64 {
return planet.SunLo(jd)
}
func SunM(jd float64) float64 {
return planet.SunM(jd)
}
/*
@name 地球偏心率
*/
func Earthe(jd float64) float64 { //'地球偏心率
return planet.Earthe(jd)
}
func EarthPI(jd float64) float64 { //近日點經度
return planet.EarthPI(jd)
}
func SunMidFun(jd float64) float64 { //'太阳中间方程
return planet.SunMidFun(jd)
}
func SunTrueLo(jd float64) float64 { // '太阳真黄经
return planet.SunTrueLo(jd)
}
func SunApparentLo(jd float64) float64 { //'太阳视黄经
return planet.SunApparentLo(jd)
}
func SunApparentRa(jd float64) float64 { // '太阳视赤经
return LoToRa(jd, SunApparentLo(jd), 0)
}
func SunApparentRaDec(jd float64) (float64, float64) {
return LoBoToRaDec(jd, SunApparentLo(jd), 0)
}
func SunTrueRa(jd float64) float64 { //'太阳真赤经
eps := TrueObliquity(jd)
sunTrueRa := ArcTan(Cos(eps) * Sin(SunTrueLo(jd)) / Cos(SunTrueLo(jd)))
//Select Case SunTrueLo(JD)
sunTrueLo := SunTrueLo(jd)
if sunTrueLo >= 90 && sunTrueLo < 180 {
sunTrueRa = 180 + sunTrueRa
} else if sunTrueLo >= 180 && sunTrueLo < 270 {
sunTrueRa = 180 + sunTrueRa
} else if sunTrueLo >= 270 && sunTrueLo <= 360 {
sunTrueRa = 360 + sunTrueRa
}
return sunTrueRa
}
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
}
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
}
func SunTimeN(jd float64, n int) float64 { //均时差
tm := (SunLo(jd) - 0.0057183 - (HSunApparentRaN(jd, n)) + (Nutation2000Bi(jd))*Cos(TrueObliquity(jd))) / 15
if tm > 23 {
tm = -24 + tm
}
return tm
}
func SunSC(lo, jd float64) float64 { //黄道上的岁差,仅黄纬=0时
t := (jd - 2451545) / 36525
//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
}
// 高精度,使用VSOP87
func HSunTrueLo(jd float64) float64 {
return HSunTrueLoN(jd, -1)
}
// HSunTrueLoN 高精度太阳真黄经,n<0 时取全量 VSOP 项。
func HSunTrueLoN(jd float64, n int) float64 {
return planet.WherePlanetN(0, 0, jd, n)
}
func HSunTrueBo(jd float64) float64 {
return HSunTrueBoN(jd, -1)
}
// HSunTrueBoN 高精度太阳真黄纬,n<0 时取全量 VSOP 项。
func HSunTrueBoN(jd float64, n int) float64 {
return planet.WherePlanetN(0, 1, jd, n)
}
func HSunApparentLo(jd float64) float64 {
return HSunApparentLoN(jd, -1)
}
func HSunApparentLoN(jd float64, n int) float64 {
lo := HSunTrueLoN(jd, n)
lo = lo + Nutation2000Bi(jd) + SunLoGXCN(jd, n)
return lo
}
func SunLoGXC(jd float64) float64 {
return SunLoGXCN(jd, -1)
}
func SunLoGXCN(jd float64, n int) float64 {
radius := EarthAwayN(jd, n)
return -20.49552 / radius / 3600
}
func EarthAway(jd float64) float64 {
return EarthAwayN(jd, -1)
}
func EarthAwayN(jd float64, n int) float64 {
return planet.WherePlanetN(0, 2, jd, n)
}
func HSunApparentRaDec(jd float64) (float64, float64) {
return HSunApparentRaDecN(jd, -1)
}
func HSunApparentRaDecN(jd float64, n int) (float64, float64) {
return LoBoToRaDec(jd, HSunApparentLoN(jd, n), HSunTrueBoN(jd, n))
}
func HSunApparentRa(jd float64) float64 { // '太阳视赤经
return HSunApparentRaN(jd, -1)
}
func HSunApparentRaN(jd float64, n int) float64 { // '太阳视赤经
return LoToRa(jd, HSunApparentLoN(jd, n), HSunTrueBoN(jd, n))
}
func HSunTrueRa(jd float64) float64 {
return HSunTrueRaN(jd, -1)
}
func HSunTrueRaN(jd float64, n int) float64 {
sunTrueLo := HSunTrueLoN(jd, n)
eps := TrueObliquity(jd)
numerator := Cos(eps) * Sin(sunTrueLo)
denominator := Cos(sunTrueLo)
return ArcTan2(numerator, denominator)
}
func HSunApparentDec(jd float64) float64 { // '太阳视赤纬
return HSunApparentDecN(jd, -1)
}
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)
}