interpolate.h#
Header file for integrator interpolation functions.
- 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
-
static inline void comp_sum(real num, real *sum, real *compCoeff)#
Compute the sum of two real numbers with a compensated summation.
- Parameters:
num – [in] Number to add to the sum.
sum – [inout] Sum of the numbers.
compCoeff – [inout] Compensation coefficient.
-
void approx_xInteg_math(const std::vector<real> &xInteg0, const std::vector<real> &accInteg0, const real &dt, const real &h, const std::vector<real> &b, const size_t &dim, const size_t starti, const size_t startb, const size_t &iterStep, std::vector<real> &xIntegNext, std::vector<real> &xIntegCompCoeffs)#
Evaluate the Gauss-Radau polynomial.
- Parameters:
xInteg0 – [in] Initial state vector.
accInteg0 – [in] Initial acceleration vector.
dt – [in] Integration time step.
h – [in] Fraction of the time step to use for the approximation.
b – [in] Interpolation coefficients for the Gauss-Radau polynomial.
dim – [in] Dimension of the system (number of 2nd derivatives).
starti – [in] Starting index of the state vector to approximate.
startb – [in] Starting index of the interpolation coefficients.
iterStep – [in] Number of derivatives to evaluate.
xIntegNext – [out] Approximated state vector.
xIntegCompCoeffs – [out] Compensation coefficients.
-
void approx_xInteg(const std::vector<real> &xInteg0, const std::vector<real> &accInteg0, const real &dt, const real &h, const std::vector<real> &b, const size_t &dim, const std::vector<IntegBody> &integBodies, std::vector<real> &xIntegNext, std::vector<real> &xIntegCompCoeffs)#
Use the Gauss-Radau polynomial to approximate the integral of the acceleration.
- Parameters:
xInteg0 – [in] Initial state vector.
accInteg0 – [in] Initial acceleration vector.
dt – [in] Integration time step.
h – [in] Fraction of the time step to use for the approximation.
b – [in] Interpolation coefficients for the Gauss-Radau polynomial.
dim – [in] Dimension of the system (number of 2nd derivatives).
integBodies – [in] List of integrated bodies in the PropSimulation.
xIntegNext – [out] Approximated state vector.
xIntegCompCoeffs – [out] Compensation coefficients.
-
void interpolate_on_the_fly(PropSimulation *propSim, const real &t, const real &dt)#
Interpolate the integrator state for the time step that was just completed.
- Parameters:
propSim – [in] PropSimulation object for the integration.
t – [in] Time at the beginning of the time step.
dt – [in] Completed time step size.
-
void get_interpIdxInWindow(const PropSimulation *propSim, const real &tWindowStart, const real &tNext, const bool &forwardProp, const bool &backwardProp, bool &interpIdxInWindow)#
Determine whether the next interpolation index is within the window of the time step that was just completed.
- Parameters:
propSim – [in] PropSimulation object for the integration.
tWindowStart – [in] Start time of the interpolation window.
tNext – [in] Time of the next interpolation.
forwardProp – [in] Flag to indicate forward integration.
backwardProp – [in] Flag to indicate backward integration.
interpIdxInWindow – [out] Flag to indicate whether the next interpolation index is within the window.
-
void get_lightTime_and_xRelative(PropSimulation *propSim, const size_t interpIdx, const real tInterpGeom, const std::vector<real> &xInterpGeom, std::vector<real> &lightTime, std::vector<real> &xInterpApparent)#
Compute the light time and apparent position of the target body.
- Parameters:
propSim – [in] PropSimulation object for the integration.
interpIdx – [in] Index of the next interpolation time.
tInterpGeom – [in] Time to interpolate to.
xInterpGeom – [in] Geometric state vector of the target body.
lightTime – [out] Light time to the target body.
xInterpApparent – [out] Apparent state vector of the target body.
-
void get_lightTimeOneBody(PropSimulation *propSim, const size_t &i, const real tInterpGeom, std::vector<real> xInterpGeom, std::vector<real> xObserver, const bool bouncePointAtCenterOfMass, real &lightTimeOneBody)#
Compute the light time to the target body.
- Parameters:
propSim – [in] PropSimulation object for the integration.
i – [in] Index of the target body.
tInterpGeom – [in] Time to interpolate to.
xInterpGeom – [in] Geometric state vector of the target body.
xObserver – [in] State vector of the observer.
bouncePointAtCenterOfMass – [in] Flag to indicate whether the bounce point is at the center of mass (as opposed to leading edge).
lightTimeOneBody – [out] Light time to the target body.