debian-skyfield/skyfield/documentation/elements.rst

107 lines
4.4 KiB
ReStructuredText
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

=============================
Osculating Orbital Elements
=============================
.. currentmodule:: skyfield.api
Skyfield is able to calculate osculating orbital elements for any
Geometric, Barycentric, or Geocentric position with respect to either
the ecliptic or equatorial plane. The data produced by Skyfield matches
the data produced by JPLs HORIZONS system.
Generating Elements
===================
Call :func:`~skyfield.elementslib.osculating_elements_of()` to generate
an :class:`~skyfield.elementslib.OsculatingElements` object. For
example, here is how to find the osculating elements of the moon
orbiting earth:
.. testcode::
from skyfield.api import load
from skyfield.elementslib import osculating_elements_of
ts = load.timescale(builtin=True)
t = ts.utc(2018, 4, 22, range(0, 25))
planets = load('de421.bsp')
earth = planets['earth']
moon = planets['moon']
position = (moon - earth).at(t)
elements = osculating_elements_of(position)
The elements are then attributes of the Elements object:
.. testcode::
i = elements.inclination.degrees
e = elements.eccentricity
a = elements.semi_major_axis.km
Attributes of OsculatingElements objects
========================================
Here is a list of the attributes of the Elements object and their types:
.. parsed-literal::
**OsculatingElements object**
**Element describing the shape of the orbit:**
├── eccentricity → `numpy.ndarray <https://docs.scipy.org/doc/numpy/reference/generated/numpy.ndarray.html>`_
**Element describing the tilt of the orbital plane:**
├── inclination → `Angle object <api-units.html>`_
**Element describing the direction in which the orbital plane is tilted:**
├── longitude_of_ascending node → `Angle object <api-units.html>`_
**Elements describing direction of periapsis:**
├── argument_of_periapsis → `Angle object <api-units.html>`_
├── longitude_of_periapsis → `Angle object <api-units.html>`_
├── periapsis_time → `Time object <api.html#time-objects>`_
**Elements describing the size of the orbit:**
├── apoapsis_distance → `Distance object <api-units.html>`_
├── mean_motion_per_day → `Angle object <api-units.html>`_
├── periapsis_distance → `Distance object <api-units.html>`_
├── period_in_days → `numpy.ndarray <https://docs.scipy.org/doc/numpy/reference/generated/numpy.ndarray.html>`_
├── semi_latus_rectum → `Distance object <api-units.html>`_
├── semi_major_axis → `Distance object <api-units.html>`_
├── semi_minor_axis → `Distance object <api-units.html>`_
**Elements describing the secondary's position in the orbit:**
├── argument_of_latitude → `Angle object <api-units.html>`_
├── eccentric_anomaly → `Angle object <api-units.html>`_
├── mean_anomaly → `Angle object <api-units.html>`_
├── mean_longitude → `Angle object <api-units.html>`_
├── true_anomaly → `Angle object <api-units.html>`_
├── true_longitude → `Angle object <api-units.html>`_
├── (the secondary's position can be implicit in periapsis_time
│ because at periapsis all anomalies are 0)
**Other attributes:**
└── time → `Time object <api.html#time-objects>`_
To fully define an object's location and orbit, one element is required from each of the above categories.
Reference Planes
================
By default the ``elements()`` method produces elements using the *xy*
plane of the ICRF as the reference plane. This is equivalent to the
J2000.0 equatorial plane within the tolerance of J2000.0. If you
instead want elements using the J2000.0 ecliptic as the reference plane,
pass it as the second argument:
.. testcode::
from skyfield.data.spice import inertial_frames
ecliptic = inertial_frames['ECLIPJ2000']
t = ts.utc(2018, 4, 22, range(0,25))
position = (moon - earth).at(t)
elements = osculating_elements_of(position, ecliptic)