libTheSky
Routines to compute sky positions of Sun, Moon, planets and more
All Namespaces Files Functions Variables Pages
modules.f90
Go to the documentation of this file.
1!> \file modules.f90 Modules used by libTheSky
2
3
4! Copyright (c) 2002-2025 Marc van der Sluys - Nikhef/Utrecht University - marc.vandersluys.nl
5!
6! This file is part of the libTheSky package,
7! see: https://libthesky.sf.net/
8!
9! This is free software: you can redistribute it and/or modify it under the terms of the
10! European Union Public Licence 1.2 (EUPL 1.2).
11!
12! This software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13! without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14! See the EU Public Licence for more details.
15!
16! You should have received a copy of the European Union Public Licence along with this code.
17! If not, see <https://www.eupl.eu/1.2/en/>.
18
19
20!***********************************************************************************************************************************
21!> \brief Constants used in libTheSky
22
24 use sufr_kinds, only: double
25 implicit none
26 save
27 private :: double
28
29 integer, parameter :: deltat_nmax = 1000 !< Maximum number of Delta-T measurements. Need ~430 until 2000
30 real(double) :: deltat_values(deltat_nmax) !< Values of DeltaT
31 real(double) :: deltat_years(deltat_nmax) !< Years for DeltaT values
32 real(double) :: deltat_accel !< Acceleration for DeltaT parabola
33 real(double) :: deltat_change !< Change for DeltaT parabola
34 real(double) :: deltat_0 !< Zero point for DeltaT parabola
35 real(double) :: deltat_forced !< Forced value for DeltaT, overriding computation
36 real(double) :: jd1820 !< JD of 1820.0, for DeltaT
37
38 integer :: deltat_n !< Actual number of DeltaT measurements
39 integer :: deltat_minyr !< Start year of DeltaT measurements
40 integer :: deltat_maxyr !< End year of DeltaT measurements
41
42 integer :: thesky_verbosity !< Verbosity of libTheSky output
43
44 real(double) :: nutationdat(9,63) !< Data for simple nutation function
45
46 character :: theskydatadir*(99) !< Directory containing data files for libTheSky
47 character :: library_name*(99) !< Name of this library
48
49end module thesky_constants
50!***********************************************************************************************************************************
51
52
53!***********************************************************************************************************************************
54!> \brief Local parameters for libTheSky: location, date, time
55
57 use sufr_kinds, only: double
58 implicit none
59 save
60 private :: double
61
62 integer, parameter :: maxlocs = 100 !< Maximum number of observation locations
63 real(double) :: lat0 !< Latitude of the observer (rad)
64 real(double) :: lon0 !< Longitude of the observer (rad)
65 real(double) :: height !< Altitude of the observer above sea level (m)
66 real(double) :: deltat !< Current value of DeltaT (s)
67 real(double) :: tz !< Current value of time zone, taking into account DST (hours; >0 is east of Greenwich)
68 real(double) :: tz0 !< Standard value of time zone, without DST ("winter time"; hours; >0 is east of Greenwich)
69 real(double) :: second !< Seconds of time of current instant
70 real(double) :: day !< Day of month of current instant, with decimals if desired
71
72 integer :: year !< Year CE of current instant
73 integer :: month !< Month of year of current instant
74 integer :: hour !< Hour of time of current instant
75 integer :: minute !< Minute of time of current instant
76 integer :: dsttp !< DST type for current location (0: none, 1: EU, 2: USA+Canada (after 2007)
77
78end module thesky_local
79!***********************************************************************************************************************************
80
81
82!***********************************************************************************************************************************
83!> \brief Planet data, needed to compute planet positions
84
86 use sufr_kinds, only: double, long
87 implicit none
88 save
89 private :: double, long
90
91 integer, parameter :: nasteroids=1000 !< Number of entries in the asteroids array. Nasteroids is actually much larger; look at the first Nasteroids asteroids only
92
93 integer :: moonla_arg(8,60) !< Arguments for the low-accuracy (la) Moon position
94 integer(long) :: moonla_lrb(3,60) !< L,B,R data for the low-accuracy (la) Moon position
95
96 integer :: pluc(43,3) !< Constants for the periodic terms for the position of Pluto
97 integer :: plul(43,2) !< Constants for the longitude of Pluto
98 integer :: plub(43,2) !< Constants for the latitude of Pluto
99 integer :: plur(43,2) !< Constants for the distance of Pluto
100
101 integer :: pl0 !< Remember a special planet
102
103 integer :: vsopnls(3,8) !< Numbers of lines in the VSOP input files (l,b,r x 8 pl)
104 integer :: vsopnblk(0:5,3,8) !< Line number in the VSOP data where the next block of (Planet, Variable (LBR), Power) starts
105
106 real(double) :: vsopdat(4,6827,10) !< Periodic terms for VSOP87
107 real(double) :: vsoptruncs(3,8) !< Truncuate VSOP87 terms at these accuracies
108
109 real(double) :: plelems(8,6) !< Planet orbital elements for Equation of Data
110 real(double) :: plelems2000(8,6) !< Planet orbital elements for J2000
111 real(double) :: plelemdata(2,8,6,0:3) !< Data to compute planet orbital elements
112
113 real(double) :: asterelems(nasteroids,9) !< Asteroid orbital elements
114 character :: asternames(nasteroids)*(18) !< Names of the asteroids
115
116 integer, parameter :: nplanpos=100 !< Number of entries in the planpos array
117 !> \brief Planpos[] is an array with many different types of coordinates and related variables:
118 !!
119 !! Geocentric (mostly) coordinates:
120 !! - 1 = gcl = Apparent geocentric ecliptic longitude
121 !! - 2 = gcb = Apparent geocentric ecliptic latitude
122 !! - 3 = r = True heliocentric distance
123 !! - 4 = delta = Apparent geocentric distance
124 !! - 5 = ra = Apparent geocentric R.A.
125 !! - 6 = dec = Apparent geocentric declination
126 !! - 7 = tau = Geocentric light time in days
127 !! - 8 = hh = Apparent geocentric hour angle
128 !! - 9 = az = Apparent geocentric azimuth
129 !! - 10 = alt = Apparent geocentric altitude
130 !! - 11 = elon = Apparent TOPOCENTRIC elongation, using topocentric altitude and correcting for refraction
131 !! - 12 = diam = Apparent geocentric apparent diameter
132 !!
133 !! Magnitude, phase, parallax:
134 !! - 13 = magn = Apparent visual magnitude
135 !! - 14 = k = Illuminated fraction
136 !! - 15 = pa = Phase angle
137 !! - 16 = parang = Topocentric parallactic angle
138 !! - 17 = hp = Horizontal parallax
139 !!
140 !! Topocentric (mostly) coordinates:
141 !! - 21 = topl = Apparent topocentric ecliptic longitude
142 !! - 22 = topb = Apparent topocentric ecliptic latitude
143 !! - 23 = delta0 = True geocentric distance
144 !! - 24 = topdelta = Apparent topocentric distance
145 !! - 25 = topra = Apparent topocentric R.A.
146 !! - 26 = topdec = Apparent topocentric declination
147 !!
148 !! - 28 = tophh = Apparent topocentric hour angle
149 !! - 29 = topaz = Apparent topocentric azimuth
150 !! - 30 = topalt = Apparent topocentric altitude
151 !! - 31 = topalt + refract = Apparent topocentric altitude, corrected for refraction
152 !! - 32 = topdiam = Apparent topocentric apparent diameter
153 !!
154 !! Heliocentric coordinates:
155 !! - 33 = l = Apparent heliocentric ecliptic longitude
156 !! - 34 = b = Apparent heliocentric ecliptic latitude
157 !! - 35 = r = Apparent heliocentric distance
158 !! - 36 = hcl00 = True heliocentric ecliptic longitude, FK5
159 !! - 37 = hcb00 = True heliocentric ecliptic latitude, FK5
160 !! - 38 = hcr00 = True heliocentric distance
161 !!
162 !! Other variables:
163 !! - 39 = pl = Planet for which data were computed
164 !! - 40 = jde = JDE for the instance of calculation
165 !! - 41 = l0+pi = True geocentric ecliptic longitude for the Sun, in FK5
166 !! - 42 = -b0 = True geocentric ecliptic latitude for the Sun, in FK5
167 !! - 43 = r0 = True geocentric distance for the Sun
168 !! - 44 = lst = Local APPARENT siderial time (radians)
169 !! - 45 = agst = Greenwich APPARENT siderial time (radians)
170 !! - 46 = t0 * 10.d0 = Apparent dynamical time in Julian Centuries since 2000.0
171 !! - 47 = dpsi = Nutation in longitude
172 !! - 48 = eps = True obliquity of the ecliptic, corrected for nutation
173 !! - 49 = gmst = Greenwich MEAN siderial time (radians)
174 !! - 50 = eps0 = Mean obliquity of the ecliptic, without nutation
175 !!
176 !! More geocentric coordinates:
177 !! - 51 = sun_gcl,b = Apparent geocentric longitude of the Sun (variable was treated as if pl.eq.3)
178 !! - 52 = sun_gcl,b = Apparent geocentric latitude of the Sun (variable was treated as if pl.eq.3)
179 !!
180 !! - 61 = gcx = Apparent geocentric x
181 !! - 62 = gcy = Apparent geocentric y
182 !! - 63 = gcz = Apparent geocentric z
183 !!
184 !! - 64 = gcx0 = True geocentric x
185 !! - 65 = gcy0 = True geocentric y
186 !! - 66 = gcz0 = True geocentric z
187 !!
188 !! - 67 = gcl0 = True geocentric ecliptic longitude
189 !! - 68 = gcb0 = True geocentric ecliptic latitude
190 !! - 69 = delta0 = True geocentric distance
191
192 real(double) :: planpos(nplanpos)
193 character :: plcon(0:19)*(3) !< Constellation abbreviation for the planets (0-9) and bright stars
194
195end module thesky_planetdata
196!***********************************************************************************************************************************
197
198
199!***********************************************************************************************************************************
200!> \brief ELP 2000-82B Moon data, needed to compute Moon positions
201
203 use sufr_kinds, only: double
204 implicit none
205 save
206 private :: double
207
208 real(double), parameter :: c1=1.d0/60.d0 !< Constant for ELP 2000-82B theory (arcminutes to degrees)
209 real(double), parameter :: c2=1.d0/3600.d0 !< Constant for ELP 2000-82B theory (arcseconds to degrees)
210 real(double), parameter :: ath=384747.9806743165d0 !< Constant for ELP 2000-82B theory (orbital separation?)
211 real(double), parameter :: a0=384747.9806448954d0 !< Constant for ELP 2000-82B theory (orbital separation?)
212
213 real(double) :: p1 !< Precession sine coefficient for ELP 2000-82B theory
214 real(double) :: p2 !< Precession sine coefficient for ELP 2000-82B theory
215 real(double) :: p3 !< Precession sine coefficient for ELP 2000-82B theory
216 real(double) :: p4 !< Precession sine coefficient for ELP 2000-82B theory
217 real(double) :: p5 !< Precession sine coefficient for ELP 2000-82B theory
218
219 real(double) :: q1 !< Precession cosine coefficient for ELP 2000-82B theory
220 real(double) :: q2 !< Precession cosine coefficient for ELP 2000-82B theory
221 real(double) :: q3 !< Precession cosine coefficient for ELP 2000-82B theory
222 real(double) :: q4 !< Precession cosine coefficient for ELP 2000-82B theory
223 real(double) :: q5 !< Precession cosine coefficient for ELP 2000-82B theory
224
225 real(double) :: w(3,0:4) !< Constants for mean longitude
226 real(double) :: eart(0:4) !< Earth-Moon barycentre (EMB) elements
227 real(double) :: peri(0:4) !< Mean longitude of the perihelion of the Earth-Moon barycentre (EMB)
228 real(double) :: p(8,0:1) !< Planetary arguments: mean longitudes and mean motions
229
230 real(double) :: del(4,0:4) !< Delaunay's variables (https://en.wikipedia.org/wiki/Orbital_elements#Delaunay_variables)
231 real(double) :: zeta(0:1) !< Mean longitude (w) + rate precession (?)
232 real(double) :: t(0:4) !< Array for time^0, ..., time^4
233
234 real(double) :: pre(3) !< CHECK: does this actually do anything?
235 real(double) :: coef(7) !< CHECK: Coefficients in ELP 2000-82B data file (float)
236 real(double) :: zone(6) !< CHECK: Something in ELP 2000-82B theory
237 real(double) :: pc1(6,1023) !< CHECK: Something in ELP 2000-82B theory
238 real(double) :: pc2(6,918) !< CHECK: Something in ELP 2000-82B theory
239 real(double) :: pc3(6,704) !< CHECK: Something in ELP 2000-82B theory
240 real(double) :: per1(3,19537) !< CHECK: Something in ELP 2000-82B theory
241 real(double) :: per2(3,6766) !< CHECK: Something in ELP 2000-82B theory
242 real(double) :: per3(3,8924) !< CHECK: Something in ELP 2000-82B theory
243
244 integer :: ilu(4) !< CHECK: Coefficients in ELP 2000-82B data file (integer)
245 integer :: ipla(11) !< CHECK: Coefficients in ELP 2000-82B data file (integer)
246 integer :: nterm(3,12) !< CHECK: Number of terms? in ELP 2000-82B data file
247 integer :: nrang(3,0:12) !< CHECK: Number of terms? in ELP 2000-82B data file
248
249 real(double) :: prec0 !< CHECK: Something in ELP 2000-82B theory
250 integer :: ideb !< Memorise whether this routine has been run before
251
252 data ideb/0/, prec0/-1.d0/, t/1.d0,4*0.d0/
253
254end module thesky_moondata
255!***********************************************************************************************************************************
256
257
258!***************************************************************************************************
259! \brief Constants for the ELP-MPP02 lunar theory
260
261module thesky_elp_mpp02_constants
262 use sufr_kinds, only: double
263
264 implicit none
265 real(double) :: w(3,0:4) !< Constants for mean longitude
266 real(double) :: eart(0:4) !< Earth-Moon barycentre (EMB) elements
267 real(double) :: peri(0:4) !< Mean longitude of the perihelion of the Earth-Moon barycentre (EMB)
268 real(double) :: zeta(0:4) !< Mean longitude (w) + rate precession (?)
269 real(double) :: del(4,0:4) !< Delaunay's variables (https://en.wikipedia.org/wiki/Orbital_elements#Delaunay_variables)
270
271 real(double) :: p(8,0:4) !< Planetary arguments: mean longitudes, mean motions, ...?
272
273 real(double) :: delnu !< Corrections of the constants (fit to DE200/LE200) (?)
274 real(double) :: dele !< Corrections of the constants (fit to DE200/LE200) (?)
275 real(double) :: delg !< Corrections of the constants (fit to DE200/LE200) (?)
276 real(double) :: delnp !< Corrections of the constants (fit to DE200/LE200) (?)
277 real(double) :: delep !< Corrections of the constants (fit to DE200/LE200) (?)
278
279 real(double) :: am !< Ratio of the mean motions (EMB / Moon)
280 real(double) :: dtasm !< 2/3 of product of (ratio of the semi-major axes) x (ratio of the mean motions) (Moon / EMB) ???
281
282 real(double) :: p1 !< Precession sine coefficient for ELP MPP02 theory
283 real(double) :: p2 !< Precession sine coefficient for ELP MPP02 theory
284 real(double) :: p3 !< Precession sine coefficient for ELP MPP02 theory
285 real(double) :: p4 !< Precession sine coefficient for ELP MPP02 theory
286 real(double) :: p5 !< Precession sine coefficient for ELP MPP02 theory
287
288 real(double) :: q1 !< Precession cosine coefficient for ELP MPP02 theory
289 real(double) :: q2 !< Precession cosine coefficient for ELP MPP02 theory
290 real(double) :: q3 !< Precession cosine coefficient for ELP MPP02 theory
291 real(double) :: q4 !< Precession cosine coefficient for ELP MPP02 theory
292 real(double) :: q5 !< Precession cosine coefficient for ELP MPP02 theory
293
294
295end module thesky_elp_mpp02_constants
296!***************************************************************************************************
297
298
299!***************************************************************************************************
300! \brief Data series for the ELP-MPP02 lunar theory
301
302module thesky_elp_mpp02_series
303 use sufr_kinds, only: double
304
305 implicit none
306 integer, parameter, private :: max1=2645, max2=33256
307 integer :: nmpb(3,3) !< Number of lines in the file for the main problem
308 integer :: nper(3,0:3,3) !< Number of lines in the file for the perturbation
309
310 real(double) :: cmpb(max1) !< Coefficients? for the main problem
311 real(double) :: fmpb(0:4,max1) !< Factors? for the main problem
312 real(double) :: cper(max2) !< Coefficients? for the perturbation series
313 real(double) :: fper(0:4,max2) !< Factors? for the perturbation series
314
315end module thesky_elp_mpp02_series
316!***************************************************************************************************
317
318
319!***********************************************************************************************************************************
320!> \brief Data to compute comet positions
321
323 use sufr_kinds, only: double
324 implicit none
325 save
326 private :: double
327
328 integer, parameter :: ncometsmax=10000 !< Size of comet database
329 integer :: ncomets !< Actual number of comets in database
330 integer :: cometdatfile !< Data file to use 1: comets.dat (MANY comets, no magnitude info), 2: comets_mpc.dat (currently visible comets + magn. info)
331 logical :: cometdiedatp(ncometsmax) !< This comet died at perihelion (true/false)
332 real(double) :: cometelems(ncometsmax,9) !< Orbital elements of the comets: 1: JD of epoch (often J2000), 2: Perihelion distance (AU?), 3: Eccentricity, 4: Inclination, 5: Argument of perihelion (omega), 6: Longitude of ascending node (OMEGA) i, 7: JD of perihelion
333 real(double) :: comepoche !< JD of epoch (often J2000) == cometelems(i,1)
334 character :: cometnames(ncometsmax)*(60) !< Names of the comets
335
336end module thesky_cometdata
337!***********************************************************************************************************************************
338
339
340!***********************************************************************************************************************************
341!> \brief Star and basic constellation data
342
344 use sufr_kinds, only: double
345 implicit none
346 save
347 private :: double
348
349 ! Selected bright stars close to the ecliptic:
350 integer, parameter :: nstars=17 !< Number of bright stars close to the ecliptic (including Pleiades)
351
352 real(double) :: starra(nstars) !< Right ascensions of the bright, ecliptical stars
353 real(double) :: stardec(nstars) !< Declinations of the bright, ecliptical stars
354 real(double) :: starl(nstars) !< Ecliptic longitudes of the bright, ecliptical stars
355 real(double) :: starb(nstars) !< Ecliptic latitudes of the bright, ecliptical stars
356
357 real :: starmags(nstars) !< Magnitudes of the bright, ecliptical stars
358 real :: starrads(nstars) !< Radii of the bright, ecliptical stars (only non-zero for Pleiades)
359
360 character :: starnames(nstars)*(10) !< English names of the bright, ecliptical stars
361 character :: starnamesnl(nstars)*(11) !< Dutch names of the bright, ecliptical stars
362 character :: starcons(nstars)*(10) !< Latin/English constellation names for the bright, ecliptical stars
363 character :: starconsnl(nstars)*(10) !< Dutch constellation names for the bright, ecliptical stars
364 character :: starconsabr(nstars)*(3) !< Constellation abbreviations for the bright, ecliptical stars
365
366 ! Constellations:
367 integer, parameter :: nconstel=88 !< Number of constellations
368 integer, parameter :: nconid=357 !< Number of data points for constellation ID
369 integer :: conid(nconid) !< Constellation ID
370
371 real(double) :: conidral(nconid) !< Constellation lower RA boundary for ID
372 real(double) :: conidrau(nconid) !< Constellation uppwer RA boundary for ID
373 real(double) :: coniddecl(nconid) !< Constellation lower declination boundary for ID
374
375 character :: conabr(nconstel)*(3) !< Abbreviations of the constellations
376 character :: conidabr(nconid)*(3) !< Abbreviations of the constellation IDs
377
378 character :: latconnames(nconstel)*(19) !< Latin constellation names
379 character :: genconnames(nconstel)*(19) !< Genitives of the Latin constellation names
380 character :: nlconnames(nconstel)*(17) !< Dutch constellation names
381 character :: enconnames(nconstel)*(18) !< English constellation names
382
383end module thesky_stardata
384!***********************************************************************************************************************************
385
386
387!***********************************************************************************************************************************
388!> \brief Data from the Bright Star Catalogue (BSC)
389
391 use sufr_kinds, only: double
392 implicit none
393 save
394 private :: double
395
396 integer, parameter :: n_bsc=9110 !< Size of the Bright Star Catalogue (BSC)
397 integer :: bsc_sao(n_bsc) !< SAO numbers of the BSC stars
398 integer :: bsc_vm_indx(n_bsc) !< Index array for sorting to visual magnitude
399
400 real(double) :: bsc_ra(n_bsc) !< Right ascensions of the BSC stars
401 real(double) :: bsc_dec(n_bsc) !< Declinations of the BSC stars
402 real(double) :: bsc_pma(n_bsc) !< Proper motions in RA of the BSC stars
403 real(double) :: bsc_pmd(n_bsc) !< Proper motions in declination of the BSC stars
404 real(double) :: bsc_rv(n_bsc) !< Radial velocities of the BSC stars
405 real(double) :: bsc_vm(n_bsc) !< Visual magnitudes of the BSC stars
406
407 real(double) :: bsc_par(n_bsc) !< Parallaxes of the BSC stars
408 real(double) :: bsc_bv(n_bsc) !< B-V colours of the BSC stars
409 real(double) :: bsc_ub(n_bsc) !< U-B colours of the BSC stars
410 real(double) :: bsc_ri(n_bsc) !< R-I colours of the BSC stars
411
412 character :: bsc_name(n_bsc)*(10) !< Proper names of the BSC stars
413 character :: bsc_abbr(n_bsc)*(10) !< Abbreviated names/codes for the BSC stars
414 character :: bsc_mult(n_bsc) !< Multiplicity codes for the BSC stars
415 character :: bsc_var(n_bsc) !< Variability codes for the BSC stars
416 character :: bsc_sptype(n_bsc)*(20) !< Spectral types of the BSC stars
417
418end module thesky_bscdata
419!***********************************************************************************************************************************
420
421
Data from the Bright Star Catalogue (BSC)
Definition modules.f90:390
integer, parameter n_bsc
Size of the Bright Star Catalogue (BSC)
Definition modules.f90:396
real(double), dimension(n_bsc) bsc_bv
B-V colours of the BSC stars.
Definition modules.f90:408
real(double), dimension(n_bsc) bsc_ub
U-B colours of the BSC stars.
Definition modules.f90:409
real(double), dimension(n_bsc) bsc_dec
Declinations of the BSC stars.
Definition modules.f90:401
real(double), dimension(n_bsc) bsc_par
Parallaxes of the BSC stars.
Definition modules.f90:407
character, dimension(10) bsc_abbr
Abbreviated names/codes for the BSC stars.
Definition modules.f90:413
real(double), dimension(n_bsc) bsc_vm
Visual magnitudes of the BSC stars.
Definition modules.f90:405
character, dimension(n_bsc) bsc_mult
Multiplicity codes for the BSC stars.
Definition modules.f90:414
real(double), dimension(n_bsc) bsc_pmd
Proper motions in declination of the BSC stars.
Definition modules.f90:403
character, dimension(20) bsc_sptype
Spectral types of the BSC stars.
Definition modules.f90:416
character, dimension(10) bsc_name
Proper names of the BSC stars.
Definition modules.f90:412
real(double), dimension(n_bsc) bsc_rv
Radial velocities of the BSC stars.
Definition modules.f90:404
real(double), dimension(n_bsc) bsc_pma
Proper motions in RA of the BSC stars.
Definition modules.f90:402
real(double), dimension(n_bsc) bsc_ra
Right ascensions of the BSC stars.
Definition modules.f90:400
integer, dimension(n_bsc) bsc_sao
SAO numbers of the BSC stars.
Definition modules.f90:397
real(double), dimension(n_bsc) bsc_ri
R-I colours of the BSC stars.
Definition modules.f90:410
integer, dimension(n_bsc) bsc_vm_indx
Index array for sorting to visual magnitude.
Definition modules.f90:398
character, dimension(n_bsc) bsc_var
Variability codes for the BSC stars.
Definition modules.f90:415
Data to compute comet positions.
Definition modules.f90:322
integer, parameter ncometsmax
Size of comet database.
Definition modules.f90:328
logical, dimension(ncometsmax) cometdiedatp
This comet died at perihelion (true/false)
Definition modules.f90:331
real(double), dimension(ncometsmax, 9) cometelems
Orbital elements of the comets: 1: JD of epoch (often J2000), 2: Perihelion distance (AU?...
Definition modules.f90:332
real(double) comepoche
JD of epoch (often J2000) == cometelems(i,1)
Definition modules.f90:333
character, dimension(60) cometnames
Names of the comets.
Definition modules.f90:334
integer ncomets
Actual number of comets in database.
Definition modules.f90:329
integer cometdatfile
Data file to use 1: comets.dat (MANY comets, no magnitude info), 2: comets_mpc.dat (currently visible...
Definition modules.f90:330
Constants used in libTheSky.
Definition modules.f90:23
character, dimension(99) library_name
Name of this library.
Definition modules.f90:47
integer thesky_verbosity
Verbosity of libTheSky output.
Definition modules.f90:42
real(double) deltat_forced
Forced value for DeltaT, overriding computation.
Definition modules.f90:35
integer, parameter deltat_nmax
Maximum number of Delta-T measurements. Need ~430 until 2000.
Definition modules.f90:29
real(double) deltat_accel
Acceleration for DeltaT parabola.
Definition modules.f90:32
integer deltat_minyr
Start year of DeltaT measurements.
Definition modules.f90:39
real(double) deltat_change
Change for DeltaT parabola.
Definition modules.f90:33
real(double) jd1820
JD of 1820.0, for DeltaT.
Definition modules.f90:36
character, dimension(99) theskydatadir
Directory containing data files for libTheSky.
Definition modules.f90:46
real(double), dimension(deltat_nmax) deltat_values
Values of DeltaT.
Definition modules.f90:30
integer deltat_n
Actual number of DeltaT measurements.
Definition modules.f90:38
real(double) deltat_0
Zero point for DeltaT parabola.
Definition modules.f90:34
real(double), dimension(9, 63) nutationdat
Data for simple nutation function.
Definition modules.f90:44
real(double), dimension(deltat_nmax) deltat_years
Years for DeltaT values.
Definition modules.f90:31
integer deltat_maxyr
End year of DeltaT measurements.
Definition modules.f90:40
Local parameters for libTheSky: location, date, time.
Definition modules.f90:56
integer, parameter maxlocs
Maximum number of observation locations.
Definition modules.f90:62
real(double) second
Seconds of time of current instant.
Definition modules.f90:69
integer month
Month of year of current instant.
Definition modules.f90:73
integer minute
Minute of time of current instant.
Definition modules.f90:75
real(double) tz
Current value of time zone, taking into account DST (hours; >0 is east of Greenwich)
Definition modules.f90:67
real(double) height
Altitude of the observer above sea level (m)
Definition modules.f90:65
real(double) tz0
Standard value of time zone, without DST ("winter time"; hours; >0 is east of Greenwich)
Definition modules.f90:68
real(double) lon0
Longitude of the observer (rad)
Definition modules.f90:64
real(double) deltat
Current value of DeltaT (s)
Definition modules.f90:66
real(double) lat0
Latitude of the observer (rad)
Definition modules.f90:63
integer hour
Hour of time of current instant.
Definition modules.f90:74
real(double) day
Day of month of current instant, with decimals if desired.
Definition modules.f90:70
integer dsttp
DST type for current location (0: none, 1: EU, 2: USA+Canada (after 2007)
Definition modules.f90:76
integer year
Year CE of current instant.
Definition modules.f90:72
ELP 2000-82B Moon data, needed to compute Moon positions.
Definition modules.f90:202
real(double), parameter a0
Constant for ELP 2000-82B theory (orbital separation?)
Definition modules.f90:211
real(double), dimension(4, 0:4) del
Delaunay's variables (https://en.wikipedia.org/wiki/Orbital_elements#Delaunay_variables)
Definition modules.f90:230
real(double) q5
Precession cosine coefficient for ELP 2000-82B theory.
Definition modules.f90:223
real(double) q3
Precession cosine coefficient for ELP 2000-82B theory.
Definition modules.f90:221
real(double), dimension(3, 0:4) w
Constants for mean longitude.
Definition modules.f90:225
integer, dimension(3, 0:12) nrang
CHECK: Number of terms? in ELP 2000-82B data file.
Definition modules.f90:247
real(double), parameter c1
Constant for ELP 2000-82B theory (arcminutes to degrees)
Definition modules.f90:208
real(double) p3
Precession sine coefficient for ELP 2000-82B theory.
Definition modules.f90:215
real(double) q4
Precession cosine coefficient for ELP 2000-82B theory.
Definition modules.f90:222
real(double), dimension(0:4) peri
Mean longitude of the perihelion of the Earth-Moon barycentre (EMB)
Definition modules.f90:227
real(double), dimension(6, 704) pc3
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:239
real(double), dimension(0:1) zeta
Mean longitude (w) + rate precession (?)
Definition modules.f90:231
real(double) q2
Precession cosine coefficient for ELP 2000-82B theory.
Definition modules.f90:220
real(double), dimension(6, 918) pc2
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:238
real(double) prec0
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:249
real(double), dimension(6, 1023) pc1
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:237
real(double), dimension(3, 19537) per1
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:240
integer ideb
Memorise whether this routine has been run before.
Definition modules.f90:250
real(double), parameter ath
Constant for ELP 2000-82B theory (orbital separation?)
Definition modules.f90:210
real(double), dimension(8, 0:1) p
Planetary arguments: mean longitudes and mean motions.
Definition modules.f90:228
real(double), dimension(0:4) t
Array for time^0, ..., time^4.
Definition modules.f90:232
integer, dimension(3, 12) nterm
CHECK: Number of terms? in ELP 2000-82B data file.
Definition modules.f90:246
real(double), dimension(3, 6766) per2
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:241
integer, dimension(4) ilu
CHECK: Coefficients in ELP 2000-82B data file (integer)
Definition modules.f90:244
real(double) p5
Precession sine coefficient for ELP 2000-82B theory.
Definition modules.f90:217
real(double) p2
Precession sine coefficient for ELP 2000-82B theory.
Definition modules.f90:214
real(double) p1
Precession sine coefficient for ELP 2000-82B theory.
Definition modules.f90:213
real(double), dimension(0:4) eart
Earth-Moon barycentre (EMB) elements.
Definition modules.f90:226
integer, dimension(11) ipla
CHECK: Coefficients in ELP 2000-82B data file (integer)
Definition modules.f90:245
real(double), parameter c2
Constant for ELP 2000-82B theory (arcseconds to degrees)
Definition modules.f90:209
real(double), dimension(6) zone
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:236
real(double) q1
Precession cosine coefficient for ELP 2000-82B theory.
Definition modules.f90:219
real(double), dimension(7) coef
CHECK: Coefficients in ELP 2000-82B data file (float)
Definition modules.f90:235
real(double) p4
Precession sine coefficient for ELP 2000-82B theory.
Definition modules.f90:216
real(double), dimension(3, 8924) per3
CHECK: Something in ELP 2000-82B theory.
Definition modules.f90:242
real(double), dimension(3) pre
CHECK: does this actually do anything?
Definition modules.f90:234
Planet data, needed to compute planet positions.
Definition modules.f90:85
real(double), dimension(4, 6827, 10) vsopdat
Periodic terms for VSOP87.
Definition modules.f90:106
integer(long), dimension(3, 60) moonla_lrb
L,B,R data for the low-accuracy (la) Moon position.
Definition modules.f90:94
character, dimension(18) asternames
Names of the asteroids.
Definition modules.f90:114
integer, dimension(43, 2) plub
Constants for the latitude of Pluto.
Definition modules.f90:98
integer, dimension(3, 8) vsopnls
Numbers of lines in the VSOP input files (l,b,r x 8 pl)
Definition modules.f90:103
integer, parameter nplanpos
Number of entries in the planpos array.
Definition modules.f90:116
real(double), dimension(8, 6) plelems
Planet orbital elements for Equation of Data.
Definition modules.f90:109
integer pl0
Remember a special planet.
Definition modules.f90:101
character, dimension(3) plcon
Constellation abbreviation for the planets (0-9) and bright stars.
Definition modules.f90:193
real(double), dimension(nplanpos) planpos
Planpos[] is an array with many different types of coordinates and related variables:
Definition modules.f90:192
real(double), dimension(8, 6) plelems2000
Planet orbital elements for J2000.
Definition modules.f90:110
integer, dimension(43, 2) plur
Constants for the distance of Pluto.
Definition modules.f90:99
real(double), dimension(3, 8) vsoptruncs
Truncuate VSOP87 terms at these accuracies.
Definition modules.f90:107
real(double), dimension(2, 8, 6, 0:3) plelemdata
Data to compute planet orbital elements.
Definition modules.f90:111
integer, dimension(43, 3) pluc
Constants for the periodic terms for the position of Pluto.
Definition modules.f90:96
integer, dimension(43, 2) plul
Constants for the longitude of Pluto.
Definition modules.f90:97
integer, dimension(8, 60) moonla_arg
Arguments for the low-accuracy (la) Moon position.
Definition modules.f90:93
integer, parameter nasteroids
Number of entries in the asteroids array. Nasteroids is actually much larger; look at the first Naste...
Definition modules.f90:91
integer, dimension(0:5, 3, 8) vsopnblk
Line number in the VSOP data where the next block of (Planet, Variable (LBR), Power) starts.
Definition modules.f90:104
real(double), dimension(nasteroids, 9) asterelems
Asteroid orbital elements.
Definition modules.f90:113
Star and basic constellation data.
Definition modules.f90:343
character, dimension(19) latconnames
Latin constellation names.
Definition modules.f90:378
character, dimension(10) starconsnl
Dutch constellation names for the bright, ecliptical stars.
Definition modules.f90:363
character, dimension(3) conidabr
Abbreviations of the constellation IDs.
Definition modules.f90:376
character, dimension(17) nlconnames
Dutch constellation names.
Definition modules.f90:380
real(double), dimension(nstars) starb
Ecliptic latitudes of the bright, ecliptical stars.
Definition modules.f90:355
real(double), dimension(nstars) starra
Right ascensions of the bright, ecliptical stars.
Definition modules.f90:352
integer, parameter nconid
Number of data points for constellation ID.
Definition modules.f90:368
character, dimension(19) genconnames
Genitives of the Latin constellation names.
Definition modules.f90:379
character, dimension(10) starcons
Latin/English constellation names for the bright, ecliptical stars.
Definition modules.f90:362
integer, parameter nconstel
Number of constellations.
Definition modules.f90:367
real, dimension(nstars) starmags
Magnitudes of the bright, ecliptical stars.
Definition modules.f90:357
real(double), dimension(nconid) coniddecl
Constellation lower declination boundary for ID.
Definition modules.f90:373
character, dimension(18) enconnames
English constellation names.
Definition modules.f90:381
real, dimension(nstars) starrads
Radii of the bright, ecliptical stars (only non-zero for Pleiades)
Definition modules.f90:358
real(double), dimension(nconid) conidrau
Constellation uppwer RA boundary for ID.
Definition modules.f90:372
real(double), dimension(nstars) starl
Ecliptic longitudes of the bright, ecliptical stars.
Definition modules.f90:354
real(double), dimension(nstars) stardec
Declinations of the bright, ecliptical stars.
Definition modules.f90:353
character, dimension(10) starnames
English names of the bright, ecliptical stars.
Definition modules.f90:360
character, dimension(3) starconsabr
Constellation abbreviations for the bright, ecliptical stars.
Definition modules.f90:364
integer, dimension(nconid) conid
Constellation ID.
Definition modules.f90:369
character, dimension(3) conabr
Abbreviations of the constellations.
Definition modules.f90:375
integer, parameter nstars
Number of bright stars close to the ecliptic (including Pleiades)
Definition modules.f90:350
character, dimension(11) starnamesnl
Dutch names of the bright, ecliptical stars.
Definition modules.f90:361
real(double), dimension(nconid) conidral
Constellation lower RA boundary for ID.
Definition modules.f90:371