- 新增日食、月食、本地可见性、中心线、半影区域、SVG 图示与沙罗周期信息 - 新增行星冲合、留、方照、物理星历、视直径、相位、亮肢角、轨道节点等计算 - 新增木星伽利略卫星位置、现象与接触事件计算 - 新增恒星星表、星座判定、自行修正与观测辅助能力 - 新增 coord、formula、orbit、sundial、lite/sun、lite/moon 等扩展包 - 完善农历年号、月相英文别名、视差角、大气质量、折射、日晷与双星计算 - 增加 NASA、JPL Horizons、IMCCE 等回归测试数据与基线测试 - 重构基础算法文件组织,补充大量公开 API 注释和语义回归测试 - 更新中文和英文 README,补充示例、精度说明、SVG 配图
54 lines
1.3 KiB
Go
54 lines
1.3 KiB
Go
package planet
|
|
|
|
import . "b612.me/astro/tools"
|
|
|
|
// SunLo 太阳几何黄经
|
|
func SunLo(jd float64) float64 {
|
|
T := (jd - 2451545) / 365250
|
|
SunLo := 280.4664567 + 360007.6982779*T + 0.03032028*T*T + T*T*T/49931 - T*T*T*T/15299 - T*T*T*T*T/1988000
|
|
return Limit360(SunLo)
|
|
}
|
|
|
|
func SunM(JD float64) float64 {
|
|
T := (JD - 2451545) / 36525
|
|
sunM := 357.5291092 + 35999.0502909*T - 0.0001559*T*T - 0.00000048*T*T*T
|
|
return Limit360(sunM)
|
|
}
|
|
|
|
// Earthe 地球偏心率
|
|
func Earthe(JD float64) float64 {
|
|
T := (JD - 2451545) / 36525
|
|
Earthe := 0.016708617 - 0.000042037*T - 0.0000001236*T*T
|
|
return Earthe
|
|
}
|
|
|
|
func EarthPI(JD float64) float64 {
|
|
T := (JD - 2451545) / 36525
|
|
return 102.93735 + 1.71953*T + 000046*T*T
|
|
}
|
|
|
|
func SunMidFun(JD float64) float64 {
|
|
T := (JD - 2451545) / 36525
|
|
M := SunM(JD)
|
|
SunMidFun := (1.9146-0.004817*T-0.000014*T*T)*Sin(M) + (0.019993-0.000101*T)*Sin(2*M) + 0.00029*Sin(3*M)
|
|
return SunMidFun
|
|
}
|
|
|
|
func SunTrueLo(JD float64) float64 {
|
|
SunTrueLo := SunLo(JD) + SunMidFun(JD)
|
|
return SunTrueLo
|
|
}
|
|
|
|
func SunApparentLo(JD float64) float64 {
|
|
T := (JD - 2451545) / 36525
|
|
SunApparentLo := SunTrueLo(JD) - 0.00569 - 0.00478*Sin(125.04-1934.136*T)
|
|
return SunApparentLo
|
|
}
|
|
|
|
func Distance(jd float64) float64 {
|
|
f := SunMidFun(jd)
|
|
m := SunM(jd)
|
|
e := Earthe(jd)
|
|
return 1.000001018 * (1 - e*e) / (1 + e*Cos(f+m))
|
|
}
|