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