libTheSky
Routines to compute sky positions of Sun, Moon, planets and more
All Namespaces Files Functions Variables Pages
thesky_data Module Reference

Procedures to set constants and read data files. More...

Functions/Subroutines

subroutine set_thesky_constants ()
 Set the initial values of the variables and constants used in this package.
 
subroutine thesky_readdata ()
 Read input data files.
 
subroutine read_deltat ()
 Read deltat.dat with historical values for DeltaT.
 
subroutine readconstellations ()
 Read constellation names: abbreviation, Latin, genitive, Dutch and English.
 
subroutine readnutation ()
 Read nutation input files.
 
subroutine readplanetdata ()
 Reads VSOP planet data from planets.dat.
 
subroutine readpluto ()
 Read periodic terms for the position of Pluto.
 
subroutine readplanetelements ()
 Read the data needed to compute the orbital elements of the planets.
 
subroutine readmoondata ()
 Read ELP-82B periodic terms from moondata.dat.
 
subroutine readmoondata_la ()
 Read low-accuracy moon-position data from Meeus (moon_la.dat)
 
subroutine elp_mpp02_initialise_and_read_files (mode, ierr)
 Initialise ELP-MPP02 data and read the data files.
 
subroutine elp_mpp02_initialise (mode)
 Initialization of the constants and parameters used for the evaluation of the ELP/MPP02 series.
 
subroutine elp_mpp02_read_files (ierr)
 Read the six data files containing the ELP/MPP02 series.
 
real(double) function elp_dms2rad (deg, min, sec)
 Function for the conversion: sexagesimal degrees -> radians.
 
subroutine readasteroidelements ()
 Read orbital-element data for the asteroids.
 
subroutine readcometelements ()
 Read orbital-element data for the comets.
 
subroutine read_bsc
 Read the Bright Star Catalogue.
 

Detailed Description

Procedures to set constants and read data files.

Function/Subroutine Documentation

◆ elp_dms2rad()

real(double) function thesky_data::elp_dms2rad ( integer, intent(in) deg,
integer, intent(in) min,
real(double), intent(in) sec )

Function for the conversion: sexagesimal degrees -> radians.

Parameters
degDegrees
minMinutes or arc
secSeconds of arc
Return values
elp_dms2radThe angle in radians

Definition at line 1129 of file data.f90.

References elp_dms2rad().

Referenced by elp_dms2rad(), and elp_mpp02_initialise().

Here is the call graph for this function:

◆ elp_mpp02_initialise()

subroutine thesky_data::elp_mpp02_initialise ( integer, intent(in) mode)

Initialization of the constants and parameters used for the evaluation of the ELP/MPP02 series.

Parameters
modeIndex of the corrections to the constants: 0: LLR observations for 1970-2000, 1: DE405 ephemeris for 1950-2060
Note
  • Returns: Set of the constants of ELPMPP02 solution in module TheSky_elp_mpp02_constants.
  • Remarks: The nominal values of some constants have to be corrected. There are two sets of corrections, one of which can be chosen using the parameter 'mode' (used in elp_mpp02_initialise()):
    • mode=0, the constants are fitted to LLR observations provided from 1970 to 2001; it is the default value;
    • mode=1, the constants are fitted to DE405 ephemeris over one century (1950-2060); the lunar angles W1, W2, W3 receive also additive corrections to the secular coefficients.
  • Moon constants: nu : mean motion of the Moon (W1(1,1)) (Nu) g : half coefficient of sin(F) in latitude (Gamma) e : half coefficient of sin(l) in longitude (E) np : mean motion of EMB (eart(1)) (n') ep : eccentricity of EMB (e')

    p is the precession rate and t is the time

See also
  • ELPdoc: Lunar solution ELP, version ELP/MPP02, Jean Chapront and Gerard Francou, October 2002

Definition at line 786 of file data.f90.

References elp_dms2rad().

Referenced by elp_mpp02_initialise_and_read_files().

Here is the call graph for this function:

◆ elp_mpp02_initialise_and_read_files()

subroutine thesky_data::elp_mpp02_initialise_and_read_files ( integer, intent(in) mode,
integer, intent(out) ierr )

Initialise ELP-MPP02 data and read the data files.

Parameters
modeIndex of the corrections to the constants: 0: LLR observations for 1970-2000, 1: DE405 ephemeris for 1950-2060 (input)
ierrFile error index: ierr=0: no error, ierr=1: file error (output)

Definition at line 735 of file data.f90.

References elp_mpp02_initialise(), and elp_mpp02_read_files().

Referenced by thesky_moon::elp_mpp02_xyz().

Here is the call graph for this function:

◆ elp_mpp02_read_files()

subroutine thesky_data::elp_mpp02_read_files ( integer, intent(out) ierr)

Read the six data files containing the ELP/MPP02 series.

Parameters
ierrFile error index: ierr=0: no error, ierr=1: file error (output)
Note
  • module elp_mpp02_constants: Set of the constants of ELP/MPP02 solution (input)
  • module elp_mpp02_series: Series of the ELP/MPP02 solution (output)
See also

Definition at line 999 of file data.f90.

References thesky_constants::theskydatadir.

Referenced by elp_mpp02_initialise_and_read_files().

◆ read_bsc()

◆ read_deltat()

◆ readasteroidelements()

subroutine thesky_data::readasteroidelements

Read orbital-element data for the asteroids.

Note
  • data are passed via the module planetdata, in asterElems(*,1:9):
  • Epoch (JD), a, e, i, omega, Omega, M, H, G, for J2000.0
See also

Definition at line 1155 of file data.f90.

References thesky_planetdata::asterelems, thesky_planetdata::asternames, thesky_planetdata::nasteroids, and thesky_constants::theskydatadir.

Referenced by thesky_readdata().

◆ readcometelements()

subroutine thesky_data::readcometelements

Read orbital-element data for the comets.

Note
  • data are passed via the module comet_data, in cometElems(*,1:9)
  • colums: 1: Epoch (JD), 2: q, 3: e, 4: i, 5: omega, 6: Omega, 7: Tp, for J2000.0, 8: H, 9: G
See also

Definition at line 1210 of file data.f90.

References thesky_cometdata::cometdatfile, thesky_cometdata::cometdiedatp, thesky_cometdata::cometelems, thesky_cometdata::cometnames, thesky_cometdata::ncomets, thesky_cometdata::ncometsmax, and thesky_constants::theskydatadir.

Referenced by thesky_readdata().

◆ readconstellations()

◆ readmoondata()

◆ readmoondata_la()

subroutine thesky_data::readmoondata_la

Read low-accuracy moon-position data from Meeus (moon_la.dat)

Definition at line 693 of file data.f90.

References thesky_planetdata::moonla_arg, thesky_planetdata::moonla_lrb, and thesky_constants::theskydatadir.

Referenced by thesky_readdata().

◆ readnutation()

subroutine thesky_data::readnutation

Read nutation input files.

Definition at line 242 of file data.f90.

References thesky_constants::nutationdat, and thesky_constants::theskydatadir.

Referenced by thesky_readdata().

◆ readplanetdata()

subroutine thesky_data::readplanetdata

Reads VSOP planet data from planets.dat.

Definition at line 276 of file data.f90.

References thesky_constants::theskydatadir, thesky_planetdata::vsopdat, thesky_planetdata::vsopnblk, thesky_planetdata::vsopnls, and thesky_planetdata::vsoptruncs.

Referenced by thesky_readdata().

◆ readplanetelements()

subroutine thesky_data::readplanetelements

Read the data needed to compute the orbital elements of the planets.

Note
  • use planetelements() to compute the orbital elements
  • L, a, e, i, Omega, pi for Mer-Nep, mean equinox of date and J2000.0 (=2x6x8)
  • Terms in one row are a_0, a_1, a_2, a_3 and should be used as: Sum(i=0,3) a_i t^i, with t the time in centuries since 2000.0
  • Angles are still expressed in degrees

Definition at line 366 of file data.f90.

References thesky_planetdata::plelemdata, and thesky_constants::theskydatadir.

Referenced by thesky_readdata().

◆ readpluto()

subroutine thesky_data::readpluto

Read periodic terms for the position of Pluto.

Definition at line 330 of file data.f90.

References thesky_planetdata::plub, thesky_planetdata::pluc, thesky_planetdata::plul, thesky_planetdata::plur, and thesky_constants::theskydatadir.

Referenced by thesky_readdata().

◆ set_thesky_constants()

subroutine thesky_data::set_thesky_constants

Set the initial values of the variables and constants used in this package.

Definition at line 34 of file data.f90.

References thesky_constants::deltat_forced, thesky_constants::jd1820, thesky_constants::library_name, thesky_constants::thesky_verbosity, and thesky_constants::theskydatadir.

◆ thesky_readdata()

subroutine thesky_data::thesky_readdata

Read input data files.

Definition at line 98 of file data.f90.

References read_deltat(), readasteroidelements(), readcometelements(), readconstellations(), readmoondata_la(), readnutation(), readplanetdata(), readplanetelements(), and readpluto().

Here is the call graph for this function: