| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
#include "erfa.h" |
|
2
|
|
|
|
|
|
|
|
|
3
|
731
|
|
|
|
|
|
int eraPlan94(double date1, double date2, int np, double pv[2][3]) |
|
4
|
|
|
|
|
|
|
/* |
|
5
|
|
|
|
|
|
|
** - - - - - - - - - - |
|
6
|
|
|
|
|
|
|
** e r a P l a n 9 4 |
|
7
|
|
|
|
|
|
|
** - - - - - - - - - - |
|
8
|
|
|
|
|
|
|
** |
|
9
|
|
|
|
|
|
|
** Approximate heliocentric position and velocity of a nominated major |
|
10
|
|
|
|
|
|
|
** planet: Mercury, Venus, EMB, Mars, Jupiter, Saturn, Uranus or |
|
11
|
|
|
|
|
|
|
** Neptune (but not the Earth itself). |
|
12
|
|
|
|
|
|
|
** |
|
13
|
|
|
|
|
|
|
** Given: |
|
14
|
|
|
|
|
|
|
** date1 double TDB date part A (Note 1) |
|
15
|
|
|
|
|
|
|
** date2 double TDB date part B (Note 1) |
|
16
|
|
|
|
|
|
|
** np int planet (1=Mercury, 2=Venus, 3=EMB, 4=Mars, |
|
17
|
|
|
|
|
|
|
** 5=Jupiter, 6=Saturn, 7=Uranus, 8=Neptune) |
|
18
|
|
|
|
|
|
|
** |
|
19
|
|
|
|
|
|
|
** Returned (argument): |
|
20
|
|
|
|
|
|
|
** pv double[2][3] planet p,v (heliocentric, J2000.0, au,au/d) |
|
21
|
|
|
|
|
|
|
** |
|
22
|
|
|
|
|
|
|
** Returned (function value): |
|
23
|
|
|
|
|
|
|
** int status: -1 = illegal NP (outside 1-8) |
|
24
|
|
|
|
|
|
|
** 0 = OK |
|
25
|
|
|
|
|
|
|
** +1 = warning: year outside 1000-3000 |
|
26
|
|
|
|
|
|
|
** +2 = warning: failed to converge |
|
27
|
|
|
|
|
|
|
** |
|
28
|
|
|
|
|
|
|
** Notes: |
|
29
|
|
|
|
|
|
|
** |
|
30
|
|
|
|
|
|
|
** 1) The date date1+date2 is in the TDB time scale (in practice TT can |
|
31
|
|
|
|
|
|
|
** be used) and is a Julian Date, apportioned in any convenient way |
|
32
|
|
|
|
|
|
|
** between the two arguments. For example, JD(TDB)=2450123.7 could |
|
33
|
|
|
|
|
|
|
** be expressed in any of these ways, among others: |
|
34
|
|
|
|
|
|
|
** |
|
35
|
|
|
|
|
|
|
** date1 date2 |
|
36
|
|
|
|
|
|
|
** |
|
37
|
|
|
|
|
|
|
** 2450123.7 0.0 (JD method) |
|
38
|
|
|
|
|
|
|
** 2451545.0 -1421.3 (J2000 method) |
|
39
|
|
|
|
|
|
|
** 2400000.5 50123.2 (MJD method) |
|
40
|
|
|
|
|
|
|
** 2450123.5 0.2 (date & time method) |
|
41
|
|
|
|
|
|
|
** |
|
42
|
|
|
|
|
|
|
** The JD method is the most natural and convenient to use in cases |
|
43
|
|
|
|
|
|
|
** where the loss of several decimal digits of resolution is |
|
44
|
|
|
|
|
|
|
** acceptable. The J2000 method is best matched to the way the |
|
45
|
|
|
|
|
|
|
** argument is handled internally and will deliver the optimum |
|
46
|
|
|
|
|
|
|
** resolution. The MJD method and the date & time methods are both |
|
47
|
|
|
|
|
|
|
** good compromises between resolution and convenience. The limited |
|
48
|
|
|
|
|
|
|
** accuracy of the present algorithm is such that any of the methods |
|
49
|
|
|
|
|
|
|
** is satisfactory. |
|
50
|
|
|
|
|
|
|
** |
|
51
|
|
|
|
|
|
|
** 2) If an np value outside the range 1-8 is supplied, an error status |
|
52
|
|
|
|
|
|
|
** (function value -1) is returned and the pv vector set to zeroes. |
|
53
|
|
|
|
|
|
|
** |
|
54
|
|
|
|
|
|
|
** 3) For np=3 the result is for the Earth-Moon Barycenter. To obtain |
|
55
|
|
|
|
|
|
|
** the heliocentric position and velocity of the Earth, use instead |
|
56
|
|
|
|
|
|
|
** the ERFA function eraEpv00. |
|
57
|
|
|
|
|
|
|
** |
|
58
|
|
|
|
|
|
|
** 4) On successful return, the array pv contains the following: |
|
59
|
|
|
|
|
|
|
** |
|
60
|
|
|
|
|
|
|
** pv[0][0] x } |
|
61
|
|
|
|
|
|
|
** pv[0][1] y } heliocentric position, au |
|
62
|
|
|
|
|
|
|
** pv[0][2] z } |
|
63
|
|
|
|
|
|
|
** |
|
64
|
|
|
|
|
|
|
** pv[1][0] xdot } |
|
65
|
|
|
|
|
|
|
** pv[1][1] ydot } heliocentric velocity, au/d |
|
66
|
|
|
|
|
|
|
** pv[1][2] zdot } |
|
67
|
|
|
|
|
|
|
** |
|
68
|
|
|
|
|
|
|
** The reference frame is equatorial and is with respect to the |
|
69
|
|
|
|
|
|
|
** mean equator and equinox of epoch J2000.0. |
|
70
|
|
|
|
|
|
|
** |
|
71
|
|
|
|
|
|
|
** 5) The algorithm is due to J.L. Simon, P. Bretagnon, J. Chapront, |
|
72
|
|
|
|
|
|
|
** M. Chapront-Touze, G. Francou and J. Laskar (Bureau des |
|
73
|
|
|
|
|
|
|
** Longitudes, Paris, France). From comparisons with JPL |
|
74
|
|
|
|
|
|
|
** ephemeris DE102, they quote the following maximum errors |
|
75
|
|
|
|
|
|
|
** over the interval 1800-2050: |
|
76
|
|
|
|
|
|
|
** |
|
77
|
|
|
|
|
|
|
** L (arcsec) B (arcsec) R (km) |
|
78
|
|
|
|
|
|
|
** |
|
79
|
|
|
|
|
|
|
** Mercury 4 1 300 |
|
80
|
|
|
|
|
|
|
** Venus 5 1 800 |
|
81
|
|
|
|
|
|
|
** EMB 6 1 1000 |
|
82
|
|
|
|
|
|
|
** Mars 17 1 7700 |
|
83
|
|
|
|
|
|
|
** Jupiter 71 5 76000 |
|
84
|
|
|
|
|
|
|
** Saturn 81 13 267000 |
|
85
|
|
|
|
|
|
|
** Uranus 86 7 712000 |
|
86
|
|
|
|
|
|
|
** Neptune 11 1 253000 |
|
87
|
|
|
|
|
|
|
** |
|
88
|
|
|
|
|
|
|
** Over the interval 1000-3000, they report that the accuracy is no |
|
89
|
|
|
|
|
|
|
** worse than 1.5 times that over 1800-2050. Outside 1000-3000 the |
|
90
|
|
|
|
|
|
|
** accuracy declines. |
|
91
|
|
|
|
|
|
|
** |
|
92
|
|
|
|
|
|
|
** Comparisons of the present function with the JPL DE200 ephemeris |
|
93
|
|
|
|
|
|
|
** give the following RMS errors over the interval 1960-2025: |
|
94
|
|
|
|
|
|
|
** |
|
95
|
|
|
|
|
|
|
** position (km) velocity (m/s) |
|
96
|
|
|
|
|
|
|
** |
|
97
|
|
|
|
|
|
|
** Mercury 334 0.437 |
|
98
|
|
|
|
|
|
|
** Venus 1060 0.855 |
|
99
|
|
|
|
|
|
|
** EMB 2010 0.815 |
|
100
|
|
|
|
|
|
|
** Mars 7690 1.98 |
|
101
|
|
|
|
|
|
|
** Jupiter 71700 7.70 |
|
102
|
|
|
|
|
|
|
** Saturn 199000 19.4 |
|
103
|
|
|
|
|
|
|
** Uranus 564000 16.4 |
|
104
|
|
|
|
|
|
|
** Neptune 158000 14.4 |
|
105
|
|
|
|
|
|
|
** |
|
106
|
|
|
|
|
|
|
** Comparisons against DE200 over the interval 1800-2100 gave the |
|
107
|
|
|
|
|
|
|
** following maximum absolute differences. (The results using |
|
108
|
|
|
|
|
|
|
** DE406 were essentially the same.) |
|
109
|
|
|
|
|
|
|
** |
|
110
|
|
|
|
|
|
|
** L (arcsec) B (arcsec) R (km) Rdot (m/s) |
|
111
|
|
|
|
|
|
|
** |
|
112
|
|
|
|
|
|
|
** Mercury 7 1 500 0.7 |
|
113
|
|
|
|
|
|
|
** Venus 7 1 1100 0.9 |
|
114
|
|
|
|
|
|
|
** EMB 9 1 1300 1.0 |
|
115
|
|
|
|
|
|
|
** Mars 26 1 9000 2.5 |
|
116
|
|
|
|
|
|
|
** Jupiter 78 6 82000 8.2 |
|
117
|
|
|
|
|
|
|
** Saturn 87 14 263000 24.6 |
|
118
|
|
|
|
|
|
|
** Uranus 86 7 661000 27.4 |
|
119
|
|
|
|
|
|
|
** Neptune 11 2 248000 21.4 |
|
120
|
|
|
|
|
|
|
** |
|
121
|
|
|
|
|
|
|
** 6) The present ERFA re-implementation of the original Simon et al. |
|
122
|
|
|
|
|
|
|
** Fortran code differs from the original in the following respects: |
|
123
|
|
|
|
|
|
|
** |
|
124
|
|
|
|
|
|
|
** * C instead of Fortran. |
|
125
|
|
|
|
|
|
|
** |
|
126
|
|
|
|
|
|
|
** * The date is supplied in two parts. |
|
127
|
|
|
|
|
|
|
** |
|
128
|
|
|
|
|
|
|
** * The result is returned only in equatorial Cartesian form; |
|
129
|
|
|
|
|
|
|
** the ecliptic longitude, latitude and radius vector are not |
|
130
|
|
|
|
|
|
|
** returned. |
|
131
|
|
|
|
|
|
|
** |
|
132
|
|
|
|
|
|
|
** * The result is in the J2000.0 equatorial frame, not ecliptic. |
|
133
|
|
|
|
|
|
|
** |
|
134
|
|
|
|
|
|
|
** * More is done in-line: there are fewer calls to subroutines. |
|
135
|
|
|
|
|
|
|
** |
|
136
|
|
|
|
|
|
|
** * Different error/warning status values are used. |
|
137
|
|
|
|
|
|
|
** |
|
138
|
|
|
|
|
|
|
** * A different Kepler's-equation-solver is used (avoiding |
|
139
|
|
|
|
|
|
|
** use of double precision complex). |
|
140
|
|
|
|
|
|
|
** |
|
141
|
|
|
|
|
|
|
** * Polynomials in t are nested to minimize rounding errors. |
|
142
|
|
|
|
|
|
|
** |
|
143
|
|
|
|
|
|
|
** * Explicit double constants are used to avoid mixed-mode |
|
144
|
|
|
|
|
|
|
** expressions. |
|
145
|
|
|
|
|
|
|
** |
|
146
|
|
|
|
|
|
|
** None of the above changes affects the result significantly. |
|
147
|
|
|
|
|
|
|
** |
|
148
|
|
|
|
|
|
|
** 7) The returned status indicates the most serious condition |
|
149
|
|
|
|
|
|
|
** encountered during execution of the function. Illegal np is |
|
150
|
|
|
|
|
|
|
** considered the most serious, overriding failure to converge, |
|
151
|
|
|
|
|
|
|
** which in turn takes precedence over the remote date warning. |
|
152
|
|
|
|
|
|
|
** |
|
153
|
|
|
|
|
|
|
** Called: |
|
154
|
|
|
|
|
|
|
** eraAnp normalize angle into range 0 to 2pi |
|
155
|
|
|
|
|
|
|
** |
|
156
|
|
|
|
|
|
|
** Reference: Simon, J.L, Bretagnon, P., Chapront, J., |
|
157
|
|
|
|
|
|
|
** Chapront-Touze, M., Francou, G., and Laskar, J., |
|
158
|
|
|
|
|
|
|
** Astron.Astrophys., 282, 663 (1994). |
|
159
|
|
|
|
|
|
|
** |
|
160
|
|
|
|
|
|
|
** Copyright (C) 2013-2019, NumFOCUS Foundation. |
|
161
|
|
|
|
|
|
|
** Derived, with permission, from the SOFA library. See notes at end of file. |
|
162
|
|
|
|
|
|
|
*/ |
|
163
|
|
|
|
|
|
|
{ |
|
164
|
|
|
|
|
|
|
/* Gaussian constant */ |
|
165
|
|
|
|
|
|
|
static const double GK = 0.017202098950; |
|
166
|
|
|
|
|
|
|
|
|
167
|
|
|
|
|
|
|
/* Sin and cos of J2000.0 mean obliquity (IAU 1976) */ |
|
168
|
|
|
|
|
|
|
static const double SINEPS = 0.3977771559319137; |
|
169
|
|
|
|
|
|
|
static const double COSEPS = 0.9174820620691818; |
|
170
|
|
|
|
|
|
|
|
|
171
|
|
|
|
|
|
|
/* Maximum number of iterations allowed to solve Kepler's equation */ |
|
172
|
|
|
|
|
|
|
static const int KMAX = 10; |
|
173
|
|
|
|
|
|
|
|
|
174
|
|
|
|
|
|
|
int jstat, i, k; |
|
175
|
|
|
|
|
|
|
double t, da, dl, de, dp, di, dom, dmu, arga, argl, am, |
|
176
|
|
|
|
|
|
|
ae, dae, ae2, at, r, v, si2, xq, xp, tl, xsw, |
|
177
|
|
|
|
|
|
|
xcw, xm2, xf, ci2, xms, xmc, xpxq2, x, y, z; |
|
178
|
|
|
|
|
|
|
|
|
179
|
|
|
|
|
|
|
/* Planetary inverse masses */ |
|
180
|
|
|
|
|
|
|
static const double amas[] = { 6023600.0, /* Mercury */ |
|
181
|
|
|
|
|
|
|
408523.5, /* Venus */ |
|
182
|
|
|
|
|
|
|
328900.5, /* EMB */ |
|
183
|
|
|
|
|
|
|
3098710.0, /* Mars */ |
|
184
|
|
|
|
|
|
|
1047.355, /* Jupiter */ |
|
185
|
|
|
|
|
|
|
3498.5, /* Saturn */ |
|
186
|
|
|
|
|
|
|
22869.0, /* Uranus */ |
|
187
|
|
|
|
|
|
|
19314.0 }; /* Neptune */ |
|
188
|
|
|
|
|
|
|
|
|
189
|
|
|
|
|
|
|
/* |
|
190
|
|
|
|
|
|
|
** Tables giving the mean Keplerian elements, limited to t^2 terms: |
|
191
|
|
|
|
|
|
|
** |
|
192
|
|
|
|
|
|
|
** a semi-major axis (au) |
|
193
|
|
|
|
|
|
|
** dlm mean longitude (degree and arcsecond) |
|
194
|
|
|
|
|
|
|
** e eccentricity |
|
195
|
|
|
|
|
|
|
** pi longitude of the perihelion (degree and arcsecond) |
|
196
|
|
|
|
|
|
|
** dinc inclination (degree and arcsecond) |
|
197
|
|
|
|
|
|
|
** omega longitude of the ascending node (degree and arcsecond) |
|
198
|
|
|
|
|
|
|
*/ |
|
199
|
|
|
|
|
|
|
|
|
200
|
|
|
|
|
|
|
static const double a[][3] = { |
|
201
|
|
|
|
|
|
|
{ 0.3870983098, 0.0, 0.0 }, /* Mercury */ |
|
202
|
|
|
|
|
|
|
{ 0.7233298200, 0.0, 0.0 }, /* Venus */ |
|
203
|
|
|
|
|
|
|
{ 1.0000010178, 0.0, 0.0 }, /* EMB */ |
|
204
|
|
|
|
|
|
|
{ 1.5236793419, 3e-10, 0.0 }, /* Mars */ |
|
205
|
|
|
|
|
|
|
{ 5.2026032092, 19132e-10, -39e-10 }, /* Jupiter */ |
|
206
|
|
|
|
|
|
|
{ 9.5549091915, -0.0000213896, 444e-10 }, /* Saturn */ |
|
207
|
|
|
|
|
|
|
{ 19.2184460618, -3716e-10, 979e-10 }, /* Uranus */ |
|
208
|
|
|
|
|
|
|
{ 30.1103868694, -16635e-10, 686e-10 } /* Neptune */ |
|
209
|
|
|
|
|
|
|
}; |
|
210
|
|
|
|
|
|
|
|
|
211
|
|
|
|
|
|
|
static const double dlm[][3] = { |
|
212
|
|
|
|
|
|
|
{ 252.25090552, 5381016286.88982, -1.92789 }, |
|
213
|
|
|
|
|
|
|
{ 181.97980085, 2106641364.33548, 0.59381 }, |
|
214
|
|
|
|
|
|
|
{ 100.46645683, 1295977422.83429, -2.04411 }, |
|
215
|
|
|
|
|
|
|
{ 355.43299958, 689050774.93988, 0.94264 }, |
|
216
|
|
|
|
|
|
|
{ 34.35151874, 109256603.77991, -30.60378 }, |
|
217
|
|
|
|
|
|
|
{ 50.07744430, 43996098.55732, 75.61614 }, |
|
218
|
|
|
|
|
|
|
{ 314.05500511, 15424811.93933, -1.75083 }, |
|
219
|
|
|
|
|
|
|
{ 304.34866548, 7865503.20744, 0.21103 } |
|
220
|
|
|
|
|
|
|
}; |
|
221
|
|
|
|
|
|
|
|
|
222
|
|
|
|
|
|
|
static const double e[][3] = { |
|
223
|
|
|
|
|
|
|
{ 0.2056317526, 0.0002040653, -28349e-10 }, |
|
224
|
|
|
|
|
|
|
{ 0.0067719164, -0.0004776521, 98127e-10 }, |
|
225
|
|
|
|
|
|
|
{ 0.0167086342, -0.0004203654, -0.0000126734 }, |
|
226
|
|
|
|
|
|
|
{ 0.0934006477, 0.0009048438, -80641e-10 }, |
|
227
|
|
|
|
|
|
|
{ 0.0484979255, 0.0016322542, -0.0000471366 }, |
|
228
|
|
|
|
|
|
|
{ 0.0555481426, -0.0034664062, -0.0000643639 }, |
|
229
|
|
|
|
|
|
|
{ 0.0463812221, -0.0002729293, 0.0000078913 }, |
|
230
|
|
|
|
|
|
|
{ 0.0094557470, 0.0000603263, 0.0 } |
|
231
|
|
|
|
|
|
|
}; |
|
232
|
|
|
|
|
|
|
|
|
233
|
|
|
|
|
|
|
static const double pi[][3] = { |
|
234
|
|
|
|
|
|
|
{ 77.45611904, 5719.11590, -4.83016 }, |
|
235
|
|
|
|
|
|
|
{ 131.56370300, 175.48640, -498.48184 }, |
|
236
|
|
|
|
|
|
|
{ 102.93734808, 11612.35290, 53.27577 }, |
|
237
|
|
|
|
|
|
|
{ 336.06023395, 15980.45908, -62.32800 }, |
|
238
|
|
|
|
|
|
|
{ 14.33120687, 7758.75163, 259.95938 }, |
|
239
|
|
|
|
|
|
|
{ 93.05723748, 20395.49439, 190.25952 }, |
|
240
|
|
|
|
|
|
|
{ 173.00529106, 3215.56238, -34.09288 }, |
|
241
|
|
|
|
|
|
|
{ 48.12027554, 1050.71912, 27.39717 } |
|
242
|
|
|
|
|
|
|
}; |
|
243
|
|
|
|
|
|
|
|
|
244
|
|
|
|
|
|
|
static const double dinc[][3] = { |
|
245
|
|
|
|
|
|
|
{ 7.00498625, -214.25629, 0.28977 }, |
|
246
|
|
|
|
|
|
|
{ 3.39466189, -30.84437, -11.67836 }, |
|
247
|
|
|
|
|
|
|
{ 0.0, 469.97289, -3.35053 }, |
|
248
|
|
|
|
|
|
|
{ 1.84972648, -293.31722, -8.11830 }, |
|
249
|
|
|
|
|
|
|
{ 1.30326698, -71.55890, 11.95297 }, |
|
250
|
|
|
|
|
|
|
{ 2.48887878, 91.85195, -17.66225 }, |
|
251
|
|
|
|
|
|
|
{ 0.77319689, -60.72723, 1.25759 }, |
|
252
|
|
|
|
|
|
|
{ 1.76995259, 8.12333, 0.08135 } |
|
253
|
|
|
|
|
|
|
}; |
|
254
|
|
|
|
|
|
|
|
|
255
|
|
|
|
|
|
|
static const double omega[][3] = { |
|
256
|
|
|
|
|
|
|
{ 48.33089304, -4515.21727, -31.79892 }, |
|
257
|
|
|
|
|
|
|
{ 76.67992019, -10008.48154, -51.32614 }, |
|
258
|
|
|
|
|
|
|
{ 174.87317577, -8679.27034, 15.34191 }, |
|
259
|
|
|
|
|
|
|
{ 49.55809321, -10620.90088, -230.57416 }, |
|
260
|
|
|
|
|
|
|
{ 100.46440702, 6362.03561, 326.52178 }, |
|
261
|
|
|
|
|
|
|
{ 113.66550252, -9240.19942, -66.23743 }, |
|
262
|
|
|
|
|
|
|
{ 74.00595701, 2669.15033, 145.93964 }, |
|
263
|
|
|
|
|
|
|
{ 131.78405702, -221.94322, -0.78728 } |
|
264
|
|
|
|
|
|
|
}; |
|
265
|
|
|
|
|
|
|
|
|
266
|
|
|
|
|
|
|
/* Tables for trigonometric terms to be added to the mean elements of */ |
|
267
|
|
|
|
|
|
|
/* the semi-major axes */ |
|
268
|
|
|
|
|
|
|
|
|
269
|
|
|
|
|
|
|
static const double kp[][9] = { |
|
270
|
|
|
|
|
|
|
{ 69613, 75645, 88306, 59899, 15746, 71087, 142173, 3086, 0 }, |
|
271
|
|
|
|
|
|
|
{ 21863, 32794, 26934, 10931, 26250, 43725, 53867, 28939, 0 }, |
|
272
|
|
|
|
|
|
|
{ 16002, 21863, 32004, 10931, 14529, 16368, 15318, 32794, 0 }, |
|
273
|
|
|
|
|
|
|
{ 6345, 7818, 15636, 7077, 8184, 14163, 1107, 4872, 0 }, |
|
274
|
|
|
|
|
|
|
{ 1760, 1454, 1167, 880, 287, 2640, 19, 2047, 1454 }, |
|
275
|
|
|
|
|
|
|
{ 574, 0, 880, 287, 19, 1760, 1167, 306, 574 }, |
|
276
|
|
|
|
|
|
|
{ 204, 0, 177, 1265, 4, 385, 200, 208, 204 }, |
|
277
|
|
|
|
|
|
|
{ 0, 102, 106, 4, 98, 1367, 487, 204, 0 } |
|
278
|
|
|
|
|
|
|
}; |
|
279
|
|
|
|
|
|
|
|
|
280
|
|
|
|
|
|
|
static const double ca[][9] = { |
|
281
|
|
|
|
|
|
|
{ 4, -13, 11, -9, -9, -3, -1, 4, 0 }, |
|
282
|
|
|
|
|
|
|
{ -156, 59, -42, 6, 19, -20, -10, -12, 0 }, |
|
283
|
|
|
|
|
|
|
{ 64, -152, 62, -8, 32, -41, 19, -11, 0 }, |
|
284
|
|
|
|
|
|
|
{ 124, 621, -145, 208, 54, -57, 30, 15, 0 }, |
|
285
|
|
|
|
|
|
|
{ -23437, -2634, 6601, 6259, -1507,-1821, 2620, -2115, -1489 }, |
|
286
|
|
|
|
|
|
|
{ 62911,-119919, 79336,17814,-24241,12068, 8306, -4893, 8902 }, |
|
287
|
|
|
|
|
|
|
{ 389061,-262125,-44088, 8387,-22976,-2093, -615, -9720, 6633 }, |
|
288
|
|
|
|
|
|
|
{ -412235,-157046,-31430,37817, -9740, -13, -7449, 9644, 0 } |
|
289
|
|
|
|
|
|
|
}; |
|
290
|
|
|
|
|
|
|
|
|
291
|
|
|
|
|
|
|
static const double sa[][9] = { |
|
292
|
|
|
|
|
|
|
{ -29, -1, 9, 6, -6, 5, 4, 0, 0 }, |
|
293
|
|
|
|
|
|
|
{ -48, -125, -26, -37, 18, -13, -20, -2, 0 }, |
|
294
|
|
|
|
|
|
|
{ -150, -46, 68, 54, 14, 24, -28, 22, 0 }, |
|
295
|
|
|
|
|
|
|
{ -621, 532, -694, -20, 192, -94, 71, -73, 0 }, |
|
296
|
|
|
|
|
|
|
{ -14614,-19828, -5869, 1881, -4372, -2255, 782, 930, 913 }, |
|
297
|
|
|
|
|
|
|
{ 139737, 0, 24667, 51123, -5102, 7429, -4095, -1976, -9566 }, |
|
298
|
|
|
|
|
|
|
{ -138081, 0, 37205,-49039,-41901,-33872,-27037,-12474, 18797 }, |
|
299
|
|
|
|
|
|
|
{ 0, 28492,133236, 69654, 52322,-49577,-26430, -3593, 0 } |
|
300
|
|
|
|
|
|
|
}; |
|
301
|
|
|
|
|
|
|
|
|
302
|
|
|
|
|
|
|
/* Tables giving the trigonometric terms to be added to the mean */ |
|
303
|
|
|
|
|
|
|
/* elements of the mean longitudes */ |
|
304
|
|
|
|
|
|
|
|
|
305
|
|
|
|
|
|
|
static const double kq[][10] = { |
|
306
|
|
|
|
|
|
|
{ 3086,15746,69613,59899,75645,88306, 12661, 2658, 0, 0 }, |
|
307
|
|
|
|
|
|
|
{ 21863,32794,10931, 73, 4387,26934, 1473, 2157, 0, 0 }, |
|
308
|
|
|
|
|
|
|
{ 10,16002,21863,10931, 1473,32004, 4387, 73, 0, 0 }, |
|
309
|
|
|
|
|
|
|
{ 10, 6345, 7818, 1107,15636, 7077, 8184, 532, 10, 0 }, |
|
310
|
|
|
|
|
|
|
{ 19, 1760, 1454, 287, 1167, 880, 574, 2640, 19, 1454 }, |
|
311
|
|
|
|
|
|
|
{ 19, 574, 287, 306, 1760, 12, 31, 38, 19, 574 }, |
|
312
|
|
|
|
|
|
|
{ 4, 204, 177, 8, 31, 200, 1265, 102, 4, 204 }, |
|
313
|
|
|
|
|
|
|
{ 4, 102, 106, 8, 98, 1367, 487, 204, 4, 102 } |
|
314
|
|
|
|
|
|
|
}; |
|
315
|
|
|
|
|
|
|
|
|
316
|
|
|
|
|
|
|
static const double cl[][10] = { |
|
317
|
|
|
|
|
|
|
{ 21, -95, -157, 41, -5, 42, 23, 30, 0, 0 }, |
|
318
|
|
|
|
|
|
|
{ -160, -313, -235, 60, -74, -76, -27, 34, 0, 0 }, |
|
319
|
|
|
|
|
|
|
{ -325, -322, -79, 232, -52, 97, 55, -41, 0, 0 }, |
|
320
|
|
|
|
|
|
|
{ 2268, -979, 802, 602, -668, -33, 345, 201, -55, 0 }, |
|
321
|
|
|
|
|
|
|
{ 7610, -4997,-7689,-5841,-2617, 1115,-748,-607, 6074, 354 }, |
|
322
|
|
|
|
|
|
|
{ -18549, 30125,20012, -730, 824, 23,1289,-352, -14767, -2062 }, |
|
323
|
|
|
|
|
|
|
{ -135245,-14594, 4197,-4030,-5630,-2898,2540,-306, 2939, 1986 }, |
|
324
|
|
|
|
|
|
|
{ 89948, 2103, 8963, 2695, 3682, 1648, 866,-154, -1963, -283 } |
|
325
|
|
|
|
|
|
|
}; |
|
326
|
|
|
|
|
|
|
|
|
327
|
|
|
|
|
|
|
static const double sl[][10] = { |
|
328
|
|
|
|
|
|
|
{ -342, 136, -23, 62, 66, -52, -33, 17, 0, 0 }, |
|
329
|
|
|
|
|
|
|
{ 524, -149, -35, 117, 151, 122, -71, -62, 0, 0 }, |
|
330
|
|
|
|
|
|
|
{ -105, -137, 258, 35, -116, -88,-112, -80, 0, 0 }, |
|
331
|
|
|
|
|
|
|
{ 854, -205, -936, -240, 140, -341, -97, -232, 536, 0 }, |
|
332
|
|
|
|
|
|
|
{ -56980, 8016, 1012, 1448,-3024,-3710, 318, 503, 3767, 577 }, |
|
333
|
|
|
|
|
|
|
{ 138606,-13478,-4964, 1441,-1319,-1482, 427, 1236, -9167, -1918 }, |
|
334
|
|
|
|
|
|
|
{ 71234,-41116, 5334,-4935,-1848, 66, 434, -1748, 3780, -701 }, |
|
335
|
|
|
|
|
|
|
{ -47645, 11647, 2166, 3194, 679, 0,-244, -419, -2531, 48 } |
|
336
|
|
|
|
|
|
|
}; |
|
337
|
|
|
|
|
|
|
|
|
338
|
|
|
|
|
|
|
/*--------------------------------------------------------------------*/ |
|
339
|
|
|
|
|
|
|
|
|
340
|
|
|
|
|
|
|
/* Validate the planet number. */ |
|
341
|
731
|
50
|
|
|
|
|
if ((np < 1) || (np > 8)) { |
|
342
|
|
|
|
|
|
|
jstat = -1; |
|
343
|
|
|
|
|
|
|
|
|
344
|
|
|
|
|
|
|
/* Reset the result in case of failure. */ |
|
345
|
0
|
0
|
|
|
|
|
for (k = 0; k < 2; k++) { |
|
346
|
0
|
0
|
|
|
|
|
for (i = 0; i < 3; i++) { |
|
347
|
0
|
|
|
|
|
|
pv[k][i] = 0.0; |
|
348
|
|
|
|
|
|
|
} |
|
349
|
|
|
|
|
|
|
} |
|
350
|
|
|
|
|
|
|
|
|
351
|
|
|
|
|
|
|
} else { |
|
352
|
|
|
|
|
|
|
|
|
353
|
|
|
|
|
|
|
/* Decrement the planet number to start at zero. */ |
|
354
|
|
|
|
|
|
|
np--; |
|
355
|
|
|
|
|
|
|
|
|
356
|
|
|
|
|
|
|
/* Time: Julian millennia since J2000.0. */ |
|
357
|
731
|
|
|
|
|
|
t = ((date1 - ERFA_DJ00) + date2) / ERFA_DJM; |
|
358
|
|
|
|
|
|
|
|
|
359
|
|
|
|
|
|
|
/* OK status unless remote date. */ |
|
360
|
731
|
|
|
|
|
|
jstat = fabs(t) <= 1.0 ? 0 : 1; |
|
361
|
|
|
|
|
|
|
|
|
362
|
|
|
|
|
|
|
/* Compute the mean elements. */ |
|
363
|
1462
|
|
|
|
|
|
da = a[np][0] + |
|
364
|
1462
|
|
|
|
|
|
(a[np][1] + |
|
365
|
1462
|
|
|
|
|
|
a[np][2] * t) * t; |
|
366
|
1462
|
|
|
|
|
|
dl = (3600.0 * dlm[np][0] + |
|
367
|
1462
|
|
|
|
|
|
(dlm[np][1] + |
|
368
|
1462
|
|
|
|
|
|
dlm[np][2] * t) * t) * ERFA_DAS2R; |
|
369
|
1462
|
|
|
|
|
|
de = e[np][0] + |
|
370
|
1462
|
|
|
|
|
|
( e[np][1] + |
|
371
|
1462
|
|
|
|
|
|
e[np][2] * t) * t; |
|
372
|
731
|
|
|
|
|
|
dp = eraAnpm((3600.0 * pi[np][0] + |
|
373
|
1462
|
|
|
|
|
|
(pi[np][1] + |
|
374
|
1462
|
|
|
|
|
|
pi[np][2] * t) * t) * ERFA_DAS2R); |
|
375
|
1462
|
|
|
|
|
|
di = (3600.0 * dinc[np][0] + |
|
376
|
1462
|
|
|
|
|
|
(dinc[np][1] + |
|
377
|
1462
|
|
|
|
|
|
dinc[np][2] * t) * t) * ERFA_DAS2R; |
|
378
|
731
|
|
|
|
|
|
dom = eraAnpm((3600.0 * omega[np][0] + |
|
379
|
1462
|
|
|
|
|
|
(omega[np][1] + |
|
380
|
1462
|
|
|
|
|
|
omega[np][2] * t) * t) * ERFA_DAS2R); |
|
381
|
|
|
|
|
|
|
|
|
382
|
|
|
|
|
|
|
/* Apply the trigonometric terms. */ |
|
383
|
731
|
|
|
|
|
|
dmu = 0.35953620 * t; |
|
384
|
6579
|
100
|
|
|
|
|
for (k = 0; k < 8; k++) { |
|
385
|
5848
|
|
|
|
|
|
arga = kp[np][k] * dmu; |
|
386
|
5848
|
|
|
|
|
|
argl = kq[np][k] * dmu; |
|
387
|
17544
|
|
|
|
|
|
da += (ca[np][k] * cos(arga) + |
|
388
|
11696
|
|
|
|
|
|
sa[np][k] * sin(arga)) * 1e-7; |
|
389
|
17544
|
|
|
|
|
|
dl += (cl[np][k] * cos(argl) + |
|
390
|
11696
|
|
|
|
|
|
sl[np][k] * sin(argl)) * 1e-7; |
|
391
|
|
|
|
|
|
|
} |
|
392
|
731
|
|
|
|
|
|
arga = kp[np][8] * dmu; |
|
393
|
2193
|
|
|
|
|
|
da += t * (ca[np][8] * cos(arga) + |
|
394
|
1462
|
|
|
|
|
|
sa[np][8] * sin(arga)) * 1e-7; |
|
395
|
2193
|
100
|
|
|
|
|
for (k = 8; k < 10; k++) { |
|
396
|
1462
|
|
|
|
|
|
argl = kq[np][k] * dmu; |
|
397
|
4386
|
|
|
|
|
|
dl += t * (cl[np][k] * cos(argl) + |
|
398
|
2924
|
|
|
|
|
|
sl[np][k] * sin(argl)) * 1e-7; |
|
399
|
|
|
|
|
|
|
} |
|
400
|
731
|
|
|
|
|
|
dl = fmod(dl, ERFA_D2PI); |
|
401
|
|
|
|
|
|
|
|
|
402
|
|
|
|
|
|
|
/* Iterative soln. of Kepler's equation to get eccentric anomaly. */ |
|
403
|
731
|
|
|
|
|
|
am = dl - dp; |
|
404
|
731
|
|
|
|
|
|
ae = am + de * sin(am); |
|
405
|
|
|
|
|
|
|
k = 0; |
|
406
|
|
|
|
|
|
|
dae = 1.0; |
|
407
|
2902
|
50
|
|
|
|
|
while (k < KMAX && fabs(dae) > 1e-12) { |
|
|
|
100
|
|
|
|
|
|
|
408
|
2171
|
|
|
|
|
|
dae = (am - ae + de * sin(ae)) / (1.0 - de * cos(ae)); |
|
409
|
2171
|
|
|
|
|
|
ae += dae; |
|
410
|
2171
|
|
|
|
|
|
k++; |
|
411
|
2171
|
50
|
|
|
|
|
if (k == KMAX-1) jstat = 2; |
|
412
|
|
|
|
|
|
|
} |
|
413
|
|
|
|
|
|
|
|
|
414
|
|
|
|
|
|
|
/* True anomaly. */ |
|
415
|
731
|
|
|
|
|
|
ae2 = ae / 2.0; |
|
416
|
731
|
|
|
|
|
|
at = 2.0 * atan2(sqrt((1.0 + de) / (1.0 - de)) * sin(ae2), |
|
417
|
|
|
|
|
|
|
cos(ae2)); |
|
418
|
|
|
|
|
|
|
|
|
419
|
|
|
|
|
|
|
/* Distance (au) and speed (radians per day). */ |
|
420
|
731
|
|
|
|
|
|
r = da * (1.0 - de * cos(ae)); |
|
421
|
731
|
|
|
|
|
|
v = GK * sqrt((1.0 + 1.0 / amas[np]) / (da * da * da)); |
|
422
|
|
|
|
|
|
|
|
|
423
|
731
|
|
|
|
|
|
si2 = sin(di / 2.0); |
|
424
|
731
|
|
|
|
|
|
xq = si2 * cos(dom); |
|
425
|
731
|
|
|
|
|
|
xp = si2 * sin(dom); |
|
426
|
731
|
|
|
|
|
|
tl = at + dp; |
|
427
|
731
|
|
|
|
|
|
xsw = sin(tl); |
|
428
|
731
|
|
|
|
|
|
xcw = cos(tl); |
|
429
|
731
|
|
|
|
|
|
xm2 = 2.0 * (xp * xcw - xq * xsw); |
|
430
|
731
|
|
|
|
|
|
xf = da / sqrt(1 - de * de); |
|
431
|
731
|
|
|
|
|
|
ci2 = cos(di / 2.0); |
|
432
|
731
|
|
|
|
|
|
xms = (de * sin(dp) + xsw) * xf; |
|
433
|
731
|
|
|
|
|
|
xmc = (de * cos(dp) + xcw) * xf; |
|
434
|
731
|
|
|
|
|
|
xpxq2 = 2 * xp * xq; |
|
435
|
|
|
|
|
|
|
|
|
436
|
|
|
|
|
|
|
/* Position (J2000.0 ecliptic x,y,z in au). */ |
|
437
|
731
|
|
|
|
|
|
x = r * (xcw - xm2 * xp); |
|
438
|
731
|
|
|
|
|
|
y = r * (xsw + xm2 * xq); |
|
439
|
731
|
|
|
|
|
|
z = r * (-xm2 * ci2); |
|
440
|
|
|
|
|
|
|
|
|
441
|
|
|
|
|
|
|
/* Rotate to equatorial. */ |
|
442
|
731
|
|
|
|
|
|
pv[0][0] = x; |
|
443
|
731
|
|
|
|
|
|
pv[0][1] = y * COSEPS - z * SINEPS; |
|
444
|
731
|
|
|
|
|
|
pv[0][2] = y * SINEPS + z * COSEPS; |
|
445
|
|
|
|
|
|
|
|
|
446
|
|
|
|
|
|
|
/* Velocity (J2000.0 ecliptic xdot,ydot,zdot in au/d). */ |
|
447
|
731
|
|
|
|
|
|
x = v * (( -1.0 + 2.0 * xp * xp) * xms + xpxq2 * xmc); |
|
448
|
731
|
|
|
|
|
|
y = v * (( 1.0 - 2.0 * xq * xq) * xmc - xpxq2 * xms); |
|
449
|
731
|
|
|
|
|
|
z = v * (2.0 * ci2 * (xp * xms + xq * xmc)); |
|
450
|
|
|
|
|
|
|
|
|
451
|
|
|
|
|
|
|
/* Rotate to equatorial. */ |
|
452
|
731
|
|
|
|
|
|
pv[1][0] = x; |
|
453
|
731
|
|
|
|
|
|
pv[1][1] = y * COSEPS - z * SINEPS; |
|
454
|
731
|
|
|
|
|
|
pv[1][2] = y * SINEPS + z * COSEPS; |
|
455
|
|
|
|
|
|
|
|
|
456
|
|
|
|
|
|
|
} |
|
457
|
|
|
|
|
|
|
|
|
458
|
|
|
|
|
|
|
/* Return the status. */ |
|
459
|
731
|
|
|
|
|
|
return jstat; |
|
460
|
|
|
|
|
|
|
|
|
461
|
|
|
|
|
|
|
} |
|
462
|
|
|
|
|
|
|
/*---------------------------------------------------------------------- |
|
463
|
|
|
|
|
|
|
** |
|
464
|
|
|
|
|
|
|
** |
|
465
|
|
|
|
|
|
|
** Copyright (C) 2013-2019, NumFOCUS Foundation. |
|
466
|
|
|
|
|
|
|
** All rights reserved. |
|
467
|
|
|
|
|
|
|
** |
|
468
|
|
|
|
|
|
|
** This library is derived, with permission, from the International |
|
469
|
|
|
|
|
|
|
** Astronomical Union's "Standards of Fundamental Astronomy" library, |
|
470
|
|
|
|
|
|
|
** available from http://www.iausofa.org. |
|
471
|
|
|
|
|
|
|
** |
|
472
|
|
|
|
|
|
|
** The ERFA version is intended to retain identical functionality to |
|
473
|
|
|
|
|
|
|
** the SOFA library, but made distinct through different function and |
|
474
|
|
|
|
|
|
|
** file names, as set out in the SOFA license conditions. The SOFA |
|
475
|
|
|
|
|
|
|
** original has a role as a reference standard for the IAU and IERS, |
|
476
|
|
|
|
|
|
|
** and consequently redistribution is permitted only in its unaltered |
|
477
|
|
|
|
|
|
|
** state. The ERFA version is not subject to this restriction and |
|
478
|
|
|
|
|
|
|
** therefore can be included in distributions which do not support the |
|
479
|
|
|
|
|
|
|
** concept of "read only" software. |
|
480
|
|
|
|
|
|
|
** |
|
481
|
|
|
|
|
|
|
** Although the intent is to replicate the SOFA API (other than |
|
482
|
|
|
|
|
|
|
** replacement of prefix names) and results (with the exception of |
|
483
|
|
|
|
|
|
|
** bugs; any that are discovered will be fixed), SOFA is not |
|
484
|
|
|
|
|
|
|
** responsible for any errors found in this version of the library. |
|
485
|
|
|
|
|
|
|
** |
|
486
|
|
|
|
|
|
|
** If you wish to acknowledge the SOFA heritage, please acknowledge |
|
487
|
|
|
|
|
|
|
** that you are using a library derived from SOFA, rather than SOFA |
|
488
|
|
|
|
|
|
|
** itself. |
|
489
|
|
|
|
|
|
|
** |
|
490
|
|
|
|
|
|
|
** |
|
491
|
|
|
|
|
|
|
** TERMS AND CONDITIONS |
|
492
|
|
|
|
|
|
|
** |
|
493
|
|
|
|
|
|
|
** Redistribution and use in source and binary forms, with or without |
|
494
|
|
|
|
|
|
|
** modification, are permitted provided that the following conditions |
|
495
|
|
|
|
|
|
|
** are met: |
|
496
|
|
|
|
|
|
|
** |
|
497
|
|
|
|
|
|
|
** 1 Redistributions of source code must retain the above copyright |
|
498
|
|
|
|
|
|
|
** notice, this list of conditions and the following disclaimer. |
|
499
|
|
|
|
|
|
|
** |
|
500
|
|
|
|
|
|
|
** 2 Redistributions in binary form must reproduce the above copyright |
|
501
|
|
|
|
|
|
|
** notice, this list of conditions and the following disclaimer in |
|
502
|
|
|
|
|
|
|
** the documentation and/or other materials provided with the |
|
503
|
|
|
|
|
|
|
** distribution. |
|
504
|
|
|
|
|
|
|
** |
|
505
|
|
|
|
|
|
|
** 3 Neither the name of the Standards Of Fundamental Astronomy Board, |
|
506
|
|
|
|
|
|
|
** the International Astronomical Union nor the names of its |
|
507
|
|
|
|
|
|
|
** contributors may be used to endorse or promote products derived |
|
508
|
|
|
|
|
|
|
** from this software without specific prior written permission. |
|
509
|
|
|
|
|
|
|
** |
|
510
|
|
|
|
|
|
|
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
|
511
|
|
|
|
|
|
|
** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
|
512
|
|
|
|
|
|
|
** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
|
513
|
|
|
|
|
|
|
** FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE |
|
514
|
|
|
|
|
|
|
** COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, |
|
515
|
|
|
|
|
|
|
** INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |
|
516
|
|
|
|
|
|
|
** BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
|
517
|
|
|
|
|
|
|
** LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
|
518
|
|
|
|
|
|
|
** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
|
519
|
|
|
|
|
|
|
** LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
|
520
|
|
|
|
|
|
|
** ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
|
521
|
|
|
|
|
|
|
** POSSIBILITY OF SUCH DAMAGE. |
|
522
|
|
|
|
|
|
|
** |
|
523
|
|
|
|
|
|
|
*/ |