- 新增日食、月食、本地可见性、中心线、半影区域、SVG 图示与沙罗周期信息 - 新增行星冲合、留、方照、物理星历、视直径、相位、亮肢角、轨道节点等计算 - 新增木星伽利略卫星位置、现象与接触事件计算 - 新增恒星星表、星座判定、自行修正与观测辅助能力 - 新增 coord、formula、orbit、sundial、lite/sun、lite/moon 等扩展包 - 完善农历年号、月相英文别名、视差角、大气质量、折射、日晷与双星计算 - 增加 NASA、JPL Horizons、IMCCE 等回归测试数据与基线测试 - 重构基础算法文件组织,补充大量公开 API 注释和语义回归测试 - 更新中文和英文 README,补充示例、精度说明、SVG 配图
71 lines
1.7 KiB
Go
71 lines
1.7 KiB
Go
package basic
|
|
|
|
import (
|
|
"math"
|
|
"testing"
|
|
)
|
|
|
|
func TestGetJQTime(t *testing.T) {
|
|
originalFunc := func(year, angle int) float64 {
|
|
const iterations = 1
|
|
|
|
var day int
|
|
if angle%2 == 0 {
|
|
day = 18
|
|
} else {
|
|
day = 3
|
|
}
|
|
|
|
month := 3.0
|
|
if angle%10 != 0 {
|
|
month += float64(angle+15) / 30.0
|
|
} else {
|
|
month += float64(angle) / 30.0
|
|
}
|
|
if month > 12 {
|
|
month -= 12
|
|
}
|
|
|
|
jd := JDECalc(year, int(month), float64(day))
|
|
if angle == 0 {
|
|
angle = 360
|
|
}
|
|
|
|
for i := 0; i < iterations; i++ {
|
|
for {
|
|
jd0 := jd
|
|
slope := (JQLospec(jd0+0.000005, float64(angle)) - JQLospec(jd0-0.000005, float64(angle))) / 0.00001
|
|
jd = jd0 - (JQLospec(jd0, float64(angle))-float64(angle))/slope
|
|
if math.Abs(jd-jd0) <= 0.00001 {
|
|
break
|
|
}
|
|
}
|
|
jd -= 0.001
|
|
}
|
|
jd += 0.001
|
|
return TD2UT(jd, false)
|
|
}
|
|
|
|
testCases := []struct {
|
|
year int
|
|
angle int
|
|
}{
|
|
{1900, 0}, {1900, 15}, {1900, 30}, {1900, 45}, {1900, 90}, {1900, 180}, {1900, 270}, {1900, 360},
|
|
{1950, 0}, {1950, 30}, {1950, 90}, {1950, 180}, {1950, 270},
|
|
{2000, 0}, {2000, 15}, {2000, 45}, {2000, 90}, {2000, 360},
|
|
{2023, 0}, {2023, 30}, {2023, 90}, {2023, 180}, {2023, 270},
|
|
{2100, 0}, {2100, 15}, {2100, 30}, {2100, 45}, {2100, 90}, {2100, 180}, {2100, 270}, {2100, 360},
|
|
{2200, 0}, {2200, 30}, {2200, 90}, {2200, 180}, {2200, 270},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
originalResult := originalFunc(tc.year, tc.angle)
|
|
optimizedResult := GetJQTime(tc.year, tc.angle)
|
|
diff := math.Abs(originalResult - optimizedResult)
|
|
if diff > 1e-10 {
|
|
t.Fatalf("GetJQTime mismatch: year=%d angle=%d original=%.15f optimized=%.15f diff=%.15f",
|
|
tc.year, tc.angle, originalResult, optimizedResult, diff)
|
|
}
|
|
}
|
|
}
|