Fundamental Arguments
Delaunay's Arguments
IERSConventions.DelaunayArgs
— TypeDelaunayArgs
Container holding the Delaunay arguments of the Nutation Theory.
Fields
M
– Mean anomaly of the Moon, in radians.S
– Mean anomaly of the Sun, in radians.F
– Mean longitude of the Moon minus mean longitude of the ascending node, in radians.D
– Mean elongation of the Moon from the Sun, in radians.Ω
– Mean longitude of the Moon's ascending node, in radians.
IERSConventions.delaunay_anomaly_moon
— Functiondelaunay_anomaly_moon(m::IERSModel, tdb_c::Number)
Compute the mean anomaly of the Moon, in radians, given time tdb_c
expressed in TDB Julian centuries since J2000.
IERSConventions.delaunay_anomaly_sun
— Functiondelaunay_anomaly_sun(m::IERSModel, tdb_c::Number)
Compute the mean anomaly of the Sun, in radians, given time tdb_c
expressed in TDB Julian centuries since J2000.
IERSConventions.delaunay_longitude_diff
— Functiondelaunay_longitude_diff(m::IERSModel, tdb_c::Number)
Compute the difference between the longitude of the Moon and the longitude of the Moon's node, in radians, given time tdb_c
expressed in TDB Julian centuries since J2000.
IERSConventions.delaunay_elongation_moon
— Functiondelaunay_elongation_moon(m::IERSModel, tdb_c::Number)
Compute the mean elongation of the Moon from the Sun, in radians, given time tdb_c
expressed in TDB Julian centuries since J2000.
IERSConventions.delaunay_longitude_node
— Functiondelaunay_longitude_node(m::IERSModel, tdb_c::Number)
Compute the longitude of the mean ascending node of the lunar orbit on th ecliptic, measured from the mean equinox of date, in radians, given time tdb_c
expressed in TDB Julian centuries since J2000.
Planetary Arguments
IERSConventions.PlanetaryArgs
— TypePlanetaryArgs
Container holding the planetary arguments of the Nutation Theory.
Fields
λ_Me
– Mercury's mean heliocentric longitude, in radians.λ_Ve
– Venus's mean heliocentric longitude, in radians.λ_Ea
– Earth's mean heliocentric longitude, in radians.λ_Ma
– Mars's mean heliocentric longitude, in radians.λ_Ju
– Jupiter's mean heliocentric longitude, in radians.λ_Sa
– Saturn's mean heliocentric longitude, in radians.λ_Ur
– Uranus's mean heliocentric longitude, in radians.λ_Ne
– Neptune's mean heliocentric longitude, in radians.pₐ
– General precession in longitude, in radians.
IERSConventions.pa_mercury
— Functionpa_mercury(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Mercury in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
This function has not been implemented for the IERS 1996 conventions.
References
IERSConventions.pa_venus
— Functionpa_venus(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Venus in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
References
IERSConventions.pa_earth
— Functionpa_earth(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Earth in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
References
IERSConventions.pa_mars
— Functionpa_mars(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Mars in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
References
IERSConventions.pa_jupiter
— Functionpa_jupiter(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Jupiter in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
References
IERSConventions.pa_saturn
— Functionpa_saturn(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Saturn in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
References
IERSConventions.pa_uranus
— Functionpa_uranus(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Uranus in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
This function has not been implemented for the IERS 1996 conventions.
References
IERSConventions.pa_neptune
— Functionpa_neptune(m::IERSModel, tdb_c::Number)
Return the mean heliocentric longitude of Neptune in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
This function has not been implemented for the IERS 1996 conventions.
References
IERSConventions.pa_precession
— Functionpaprecession(m::IERSModel, tdbc::Number)
Return the general accumulated precession in longitude pₐ
in radians, at time tdb_c
expressed in TDB
Julian centuries since J2000
.
References
Fukushima-Williams
IERSConventions.fw2xy
— Functionfw2xy(ϵ::Number, ψ::Number, γ::Number, φ::Number)
Compute the CIP X and Y coordinates from Fukushima-Williams bias-precession-nutation angles, in radians.
References
- Wallace P. T. and Capitaine N. (2006), Precession-nutation procedures consistent with IAU 2006 resolutions, DOI: 10.1051/0004-6361:20065897
IERSConventions.fw_angles
— Functionfw_angles(m::IERS2010, tt_c::Number)
Compute the precession angles, γ, ϕ, ψ, ϵ in radians, according to the IAU 2006 Fukushima-Williams 4-angle formulation at time tt_c
expressed in TT
Julian centuries since J2000
.
References
- Luzum, B. and Petit G. (2012), The IERS Conventions (2010), IERS Technical Note No. 36
- Wallace P. T. and Capitaine N. (2006), Precession-nutation procedures consistent with IAU 2006 resolutions, DOI: 10.1051/0004-6361:20065897
- ERFA library
IERSConventions.fw_matrix
— Functionfw_matrix(γ, ϕ, ψ, ε)
Form a rotation matrix given the Fukushima-Williams angles, expressed in radians.
The present function can construct three different matrices depending on which angles are supplied as arguments:
NPB: To obtain the Nutation-Precession-Bias (NPB) matrix, generate the four standard FW precession angles (̄γ, ̄ϕ, ̄ψ, ϵₐ) then generate the nutation components Δψ and Δϵ and add them to ̄ψ, ϵₐ. Finally, call the present functions using those four angles as arguments.
PB: To obtain the Precession-Bias matrix, generate the four standard FW precession angles and call the present function.
B: To obtain the frame bias matrix, generate the four standard FW precession angles at date J2000.0 and call this function.
The remaining nutation-only and precession only matrices can be obtained by combining these three appropriately.
References
- Wallace P. T. and Capitaine N. (2006), Precession-nutation procedures consistent with IAU 2006 resolutions, DOI: 10.1051/0004-6361:20065897
- ERFA library
Earth Orientation Parameters
Constants
IERSConventions.NutationCorrections
— TypeNutationCorrections
Container to hold the nutation corrections and celestial pole offsets associated to a given IERS model (e.g., 2000A)
Fields
δX, δY
: Celestial pole offsets referred to the model IAU2000A (rad).δΔψ, δΔϵ
: Nutation corrections in longitude and obliquity (rad)
See also
See also EOPData
.
IERSConventions.NutCorrectionsInterpolator
— TypeNutCorrectionsInterpolator
Container to store the interpolators for the nutation corrections and celestial pole offsets associated to a given IERS model.
See also
See also EOPInterpolator
IERSConventions.EOPData
— TypeEOPData{T}
EOP Data container. Data is parameterised by time expressed in Terrestrial Time (TT) days.
Fields
filename
: File where the EOP data are stored.days_UTC
: UTC Julian days since J2000.cent_TT
: TT Julian centuries since J2000.UT1_TT
: UT1 minus TT offset, in seconds.LOD
: Length of day offset (s).xp, yp
: Polar motion with respect to the crust (rad).nut1996, nut2003, nut2006
: nutation and CIP corrections.
IERSConventions.EOPInterpolator
— TypeEOPInterpolator
Container to store the interpolators for the loaded EOP data.
IERSConventions.IERS_EOP
— ConstantIERS_EOP
Earth Orientation Parameters (EOP) interpolators.
See also
See also eop_load_data!
and EOPInterpolator
.
IERSConventions.IERS_EOP_DATA
— ConstantLoading
IERSConventions.eop_read_data
— Functioneop_read_data(filename)
Read Earth Orientation Parameters (EOP) from a dedicated JSMD .eop.dat
file.
JSMD's .eop.dat
EOP files are meant to have a fixed structure to ease the retrieval of the relevant EOP data.
IERSConventions.eop_set_data!
— Functioneop_set_data!(m::IERSModel, filename)
Set Earth Orientation Parameters (EOP) to be used for frames transformations from a JSMD .eop.dat
file, given a reference model m
.
Parsing
IERSConventions.eop_write_data
— Functioneop_write_data(data, output_filename)
Write the EOP data stored in the matrix data
to a dedicated JSMD .eop-dat
file.
The output_filename
should not include the file extension, which is automatically added by this function.
See also
See also eop_generate_from_csv
and eop_generate_from_txt
.
IERSConventions.δnut_to_δcip
— Functionδnut_to_δcip(m::IERSModel, t::Number, δΔψ::Number, δΔϵ::Number)
Convert nutation corrections in longitude δΔψ
and obliquity δΔϵ
to CIP corrections δX
, δY
at time t
expressed in TT Julian centuries since J2000 for model m
. All input and output EOP are given in radians.
References
- IERS Technical Note No. 36
- Paris IERS observatory FTP server (UAI2000 package).
See also
See also δcip_to_δnut
.
IERSConventions.δcip_to_δnut
— Functionδcip_to_δnut(m::IERSModel, t::Number, δX::Number, δY::Number)
Convert CIP corrections δX
, δY
to nutation corrections in longitude δΔψ
and obliquity δΔϵ
to at time t
expressed in TT Julian centuries since J2000 for model m
. All input and output EOP are given in radians.
References
- IERS Technical Note No. 36
- Paris IERS observatory FTP server (UAI2000 package).
See also
See also δnut_to_δcip
.
Interpolation Functions
IERSConventions.eop_δΔψ
— Functioneop_δΔψ(m::IERSModel, tt_c::Number)
Interpolate and retrieve the EOP nutation correction in longitude δΔψ
, in radians, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
See also
IERSConventions.eop_δΔϵ
— Functioneop_δΔϵ(m::IERSModel, tt_c::Number)
Interpolate and retrieve the EOP nutation correction in obliquity δΔϵ
, in radians, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
See also
IERSConventions.eop_δX
— Functioneop_δX(m::IERSModel, tt_c::Number)
Interpolate and retrieve the CIP δX
correction, in radians, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
See also
IERSConventions.eop_δY
— Functioneop_δY(m::IERSModel, tt_c::Number)
Interpolate and retrieve the CIP δY
correction, in radians, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
See also
IERSConventions.eop_xp
— Functioneop_xp(m::IERSModel, tt_c::Number)
Interpolate and retrieve the pole xₚ
coordinate, in radians, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
See also
See also eop_yp
.
IERSConventions.eop_yp
— Functioneop_yp(m::IERSModel, tt_c::Number)
Interpolate and retrieve the pole yₚ
coordinate, in radians, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
See also
See also eop_xp
.
IERSConventions.eop_lod
— Functioneop_lod(m::IERSModel, tt_c::Number)
Interpolate and retrieve the length of day LOD
offset, in seconds, at time tt_c
expressed in TT
Julian centuries since J2000 for the IERS convention m
.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
IERSConventions.offset_tt2ut1
— Functionoffset_tt2ut1(tt_s::Number)
Return the TT-to-UT1 offset, in seconds, at tt_s
expressed in TT seconds since J2000.
If time is outside the boundaries for which there is available EOP data, a zero value is returned.
Poisson Series
IERSConventions.PoissonSeries
— TypePoissonSeries
This container stores the non-polynomial part of a Poisson series, i.e., the sine and cosine coefficients and the Delaunay's and Planetary arguments of the nutation theory multipliers.
IERSConventions.NutationDataParser
— TypeNutationDataParser <: PoissonDataParser
Parser for nutation-like data, in which the orders of the different coefficients are stored on separate columns, e.g., in and out of phase.
Fields
- ncols: number of columns
- c_dargs: first column of the Delaunay's arguments
- c_pargs: first column of the planetary arguments
- c_sin: column with the sine terms
- c_cos: column with the cosine terms
- linePattern: regex expression to parse the relevant data lines
IERSConventions.CIODataParser
— TypeCIODataParser <: PoissonDataParser
Parser for CIO-like data, in which the orders of the different coefficients are separated by a specific line header in the form of " j = 0 Nb of terms = 1306".
Fields
- ncols: number of columns
- c_dargs: first column of the Delaunay's arguments
- c_pargs: first column of the planetary arguments
- c_sin: column with the sine terms
- c_cos: column with the cosine terms
- linePattern: regex expression to parse the relevant data lines
IERSConventions.parse_iers_constants
— Functionparse_iers_constants(filename::String, parser::PoissonDataParser)
Retrieve the Poisson series within filename
with the configuration of parser
.
IERSConventions.generate_iers_file
— Functiongenerate_iers_file(filename::String, constant_name::Symbol, constant_data)
Generate or append the data in constant_data
to filename
as a variable named constant_name
.
Miscellaneous
IERSConventions.cio_locator
— Functioncio_locator(m::IERSModel, tt_c::Number, x::Number, y::Number)
Compute the CIO locator s
, in radians, following the IERS Conventions m
at time tt_c
, expressed in TT
Julian centuries since J2000, given the CIP coordinates x
and y
.
References
- Capitaine N. and Wallace P. T. (2008), Concise CIO based precession-nutation formulations
- IERS Technical Note No. 21
- IERS Technical Note No. 32
- IERS Technical Note No. 36
See also
See also iers_cip_motion
, cip_xy
and cip_xys
.
IERSConventions.equation_equinoxes
— Functionequation_equinoxes(m::IERSModel, tt_c::Number, δΔψ::Number = 0)
Compute the Equation of the Equinoxes, in radians, according to the IERS Conventions m
, at time tt_c
expressed as TT
Julian centuries since J2000. An optional EOP correction for the nutation in longitude can be passed via δΔψ
.
In this framework, the equation of the equinoxes is always defined according to the following equation: GAST = GMST + equation of the equinoxes
References
See also
See also iers_obliquity
, iers_nutation_comp
and eeq_complementary
.
IERSConventions.eeq_complementary
— Functioneeq_complementary(m::IERSModel, tt_c::Number)
Compute the complementary terms of the equation of the equinoxes, in radians, associated to the IERS Conventions m
, at time tt_c
expressed in TT
Julian centuries since J2000.
For the IERS 1996 Conventions, starting from 1997-02-27T00:00:00 UTC, two additional terms are included to account for the Moon effect (see IAU 1997 C7 resolution). The complementary terms of earlier dates are always null.
References
IERSConventions.npb2xy
— Functionnpb2xy(A::AbstractMatrix)
Retrieve the CIP X and Y coordinates from the nutation-precession-bias matrix, in radians.
References
- Wallace P. T. and Capitaine N. (2006), Precession-nutation procedures consistent with IAU 2006 resolutions, DOI: 10.1051/0004-6361:20065897
IERSConventions.precession_angles_rot3
— Functionprecession_angles_rot3(m::IERSModel, tt_c::Number)
Return the equatorial precession angles zₐ, θₐ, ζₐ, in radians, at time tt_c
expressed in TT
Julian centuries since J2000
for the 3-rotations precession series initially used by Newcomb and Lieske.
The expressions for these angles compatible with the IAU 2000A precession and nutation have been developed in order to match the 4-rotation series to sub-microarcsecond accuracy over 4 centuries.
TT
is used as time argument instead of TDB. The largest term in the TDB-TT difference causes a periodic error which is significantly under the microarcsecond accuracy.
References
- Lieske J. H. et al, (1977), Expression for the Precession Quantities Based upon the IAU (1976) System of Astronomical Constants.
- Capitained N. 2003b et al., Expressions for IAU 2000 precession quantities.
- Hilton J. L. et al., (2006), Report of the International Astronomical Union Division I Working
Group on Precession and the Ecliptic.
See also
See also iers_precession
and precession_angles_rot4
IERSConventions.precession_angles_rot4
— Functionprecession_angles_rot4(m::IERSModel, tt_c::Number)
Return the precession angles ϵ₀, ψₐ, ωₐ, χₐ, in radians, at time tt_c
expressed in TT
Julian centuries since J2000
required for the canonical 4-rotations precession series.
TT
is used as time argument instead of TDB. The largest term in the TDB-TT difference causes a periodic error which is significantly under the microarcsecond accuracy.
References
See also
See also iers_precession
and precession_angles_rot4
IERSConventions.tio_locator
— Functiontio_locator(m::IERSModel, tt_c::Number)
Compute the TIO locator s'
at date, positioning the Terrestrial Intermediate Origin on the equator of the Celestial Intermediate Pole (CIP) at time tt_c
expressed as TT
Julian centuries since J2000.
This function approximates the unpredictable motion of the TIO locator s' with its secular drift of ~0.47 μas/century.
References
- IERS Technical Note No. 36
- Lambert, S. and Bizouard C. (2002), Positioning the Terrestrial Ephemeris Origin in the Terrestrial Reference Frame, DOI: 10.1051/0004-6361:20021139
IERSConventions.xys2m
— Functionxys2m(x::Number, y::Number, s::Number)
Compute the GCRF-to-CIRF matrix given the CIP x
, y' coordinates and the CIO locator
s`, all in radians.
References
- Wallace P. T. and Capitaine N. (2006), Precession-nutation procedures consistent with IAU 2006 resolutions, DOI: 10.1051/0004-6361:20065897
- ERFA library