elements.h

Contents

elements.h#

Header file for the orbital elements.

Author

Rahil Makadia makadia2@illinois.edu

LICENSE#

Copyright (C) 2022-2025 Rahil Makadia

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program; if not, see https://www.gnu.org/licenses.

Functions

void kepler_solve_elliptic(const real &M, const real &e, real &E, const real &tol, const int &max_iter)#

Solve the Kepler equation for elliptic orbits.

Parameters:
  • M[in] Mean anomaly.

  • e[in] Eccentricity.

  • E[out] Eccentric anomaly.

  • tol[in] Tolerance.

  • max_iter[in] Maximum number of iterations.

void kepler_solve_hyperbolic(const real &M, const real &e, real &EHyp, const real &tol, const int &max_iter)#

Solve the Kepler equation for hyperbolic orbits.

Parameters:
  • M[in] Mean anomaly.

  • e[in] Eccentricity.

  • EHyp[out] Hyperbolic anomaly.

  • tol[in] Tolerance.

  • max_iter[in] Maximum number of iterations.

void kepler_solve(const real &epochMjD, const std::vector<real> &cometaryState, const real &GM, real &M, real &E, real &nu, const real &tol = 1.0e-12L, const int &max_iter = 100)#

Solve the Kepler equation.

Parameters:
  • epochMjD[in] Epoch in TDB Modified Julian Date.

  • cometaryState[in] Cometary elements.

  • GM[in] Gravitational parameter.

  • M[out] Mean anomaly.

  • E[out] Eccentric anomaly (elliptic orbits) or hyperbolic anomaly (hyperbolic orbits)

  • nu[out] True anomaly.

  • tol[in] Tolerance.

  • max_iter[in] Maximum number of iterations.

void cometary_to_keplerian(const real &epochMjd, const std::vector<real> &cometaryState, std::vector<real> &keplerianState, const real GM = 2.959122082855911e-4L)#

Convert Cometary elements to Keplerian elements.

Parameters:
  • epochMjd[in] Epoch in TDB Modified Julian Date.

  • cometaryState[in] Cometary elements.

  • keplerianState[out] Keplerian elements.

  • GM[in] Gravitational parameter (default Sun).

void keplerian_to_cometary(const real &epochMjd, const std::vector<real> &keplerianState, std::vector<real> &cometaryState, const real GM = 2.959122082855911e-4L)#

Convert Keplerian elements to Cometary elements.

Parameters:
  • epochMjd[in] Epoch in TDB Modified Julian Date.

  • keplerianState[in] Keplerian elements.

  • cometaryState[out] Cometary elements.

  • GM[in] Gravitational parameter (default Sun).

void keplerian_to_cartesian(const std::vector<real> &keplerianState, std::vector<real> &cartesianState, const real GM = 2.959122082855911e-4L)#

Convert Keplerian elements to Cartesian state.

Parameters:
  • keplerianState[in] Keplerian elements.

  • cartesianState[out] Cartesian state.

  • GM[in] Gravitational parameter (default Sun).

void cartesian_to_keplerian(const std::vector<real> &cartesianState, std::vector<real> &keplerianState, const real GM = 2.959122082855911e-4L)#

Convert Cartesian state to Keplerian elements.

Parameters:
  • cartesianState[in] Cartesian state.

  • keplerianState[out] Keplerian elements.

  • GM[in] Gravitational parameter (default Sun).

void cometary_to_cartesian(const real &epochMjd, const std::vector<real> &cometaryState, std::vector<real> &cartesianState, const real GM = 2.959122082855911e-4L)#

Convert Cometary elements to Cartesian state.

Parameters:
  • epochMjd[in] Epoch in TDB Modified Julian Date.

  • cometaryState[in] Cometary elements.

  • cartesianState[out] Cartesian state.

  • GM[in] Gravitational parameter (default Sun).

void cartesian_to_cometary(const real &epochMjd, const std::vector<real> &cartesianState, std::vector<real> &cometaryState, const real GM = 2.959122082855911e-4L)#

Convert Cartesian state to Cometary elements.

Parameters:
  • epochMjd[in] Epoch in TDB Modified Julian Date.

  • cartesianState[in] Cartesian state.

  • cometaryState[out] Cometary elements.

  • GM[in] Gravitational parameter (default Sun).

void get_elements_partials(const real &epochMjd, const std::vector<real> &elems, const std::string conversion, std::vector<std::vector<real>> &partials, const real GM = 2.959122082855911e-4L)#

Get the partial derivatives of the Cometary/Keplerian elements with respect to the Cartesian state.

Parameters:
  • epochMjd[in] Epoch in TDB Modified Julian Date.

  • elems[in] Elements.

  • conversion[in] Conversion type.

  • partials[out] Partials of the elements w.r.t. the Cartesian state.

  • GM[in] Gravitational parameter (default Sun).

void get_cartesian_partials(const real &epochMjd, const std::vector<real> &state, const std::string &conversion, std::vector<std::vector<real>> &partials, const real GM = 2.959122082855911e-4L)#

Get the partial derivatives of the Cartesian state with respect to the Cometary/Keplerian elements.

Parameters:
  • epochMjd[in] Epoch in TDB Modified Julian Date.

  • elems[in] Elements.

  • conversion[in] Conversion type.

  • partials[out] Partials of the Cartesian state w.r.t. the elements.

  • GM[in] Gravitational parameter (default Sun).