网上找的:
2 p1 e6 [9 Q/ F0 ?8 k O; k" U: `8 v: c! s
已知两天体赤经赤纬,如何计算角距离? ' G& }2 P9 J; u: Y1 F1 x+ b" J
2 o8 R; H+ i2 J" V3 H/ X+ d7 W如果你了解球坐标和向量代数, 化为球极坐标问题来解决思路比较简明清晰. (下面, 赤经---R.A. 赤纬---Dec)* y' U( e4 C h4 C
3 _% U' L u/ P3 ^0 r; h+ i每颗恒星在单位球上的投影的球坐标为(r, theta, phi), 这里r=1, theta=-(Dec-90), phi=R.A. ; ^, E6 O% L2 e4 g; L# r! O7 F
% |" E& a7 B5 u; N- P" M
变成投影点的直角坐标: * J; p% |7 J! `6 u4 u
x=sin(theta)cos(phi)
; Z8 n' [) {5 J% a. n+ w6 yy=sin(theta)sin(phi)
0 @5 M& d9 j) Dz=cos(theta) : i+ {7 Z, c2 j$ ]+ g& J
& Q$ a2 n! k6 W5 i
这样可以把两颗星投影的角距离变为求两点间对球心的张角的简单问题. (点x0, y0, z0与点x1, y1, z1). 如果你用的角距离不大于180度(=Pi), 那么这个张角的值A可以直接求出: A=arc cos (x0*x1+y0*y1+z0*z1) \) Q5 K: l+ X6 @
) d4 h: b( m* O2 `
==============================================================
- p( V, ~4 [$ a' c9 ]7 T令:
; U; W$ d! r. W, X) _1 o1 V7 Y赤纬 = a1, a2( W7 y0 U. P6 ?: P
赤经 = b1, b2
3 I# E# v6 D9 k6 y
7 o5 q- J7 d. {! B0 m4 _, v, v则:8 ]1 w& R n, h3 k% o% R( {& A7 h
7 U: Z# c0 X6 |3 C! U$ B5 ?9 e
角距离 = arccos(sin(a1) * sin(a2) + cos(a1) * cos(a2) * cos(b2 - b1)) |