astro/basic/orbit_magnitude.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

46 lines
1.4 KiB
Go

package basic
import "math"
// OrbitAsteroidMagnitudeHG 返回小行星 H-G 模型的视星等。
func OrbitAsteroidMagnitudeHG(jd float64, elements OrbitElements, absoluteMagnitude, slopeParameter float64) float64 {
if !isFinite(jd) || !isFinite(absoluteMagnitude) || !isFinite(slopeParameter) {
return math.NaN()
}
sunDistance := OrbitSunDistance(jd, elements)
earthDistance := OrbitEarthDistance(jd, elements)
phaseAngle := OrbitPhaseAngle(jd, elements)
if !isFinitePositive(sunDistance) || !isFinitePositive(earthDistance) || !isFinite(phaseAngle) {
return math.NaN()
}
phaseBlend := orbitHGSlopeBlend(phaseAngle, slopeParameter)
if phaseBlend == 0 {
return math.Inf(1)
}
if !isFinitePositive(phaseBlend) {
return math.NaN()
}
return absoluteMagnitude + 5*math.Log10(sunDistance*earthDistance) - 2.5*math.Log10(phaseBlend)
}
func orbitHGSlopeBlend(phaseAngle, slopeParameter float64) float64 {
phi1 := orbitHGPhaseFunction1(phaseAngle)
phi2 := orbitHGPhaseFunction2(phaseAngle)
return (1-slopeParameter)*phi1 + slopeParameter*phi2
}
func orbitHGPhaseFunction1(phaseAngle float64) float64 {
return math.Exp(-3.33 * math.Pow(orbitHGTanHalfPhaseAngle(phaseAngle), 0.63))
}
func orbitHGPhaseFunction2(phaseAngle float64) float64 {
return math.Exp(-1.87 * math.Pow(orbitHGTanHalfPhaseAngle(phaseAngle), 1.22))
}
func orbitHGTanHalfPhaseAngle(phaseAngle float64) float64 {
return math.Tan((phaseAngle * math.Pi / 180) / 2)
}