astro/basic/sun_physical.go
starainrt 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

53 lines
1.7 KiB
Go

package basic
import (
"math"
. "b612.me/astro/tools"
)
const (
sunPhysicalInclinationDeg = 7.25
sunPhysicalKBaseDeg = 73.6667
sunPhysicalKRateDeg = 1.3958333
sunCarringtonStartJD = 2398220.0
sunCarringtonRotationDays = 25.38
sunPhysicalKEpochJD = 2396758.0
)
// SunPhysicalInfo 太阳物理观测参数 / physical observing parameters of the Sun.
type SunPhysicalInfo struct {
// P 太阳北极位置角,单位度 / position angle of the solar north pole in degrees.
P float64
// B0 日面中心太阳纬度,单位度 / heliographic latitude of the disk center in degrees.
B0 float64
// L0 日面中心卡林顿经度,单位度 / Carrington heliographic longitude of the disk center in degrees.
L0 float64
}
// SunPhysical 太阳物理观测参数 / physical observing parameters of the Sun.
func SunPhysical(jd float64) SunPhysicalInfo {
return SunPhysicalN(jd, -1)
}
// SunPhysicalN 太阳物理观测参数(截断版) / truncated physical observing parameters of the Sun.
func SunPhysicalN(jd float64, n int) SunPhysicalInfo {
lambda := HSunApparentLoN(jd, n)
epsilon := TrueObliquity(jd)
k := sunPhysicalKBaseDeg + sunPhysicalKRateDeg*(jd-sunPhysicalKEpochJD)/36525.0
theta := (jd - sunCarringtonStartJD) * 360.0 / sunCarringtonRotationDays
x := math.Atan(-Cos(lambda)*Tan(epsilon)) * 180.0 / math.Pi
y := math.Atan(-Cos(lambda-k)*Tan(sunPhysicalInclinationDeg)) * 180.0 / math.Pi
p := Limit360(x + y)
b0 := ArcSin(Sin(lambda-k) * Sin(sunPhysicalInclinationDeg))
eta := ArcTan2(-Sin(lambda-k)*Cos(sunPhysicalInclinationDeg), -Cos(lambda-k))
l0 := Limit360(eta - theta)
return SunPhysicalInfo{
P: p,
B0: b0,
L0: l0,
}
}