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