- 新增日食、月食、本地可见性、中心线、半影区域、SVG 图示与沙罗周期信息 - 新增行星冲合、留、方照、物理星历、视直径、相位、亮肢角、轨道节点等计算 - 新增木星伽利略卫星位置、现象与接触事件计算 - 新增恒星星表、星座判定、自行修正与观测辅助能力 - 新增 coord、formula、orbit、sundial、lite/sun、lite/moon 等扩展包 - 完善农历年号、月相英文别名、视差角、大气质量、折射、日晷与双星计算 - 增加 NASA、JPL Horizons、IMCCE 等回归测试数据与基线测试 - 重构基础算法文件组织,补充大量公开 API 注释和语义回归测试 - 更新中文和英文 README,补充示例、精度说明、SVG 配图
100 lines
2.0 KiB
Go
100 lines
2.0 KiB
Go
package basic
|
|
|
|
import (
|
|
"b612.me/astro/planet"
|
|
. "b612.me/astro/tools"
|
|
)
|
|
|
|
func MoonLo(jd float64) float64 { //'月球平黄经
|
|
return planet.MoonLo(jd)
|
|
}
|
|
|
|
func SunMoonAngle(jd float64) float64 { // '月日距角
|
|
return planet.SunMoonAngle(jd)
|
|
}
|
|
|
|
func MoonM(jd float64) float64 { // '月平近点角
|
|
return planet.MoonM(jd)
|
|
}
|
|
|
|
func MoonLonX(jd float64) float64 { // As Double '月球经度参数(到升交点的平角距离)
|
|
return planet.MoonLonX(jd)
|
|
}
|
|
|
|
func MoonI(jd float64) float64 {
|
|
return planet.MoonI(jd)
|
|
}
|
|
|
|
func MoonR(jd float64) float64 {
|
|
return planet.MoonR(jd)
|
|
}
|
|
|
|
func MoonB(jd float64) float64 {
|
|
return planet.MoonB(jd)
|
|
}
|
|
|
|
func MoonTrueLo(jd float64) float64 {
|
|
return planet.MoonTrueLo(jd)
|
|
}
|
|
func MoonTrueBo(jd float64) float64 {
|
|
return planet.MoonTrueBo(jd)
|
|
}
|
|
func MoonAway(jd float64) float64 { //'月地距离
|
|
return planet.MoonAway(jd)
|
|
}
|
|
|
|
/*
|
|
* @name 月球视黄经
|
|
*/
|
|
func MoonApparentLo(jd float64) float64 {
|
|
return MoonTrueLo(jd) + Nutation2000Bi(jd)
|
|
}
|
|
|
|
/*
|
|
* 月球真赤纬
|
|
*/
|
|
func MoonTrueDec(jd float64) float64 {
|
|
moonLo := MoonApparentLo(jd)
|
|
moonBo := MoonTrueBo(jd)
|
|
tmp := Sin(moonBo)*Cos(TrueObliquity(jd)) + Cos(moonBo)*Sin(TrueObliquity(jd))*Sin(moonLo)
|
|
res := ArcSin(tmp)
|
|
return res
|
|
}
|
|
|
|
/*
|
|
* 月球真赤经
|
|
*/
|
|
func MoonTrueRa(jd float64) float64 {
|
|
return LoToRa(jd, MoonApparentLo(jd), MoonTrueBo(jd))
|
|
}
|
|
|
|
func MoonTrueRaDec(jd float64) (float64, float64) {
|
|
return LoBoToRaDec(jd, MoonApparentLo(jd), MoonTrueBo(jd))
|
|
}
|
|
|
|
/*
|
|
*
|
|
|
|
*
|
|
传入世界时
|
|
*/
|
|
func MoonApparentRa(jd, lon, lat float64, tz int) float64 {
|
|
jde := TD2UT(jd, true)
|
|
utcJD := jde - float64(tz)/24.000
|
|
ra := MoonTrueRa(utcJD)
|
|
dec := MoonTrueDec(utcJD)
|
|
away := MoonAway(utcJD) / 149597870.7
|
|
topoRA := TopocentricRa(ra, dec, lat, lon, jd-float64(tz)/24.000, away, 0)
|
|
return topoRA
|
|
}
|
|
|
|
func MoonApparentDec(jd, lon, lat, tz float64) float64 {
|
|
jde := TD2UT(jd, true)
|
|
utcJD := jde - tz/24
|
|
ra := MoonTrueRa(utcJD)
|
|
dec := MoonTrueDec(utcJD)
|
|
away := MoonAway(utcJD) / 149597870.7
|
|
topoDec := TopocentricDec(ra, dec, lat, lon, jd-tz/24, away, 0)
|
|
return topoDec
|
|
}
|