Isis 3 Programmer Reference
|
Obtain SPICE position information for a body. More...
#include <SpicePosition.h>
Public Types | |
enum | Source { Spice , Memcache , HermiteCache , PolyFunction , PolyFunctionOverHermiteConstant } |
This enum indicates the status of the object. More... | |
enum | PartialType { WRT_X , WRT_Y , WRT_Z } |
enum | OverrideType { NoOverrides , ScaleOnly , BaseAndScale } |
Public Member Functions | |
SpicePosition (int targetCode, int observerCode) | |
Construct an empty SpicePosition class using valid body codes. | |
virtual | ~SpicePosition () |
Destructor. | |
void | SetTimeBias (double timeBias) |
Apply a time bias when invoking SetEphemerisTime method. | |
double | GetTimeBias () const |
Returns the value of the time bias added to ET. | |
virtual void | SetAberrationCorrection (const QString &correction) |
Set the aberration correction (light time) | |
virtual QString | GetAberrationCorrection () const |
Returns current state of stellar aberration correction. | |
double | GetLightTime () const |
Return the light time coorection value. | |
virtual const std::vector< double > & | SetEphemerisTime (double et) |
Return J2000 coordinate at given time. | |
virtual double | EphemerisTime () const |
Return the current ephemeris time. | |
double | scaledTime () const |
Return the scaled time. | |
const std::vector< double > & | GetCenterCoordinate () |
Compute and return the coordinate at the center time. | |
virtual const std::vector< double > & | Coordinate () |
Return the current J2000 position. | |
const std::vector< double > & | Velocity () |
Return the current J2000 velocity. | |
bool | HasVelocity () |
Return the flag indicating whether the velocity exists. | |
void | LoadCache (double startTime, double endTime, int size) |
Cache J2000 position over a time range. | |
void | LoadCache (double time) |
Cache J2000 position for a time. | |
void | LoadCache (Table &table) |
Cache J2000 positions using a table file. | |
void | LoadCache (nlohmann::json &isd) |
Load the cached data from an ALE ISD. | |
Table | LineCache (const QString &tableName) |
Return a table with J2000 to reference positions. | |
Table | LoadHermiteCache (const QString &tableName) |
Cache J2000 position over existing cached time range using polynomials stored as Hermite cubic spline knots. | |
void | ReloadCache () |
Cache J2000 positions over existing cached time range using polynomials. | |
void | ReloadCache (Table &table) |
Cache J2000 position over existing cached time range using table. | |
Table | Cache (const QString &tableName) |
Return a table with J2000 positions. | |
bool | IsCached () const |
Is this position cached. | |
int | cacheSize () const |
Get the size of the current cached positions. | |
void | SetPolynomial (const Source type=PolyFunction) |
Set the coefficients of a polynomial fit to each of the components (X, Y, Z) of the position vector for the time period covered by the cache, component = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_baseTime) / p_timeScale. | |
void | SetPolynomial (const std::vector< double > &XC, const std::vector< double > &YC, const std::vector< double > &ZC, const Source type=PolyFunction) |
Set the coefficients of a polynomial (parabola) fit to each of the three coordinates of the position vector for the time period covered by the cache, coord = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_baseTime) / p_timeScale. | |
void | GetPolynomial (std::vector< double > &XC, std::vector< double > &YC, std::vector< double > &ZC) |
Return the coefficients of a polynomial fit to each of the three coordinates of the position for the time period covered by the cache, angle = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_basetime) / p_timeScale. | |
void | SetPolynomialDegree (int degree) |
Set the polynomial degree. | |
Source | GetSource () |
Return the source of the position. | |
void | ComputeBaseTime () |
Compute the base time using cached times. | |
double | GetBaseTime () |
Return the base time for the position. | |
void | SetOverrideBaseTime (double baseTime, double timeScale) |
Set an override base time to be used with observations on scanners to allow all images in an observation to use the same base time and polynomials for the positions. | |
double | GetTimeScale () |
Return the time scale for the position. | |
double | DPolynomial (const int coeffIndex) |
Evaluate the derivative of the fit polynomial (parabola) defined by the given coefficients with respect to the coefficient at the given index, at the current time. | |
std::vector< double > | CoordinatePartial (SpicePosition::PartialType partialVar, int coeffIndex) |
Set the coefficients of a polynomial fit to each of the three coordinates of the position vector for the time period covered by the cache,. | |
std::vector< double > | VelocityPartial (SpicePosition::PartialType partialVar, int coeffIndex) |
Compute the derivative of the velocity with respect to the specified variable. | |
void | Memcache2HermiteCache (double tolerance) |
This method reduces the cache for position, time and velocity to the minimum number of values needed to interpolate the J2000 coordinates using a Hermite spline, given a tolerance of deviation from the NAIF values. | |
std::vector< double > | Extrapolate (double timeEt) |
Extrapolate position for a given time assuming a constant velocity. | |
std::vector< double > | HermiteCoordinate () |
This method returns the Hermite coordinate for the current time for PolyFunctionOverHermiteConstant functions. | |
Protected Member Functions | |
void | SetEphemerisTimeMemcache () |
This is a protected method that is called by SetEphemerisTime() when Source type is Memcache. | |
void | SetEphemerisTimeHermiteCache () |
This is a protected method that is called by SetEphemerisTime() when Source type is HermiteCache. | |
virtual void | SetEphemerisTimeSpice () |
This is a protected method that is called by SetEphemerisTime() when Source type is Spice. | |
void | SetEphemerisTimePolyFunction () |
This is a protected method that is called by SetEphemerisTime() when Source type is PolyFunction. | |
void | SetEphemerisTimePolyFunctionOverHermiteConstant () |
This is a protected method that is called by SetEphemerisTime() when Source type is PolyFunctionOverHermiteConstant. | |
SpicePosition (int targetCode, int observerCode, bool swapObserverTarget) | |
Constructor for swapping observer/target order. | |
int | getObserverCode () const |
Returns observer code. | |
int | getTargetCode () const |
Returns target code. | |
double | getAdjustedEphemerisTime () const |
Returns adjusted ephemeris time. | |
void | computeStateVector (double et, int target, int observer, const QString &refFrame, const QString &abcorr, double state[6], bool &hasVelocity, double &lightTime) const |
Computes the state vector of the target w.r.t observer. | |
void | setStateVector (const double state[6], const bool &hasVelocity) |
Sets the state of target relative to observer. | |
void | setLightTime (const double &lightTime) |
Inheritors can set the light time if indicated. | |
Private Member Functions | |
void | init (int targetCode, int observerCode, const bool &swapObserverTarget=false) |
Internal initialization of the object support observer/target swap. | |
void | ClearCache () |
Removes the entire cache from memory. | |
void | LoadTimeCache () |
Load the time cache. | |
void | CacheLabel (Table &table) |
Add labels to a SpicePosition table. | |
double | ComputeVelocityInTime (PartialType var) |
Compute the velocity with respect to time instead of scaled time. | |
Private Attributes | |
int | p_targetCode |
target body code | |
int | p_observerCode |
observer body code | |
double | p_timeBias |
iTime bias when reading kernels | |
QString | p_aberrationCorrection |
Light time correction to apply. | |
double | p_et |
Current ephemeris time. | |
std::vector< double > | p_coordinate |
J2000 position at time et. | |
std::vector< double > | p_velocity |
J2000 velocity at time et. | |
Source | p_source |
Enumerated value for the location of the SPK information used. | |
std::vector< double > | p_cacheTime |
iTime for corresponding position | |
std::vector< double > | p_coefficients [3] |
Coefficients of polynomials fit to 3 coordinates. | |
double | p_baseTime |
Base time used in fit equations. | |
double | p_timeScale |
Time scale used in fit equations. | |
bool | p_degreeApplied |
Flag indicating whether or not a polynomial. | |
int | p_degree |
Degree of polynomial function fit to the coordinates of the position. | |
double | p_fullCacheStartTime |
Original start time of the complete cache after spiceinit. | |
double | p_fullCacheEndTime |
Original end time of the complete cache after spiceinit. | |
double | p_fullCacheSize |
Orignial size of the complete cache after spiceinit. | |
bool | p_hasVelocity |
Flag to indicate velocity is available. | |
OverrideType | p_override |
Time base and scale override options;. | |
double | p_overrideBaseTime |
Value set by caller to override computed base time. | |
double | p_overrideTimeScale |
Value set by caller to override computed time scale. | |
bool | m_swapObserverTarget |
double | m_lt |
!< Swap traditional order | |
ale::States * | m_state |
!< Light time correction | |
Friends | |
class | ::IsisIlluminator_Velocity_Test |
Obtain SPICE position information for a body.
This class will obtain the J2000 body position between a target and observer body. For example, a spacecraft and Mars or the Sun and Mars. It is essentially a C++ wrapper to the NAIF spkez_c routine. Therefore, appropriate NAIF kernels are expected to be loaded prior to using this class. The position can be returned with or without one way light time corrections between the two bodies. See NAIF required reading for more information regarding this subject at ftp://naif.jpl.nasa.gov/pub/naif/toolkit_docs/C/ascii/individual_docs/spk.req
An important functionality of this class is the ability to cache the positions so they do not have to be constantly read from the NAIF kernels. Onced the data is cached the NAIF kernels can be unloaded too.
2003-12-01 Jeff Anderson Original Version derived from Spice class
2006-03-23 Jeff Anderson Added check to SetEphemeris to return if the time did not change. Should speed up line scan cameras
2007-07-10 Debbie A. Cook Added else to method SetAberrationCorrection to separate error section from the rest of the code
2007-08-24 Debbie A. Cook Added members p_coefficients, enums PartialType and Coefficient, and methods ReloadCache, SetPolynomial, GetPolynomial, ComputeBaseTime, DPolynomial, and CoordinatePartial to support solving for instrument position in BundleAdjust
2008-01-10 Debbie A. Cook The function was changed from Parabola to Poly1D. New methods GetBaseTime and SetOverrideBaseTime were added
2008-02-07 Jeannie Walldren Poly1D was changed to PolynomialUnivariate
2008-02-10 Debbie A. Cook Removed the (-1.) in case A of DPolynomial since it was not actually part of the position derivation but how it was being applied in BundleAdjust.
2008-06-18 Steven Lambright Fixed documentation
2008-06-25 Debbie A. Cook Added members p_velocity, p_cacheVelocity, and p_hasVelocity; also added methods Velocity() and HasVelocity() to support miniRF.
2008-06-26 Debbie A. Cook Replaced Naif error handling calls with Isis NaifStatus
2009-08-03 Jeannie Walldren - Added methods ReloadCache( table ), HermiteIndices(), Memcache2HermiteCache() to allow for downsized instrument position tables in labels of Isis cubes and added methods SetEphemerisTimeSpice(), SetEphemerisTimeHermiteCache(), and SetEphemerisTimeMemcache() to make software more readable.
2009-08-14 Debbie A. Cook - Corrected loop counter in HermiteIndices
2009-08-27 Jeannie Walldren - Added documentation.
2009-10-20 Debbie A. Cook - Corrected calculation of extremum in ReloadCache
2009-11-06 Debbie A. Cook - Added velocity partial derivative method
2009-12-15 Debbie A. Cook - Changed enumerated partial types and argument list for CoordinatePartial and VelocityPartial
2010-03-19 Debbie A. Cook - Added argument coeffIndex to method Velocity Partial
2010-12-07 Steven Lambright - Moved the cubic hermite splines to member scope for efficiency. It was a significant overhead to keep reconstructing these. Created ClearCache() to help increase code reusability.
2011-02-12 Debbie A. Cook - Added PolyFunction to source types and new method SetEphemerisTimePolyFunction to support the new type. Also added method SetPolynomialDegree to allow the degree of the polynomials fit to the position coordinates to be changed. The fit polynomial was changed from a fixed 2nd order polynomial to an nth degree polynomial with one independent variable. Added private class members p_fullCacheStartTime, p_fullCacheEndTime, and p_fullCacheSize. Added p_timeScale, GetBaseTime(), SetOverrideBaseTime, GetTimeScale(), Extrapolate(double timeEt), and ComputeVelocityInTime(PartialType var). The function was changed from a Parabola to Polynomial1Variable, now called PolynomialUnivariate.
2011-02-14 Debbie A. Cook - Corrected previous update for Hermite case. Created a special member, p_overrideScale, for Hermite case. Also removed obsolete enum Coefficient.
2011-02-17 Debbie A. Cook - Corrected missed problem with degree forced to be 2 and corrected calculation of velocity partial
2011-02-22 Debbie A. Cook - Corrected Extrapolation method
2011-02-28 Debbie A. Cook - Fixed typo in LoadCache and potential memory problem in SetPolynomial
2011-04-10 Debbie A. Cook - Added GetSource method to support spkwriter.
2011-05-27 Debbie A. Cook - Renamed old ReloadCache method for converting polynomial functions to Hermite cubic splines to LoadHermiteCache for use with spkwriter.
2012-03-31 Debbie A. Cook - Programmer notes: Added new interpolation algorithm, PolyFunctionOverHermiteConstant, and new supporting method, SetEphemerisTimePolyOverHermiteConstant. Also added argument to SetPolynomial methods for type. LineCache and ReloadCache were modified to allow other function types beyond the PolyFunction. Added new method to return Hermite coordinate.
2012-10-25 Jeannie Backer - Brought class closer to Isis3 standards: Ordered includes in cpp file, replaced quotation marks with angle braces in 3rd party includes, fixed history indentation. References #1181.
2012-10-31 Kris Becker - Added implementation for swapping of observer/target and light time correction to surface. Added a new, special protected constructor; virtualized the SetEphemerisTimeSpice method which allows for specialized determination of light time corrections; generalized the retrieval of body state vectors (computeStateVector); added many new, mostly protected, ssupport routines for this generalization. Fixes (mostly) #0909, #1136 and #1223.
2013-03-28 Debbie A. Cook - Fixed bug causing jigsaw to fail with a singular definite matrix on radar data. The bug was in the method VelocityPartial and occurred when the et = baseTime and the coeffIndex was 0. This caused the derivative equation to be 0 * 0 ** -1. This update fixes issue #1582.
2015-02-20 Jeannie Backer - Improved error messages.
2015-07-21 Kristin Berry - Added additional NaifStatus::CheckErrors() to see if any NAIF errors were signaled. References #2248.
2015-08-25 Kristin Berry - Moved check to make sure a polynomial exists to earlier in LoadHermiteCache. Was failing due to lack of a polynomial with a confusing error message before the check.
2017-08-18 Tyler Wilson, Summer Stapleton, Ian Humphrey - Added opening/closing brackets to SetEphemerisTimePolyFunction() so this class compiles without warnings under C++14. References #4809.
2018-06-22 Ken Edmundson - Added scaledTime() method to return current scaled time.
2020-07-01 Kristin Berry - Updated to use ale::States for internal state cache.
Definition at line 176 of file SpicePosition.h.
enum Isis::SpicePosition::OverrideType |
Definition at line 292 of file SpicePosition.h.
enum Isis::SpicePosition::PartialType |
Definition at line 204 of file SpicePosition.h.
This enum indicates the status of the object.
The class expects functions to be after MemCache in the list.
Definition at line 183 of file SpicePosition.h.
Isis::SpicePosition::SpicePosition | ( | int | targetCode, |
int | observerCode ) |
Construct an empty SpicePosition class using valid body codes.
See required reading ftp://naif.jpl.nasa.gov/pub/naif/toolkit_docs/C/ascii/individual_docs/naif_ids.req
targetCode | Valid naif body name. |
observerCode | Valid naif body name. |
Definition at line 37 of file SpicePosition.cpp.
References init().
|
virtual |
Destructor.
Free the memory allocated by this SpicePosition instance.
Definition at line 133 of file SpicePosition.cpp.
References ClearCache().
|
protected |
Constructor for swapping observer/target order.
This specialized constructor is provided to expressly support swap of observer/target order in the NAIF spkez_c/spkezp_c routines when determining the state of spacecraft and target body.
Traditionally, ISIS (and ISIS2!) has had the target/observer order swapped improperly to determine state vector between the two bodies. This constructor provides a transaitional path to correct this in a controlled way. See SpacecraftPosition for details.
Note that the targetCode and observerCode are always provided in the same order as the orignal constructor (i.e., targetCode=s/c, observerCode=planet) as the swapObserverTarget boolean parameter provides the means to properly implement the swap internally.
It is not as simple as simply swapping the codes in the constructor as internal representation of the state vector is in body fixed state of the target body relative to observer. If the swap is invoked, the state vector must be inverted.
targetCode | Traditional s/c code |
observerCode | Traditional target/planet code |
swapObserverTarget | True indicates implement the observer/target swap, false will invoke preexisting behavior |
Definition at line 70 of file SpicePosition.cpp.
References init().
Table Isis::SpicePosition::Cache | ( | const QString & | tableName | ) |
Return a table with J2000 positions.
Return a table containg the cached coordinates with the given name. The table will have four or seven columns, J2000 x,y,z (optionally vx,vy,vx) and the ephemeris time.
tableName | Name of the table to create and return |
2009-08-03 Jeannie Walldren - Added CacheType keyword to output table. This is based on p_source and will be read by LoadCache(Table).
2011-01-05 Debbie A. Cook - Added PolyFunction
Definition at line 549 of file SpicePosition.cpp.
References CacheLabel(), Isis::TableField::Double, Isis::IException::Io, LineCache(), m_state, Memcache2HermiteCache(), p_baseTime, p_cacheTime, p_coefficients, p_degree, p_fullCacheSize, p_hasVelocity, p_source, p_timeScale, PolyFunction, and PolyFunctionOverHermiteConstant.
Referenced by LineCache(), and LoadHermiteCache().
|
private |
Add labels to a SpicePosition table.
Return a table containing the labels defining the position table.
Definition at line 658 of file SpicePosition.cpp.
References HermiteCache, Isis::Table::Label(), Memcache, p_fullCacheEndTime, p_fullCacheSize, p_fullCacheStartTime, p_source, and Isis::toString().
Referenced by Cache().
|
inline |
Get the size of the current cached positions.
Definition at line 247 of file SpicePosition.h.
References m_state.
Referenced by Isis::Spice::createCache(), and Isis::Spice::init().
|
private |
Removes the entire cache from memory.
Definition at line 1484 of file SpicePosition.cpp.
References m_state, and p_cacheTime.
Referenced by LoadHermiteCache(), ReloadCache(), and ~SpicePosition().
void Isis::SpicePosition::ComputeBaseTime | ( | ) |
Compute the base time using cached times.
Definition at line 1116 of file SpicePosition.cpp.
References p_baseTime, p_cacheTime, p_override, p_overrideBaseTime, p_overrideTimeScale, and p_timeScale.
Referenced by SetPolynomial(), and SetPolynomial().
|
protected |
Computes the state vector of the target w.r.t observer.
This method computes the state vector of the target that is relative of the observer. It first attempts to retrieve with velocity vectors. If that fails, it makes an additional attempt to get the state w/o velocity vectors. The final result is indicated by the hasVelocity parameter.
The parameters to this routine are the same as the NAIF spkez_c/spkezp_c routines. See http://naif.jpl.nasa.gov/pub/naif/toolkit_docs/C/cspice/spkez_c.html for complete description.
Note that this routine does not actually affect the internals of this object (hence the constness of the method). It is up to the caller to apply the results and potentially handle swapping of observer/target and light time correction. See SpacecraftPosition for additional details on this application of the results.
et | Time to compute state vector for |
target | NAIF target code |
observer | NAIF observer code |
refFrame | Reference frame to express coordinates in (e.g., J2000) |
abcorr | Stellar aberration correction option |
state | Returns the 6-element state vector in target body fixed coordinates |
hasVelocity | Returns knowledge of whether the velocity vector is valid |
lightTime | Returns the light time correct resulting from the request if applicable |
Definition at line 1751 of file SpicePosition.cpp.
References Isis::NaifStatus::CheckErrors().
Referenced by Isis::SpacecraftPosition::SetEphemerisTimeSpice(), and SetEphemerisTimeSpice().
|
private |
Compute the velocity with respect to time instead of scaled time.
coef | A SpicePosition polynomial function partial type |
Definition at line 1612 of file SpicePosition.cpp.
References p_baseTime, p_coefficients, p_degree, p_et, and p_timeScale.
Referenced by SetEphemerisTimePolyFunction().
|
inlinevirtual |
Return the current J2000 position.
Definition at line 216 of file SpicePosition.h.
References p_coordinate.
Referenced by Isis::Spice::computeSolarLongitude(), GetCenterCoordinate(), Isis::Spice::instrumentBodyFixedPosition(), Isis::Spice::instrumentBodyFixedVelocity(), Isis::IsisIlluminator::position(), Isis::Spice::setTime(), Isis::Spice::subSpacecraftPoint(), and Isis::Spice::targetCenterDistance().
std::vector< double > Isis::SpicePosition::CoordinatePartial | ( | SpicePosition::PartialType | partialVar, |
int | coeffIndex ) |
Set the coefficients of a polynomial fit to each of the three coordinates of the position vector for the time period covered by the cache,.
coordinate = c0 + c1*t + c2*t**2 + ... cn*t**n, where t = (time - p_basetime) / p_timeScale.
partialVar | Designated variable of the partial derivative |
Definition at line 1167 of file SpicePosition.cpp.
References DPolynomial().
double Isis::SpicePosition::DPolynomial | ( | const int | coeffIndex | ) |
Evaluate the derivative of the fit polynomial (parabola) defined by the given coefficients with respect to the coefficient at the given index, at the current time.
coeffIndex | Index of coefficient to differentiate with respect to |
Definition at line 1244 of file SpicePosition.cpp.
References p_baseTime, p_degree, p_et, p_timeScale, Isis::IException::Programmer, and Isis::toString().
Referenced by CoordinatePartial().
|
inlinevirtual |
Return the current ephemeris time.
Definition at line 207 of file SpicePosition.h.
References p_et.
Referenced by getAdjustedEphemerisTime(), Isis::IsisIlluminator::position(), and Isis::IsisIlluminator::velocity().
std::vector< double > Isis::SpicePosition::Extrapolate | ( | double | timeEt | ) |
Extrapolate position for a given time assuming a constant velocity.
The position and velocity at the current time will be used to extrapolate position at the input time. If velocity does not exist, the value at the current time will be output. The caller must make sure to call SetEphemerisTime to set the time to the time to be used for the extrapolation.
[in] | timeEt | The time of the position to be extrapolated |
[out] | An | extrapolated position at the input time |
Definition at line 1635 of file SpicePosition.cpp.
References p_coordinate, p_et, p_hasVelocity, and p_velocity.
|
virtual |
Returns current state of stellar aberration correction.
The aberration correction is the value of the parameter that will be provided to the spkez_c/spkezp_c routines when determining the targer/observer vector state. See SetAberrationCorrection() for valid values.
Reimplemented in Isis::SpacecraftPosition.
Definition at line 213 of file SpicePosition.cpp.
References p_aberrationCorrection.
Referenced by SetEphemerisTimeSpice().
|
protected |
Returns adjusted ephemeris time.
This method returns the actual ephemeris time adjusted by a specifed time bias. The bias typically comes explicitly from the camera model but could be adjusted by the environment they are utlized in.
Definition at line 1714 of file SpicePosition.cpp.
References EphemerisTime(), and GetTimeBias().
Referenced by Isis::SpacecraftPosition::SetEphemerisTimeSpice(), and SetEphemerisTimeSpice().
|
inline |
Return the base time for the position.
Definition at line 276 of file SpicePosition.h.
References p_baseTime.
Referenced by Isis::IsisBundleObservation::initializeExteriorOrientation().
const std::vector< double > & Isis::SpicePosition::GetCenterCoordinate | ( | ) |
Compute and return the coordinate at the center time.
Definition at line 1595 of file SpicePosition.cpp.
References Coordinate(), p_fullCacheEndTime, p_fullCacheStartTime, and SetEphemerisTime().
Referenced by Isis::IsisBundleObservation::bundleOutputFetchData().
double Isis::SpicePosition::GetLightTime | ( | ) | const |
Return the light time coorection value.
This method returns the light time correction of the last call to SetEphemerisTimeSpice. This is the actual time after adjustments that has resulting int the adjustment of the target body. The observer position should be unchanged.
Definition at line 230 of file SpicePosition.cpp.
References m_lt.
|
protected |
Returns observer code.
This methods returns the proper observer code as specified in constructor. Code has been subjected to swapping if requested.
Definition at line 1684 of file SpicePosition.cpp.
References p_observerCode.
Referenced by Isis::SpacecraftPosition::SetEphemerisTimeSpice(), and SetEphemerisTimeSpice().
void Isis::SpicePosition::GetPolynomial | ( | std::vector< double > & | XC, |
std::vector< double > & | YC, | ||
std::vector< double > & | ZC ) |
Return the coefficients of a polynomial fit to each of the three coordinates of the position for the time period covered by the cache, angle = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_basetime) / p_timeScale.
[out] | XC | Coefficients of fit to first coordinate of position |
[out] | YC | Coefficients of fit to second coordinate of position |
[out] | ZC | Coefficients of fit to third coordinate of position |
Definition at line 1103 of file SpicePosition.cpp.
References p_coefficients.
Referenced by Isis::IsisBundleObservation::applyParameterCorrections(), Isis::IsisBundleObservation::bundleOutputFetchData(), and Isis::IsisBundleObservation::initializeExteriorOrientation().
|
inline |
Return the source of the position.
Definition at line 269 of file SpicePosition.h.
References p_source.
Referenced by Isis::Spice::createCache().
|
protected |
Returns target code.
This methods returns the proper target code as specified in constructor. Code has been subjected to swapping if requested.
Definition at line 1698 of file SpicePosition.cpp.
References p_targetCode.
Referenced by Isis::SpacecraftPosition::SetEphemerisTimeSpice(), and SetEphemerisTimeSpice().
double Isis::SpicePosition::GetTimeBias | ( | ) | const |
Returns the value of the time bias added to ET.
Definition at line 161 of file SpicePosition.cpp.
References p_timeBias.
Referenced by getAdjustedEphemerisTime().
|
inline |
Return the time scale for the position.
Definition at line 283 of file SpicePosition.h.
References p_timeScale.
Referenced by Isis::IsisBundleObservation::initializeExteriorOrientation().
|
inline |
Return the flag indicating whether the velocity exists.
Definition at line 224 of file SpicePosition.h.
References p_hasVelocity.
Referenced by Isis::Spice::createCache().
std::vector< double > Isis::SpicePosition::HermiteCoordinate | ( | ) |
This method returns the Hermite coordinate for the current time for PolyFunctionOverHermiteConstant functions.
Definition at line 1655 of file SpicePosition.cpp.
References p_coordinate, p_source, PolyFunctionOverHermiteConstant, Isis::IException::Programmer, and SetEphemerisTimeHermiteCache().
|
private |
Internal initialization of the object support observer/target swap.
This initailizer provides options to swap observer/target properly.
targetCode | Traditional s/c code |
observerCode | Traditional target/planet code |
swapObserverTarget | True indicates implement the observer/target swap, false will invoke preexisting behavior |
Definition at line 87 of file SpicePosition.cpp.
References m_lt, m_state, p_aberrationCorrection, p_baseTime, p_coefficients, p_coordinate, p_degree, p_degreeApplied, p_et, p_fullCacheEndTime, p_fullCacheSize, p_fullCacheStartTime, p_hasVelocity, p_observerCode, p_override, p_source, p_targetCode, p_timeBias, p_timeScale, p_velocity, and Spice.
Referenced by SpicePosition(), and SpicePosition().
|
inline |
Is this position cached.
Definition at line 242 of file SpicePosition.h.
References m_state.
Referenced by Isis::Spice::createCache().
Table Isis::SpicePosition::LineCache | ( | const QString & | tableName | ) |
Return a table with J2000 to reference positions.
Return a table containing the cached positions with the given name. The table will have seven columns, positionX, positionY, positionZ, angular velocity X, angular velocity Y, angular velocity Z, and time of J2000 position.
tableName | Name of the table to create and return |
Definition at line 704 of file SpicePosition.cpp.
References Cache(), HermiteCache, Memcache, p_source, Isis::IException::Programmer, and ReloadCache().
Referenced by Cache().
void Isis::SpicePosition::LoadCache | ( | double | startTime, |
double | endTime, | ||
int | size ) |
Cache J2000 position over a time range.
This method will load an internal cache with coordinates over a time range. This prevents the NAIF kernels from being read over-and-over again and slowing a application down due to I/O performance. Once the cache has been loaded then the kernels can be unloaded from the NAIF system.
startTime | Starting ephemeris time in seconds for the cache |
endTime | Ending ephemeris time in seconds for the cache |
size | Number of coordinates/positions to keep in the cache |
Definition at line 297 of file SpicePosition.cpp.
References HermiteCache, LoadTimeCache(), m_state, Memcache, p_cacheTime, p_coordinate, p_fullCacheEndTime, p_fullCacheSize, p_fullCacheStartTime, p_hasVelocity, p_source, p_velocity, Isis::IException::Programmer, and SetEphemerisTime().
Referenced by Isis::Spice::createCache(), Isis::Spice::init(), LoadCache(), and ReloadCache().
void Isis::SpicePosition::LoadCache | ( | double | time | ) |
Cache J2000 position for a time.
This method will load an internal cache with coordinates for a single time (e.g. useful for framing cameras). This prevents the NAIF kernels from being read over-and-over again and slowing a application down due to I/O performance. Once the cache has been loaded then the kernels can be unloaded from the NAIF system. This calls the LoadCache(stime,etime,size) method using the time as both the starting and ending time with a size of 1.
time | single ephemeris time in seconds to cache |
Definition at line 354 of file SpicePosition.cpp.
References LoadCache().
void Isis::SpicePosition::LoadCache | ( | nlohmann::json & | isd | ) |
Load the cached data from an ALE ISD.
The SpicePosition object must be set to a SPICE source before loading the cache.
isdPos | The ALE ISD as a JSON object. |
Definition at line 368 of file SpicePosition.cpp.
References m_state, Memcache, p_cacheTime, p_fullCacheEndTime, p_fullCacheSize, p_fullCacheStartTime, p_hasVelocity, p_source, Isis::IException::Programmer, and SetEphemerisTime().
void Isis::SpicePosition::LoadCache | ( | Table & | table | ) |
Cache J2000 positions using a table file.
This method will load an internal cache with coordinates from an ISIS table file. The table must have 4 columns, or 7 (if velocity) is included, and at least one row. The 4 columns contain the following information, body position x,y,z in J2000 and the ephemeris time of that position. If there are multiple rows it is assumed you can interpolate position at times in between the rows.
table | An ISIS table blob containing valid J2000 coordinate/time values |
2009-08-03 Jeannie Walldren - Reads CacheType keyword from table and sets p_source. If no CacheType keyword, we know this is an older image, so set p_source to Memcache.
2011-01-05 Debbie A. Cook - Added PolyFunction type
2011-04-08 Debbie A. Cook - Corrected loop counter in PolyFunction section to only go up to table.Records() - 1
Definition at line 429 of file SpicePosition.cpp.
References Isis::PvlObject::findKeyword(), Isis::PvlObject::hasKeyword(), HermiteCache, Isis::IException::Io, Isis::Table::Label(), m_state, Memcache, Isis::Table::Name(), p_cacheTime, p_fullCacheEndTime, p_fullCacheSize, p_fullCacheStartTime, p_hasVelocity, p_override, p_overrideTimeScale, p_source, PolyFunction, Isis::IException::Programmer, Isis::Table::Records(), SetOverrideBaseTime(), SetPolynomial(), SetPolynomialDegree(), and Isis::toDouble().
Table Isis::SpicePosition::LoadHermiteCache | ( | const QString & | tableName | ) |
Cache J2000 position over existing cached time range using polynomials stored as Hermite cubic spline knots.
This method will reload an internal cache with positions formed from a cubic Hermite spline over a time range. The method assumes a polynomial function has been fit to the coordinates of the positions and calculates the spline from the polynomial function.
Definition at line 793 of file SpicePosition.cpp.
References Cache(), ClearCache(), HermiteCache, m_state, p_baseTime, p_cacheTime, p_coefficients, p_coordinate, p_degree, p_et, p_fullCacheEndTime, p_fullCacheSize, p_fullCacheStartTime, p_hasVelocity, p_source, p_velocity, PolyFunction, Isis::IException::Programmer, and SetEphemerisTime().
|
private |
Load the time cache.
This method should works with the LoadCache(startTime, endTime, size) method to load the time cache.
Definition at line 1577 of file SpicePosition.cpp.
References p_cacheTime, p_fullCacheEndTime, p_fullCacheSize, and p_fullCacheStartTime.
Referenced by LoadCache(), and ReloadCache().
void Isis::SpicePosition::Memcache2HermiteCache | ( | double | tolerance | ) |
This method reduces the cache for position, time and velocity to the minimum number of values needed to interpolate the J2000 coordinates using a Hermite spline, given a tolerance of deviation from the NAIF values.
tolerance | Maximum error allowed between NAIF kernel coordinate values and values interpolated by the Hermite spline. |
Definition at line 1463 of file SpicePosition.cpp.
References HermiteCache, m_state, Memcache, p_cacheTime, p_source, and Isis::IException::Programmer.
Referenced by Cache(), Isis::Spice::createCache(), and Isis::Spice::init().
void Isis::SpicePosition::ReloadCache | ( | ) |
Cache J2000 positions over existing cached time range using polynomials.
This method will reload an internal cache with positions calculated from functions fit to the coordinates of the position over a time range.
Definition at line 729 of file SpicePosition.cpp.
References Isis::NaifStatus::CheckErrors(), HermiteCache, LoadTimeCache(), m_state, Memcache, p_cacheTime, p_coordinate, p_et, p_hasVelocity, p_source, p_velocity, Isis::IException::Programmer, and SetEphemerisTime().
Referenced by LineCache().
void Isis::SpicePosition::ReloadCache | ( | Table & | table | ) |
Cache J2000 position over existing cached time range using table.
This method will reload an internal cache with positions formed from coordinates in a table
table | An ISIS table blob containing valid J2000 coordinate/time values. |
Definition at line 1567 of file SpicePosition.cpp.
References ClearCache(), LoadCache(), p_source, and Spice.
double Isis::SpicePosition::scaledTime | ( | ) | const |
Return the scaled time.
Definition at line 1551 of file SpicePosition.cpp.
References p_baseTime, p_et, and p_timeScale.
|
virtual |
Set the aberration correction (light time)
See NAIF required reading for more information on this correction at ftp://naif.jpl.nasa.gov/pub/naif/toolkit_docs/C/ascii/individual_docs/spk.req
correction | This value must be one of the following: "NONE", "LT", "LT+S", "CN", "CN+S", "XLT", "XLT+S", "XCN" and "XCN+S" where LT is a correction for planetary aberration (light time), CN is converged Newtonian, XLT is transmission case using Newtonian formulation, XCN is transmission case using converged Newtonian formuation and S a correction for stellar aberration. See http://naif.jpl.nasa.gov/pub/naif/toolkit_docs/C/cspice/spkezr_c.html for additional information on the "abcorr" parameters. If never called the default is "LT+S". |
Reimplemented in Isis::SpacecraftPosition.
Definition at line 186 of file SpicePosition.cpp.
References p_aberrationCorrection, and Isis::IException::Programmer.
Referenced by Isis::SpacecraftPosition::SetAberrationCorrection().
|
virtual |
Return J2000 coordinate at given time.
This method returns the J2000 coordinates (x,y,z) of the body at a given et in seconds. The coordinates are obtained from either a valid NAIF spk kernel, or alternatively from an internal cache loaded from an ISIS Table object. In the first case, the SPK kernel must contain positions for the body code specified in the constructor at the given time and it must be loaded using the SpiceKernel class.
et | ephemeris time in seconds |
Definition at line 249 of file SpicePosition.cpp.
References Isis::NaifStatus::CheckErrors(), HermiteCache, Memcache, p_coordinate, p_et, p_source, PolyFunction, PolyFunctionOverHermiteConstant, SetEphemerisTimeHermiteCache(), SetEphemerisTimeMemcache(), SetEphemerisTimePolyFunction(), SetEphemerisTimePolyFunctionOverHermiteConstant(), and SetEphemerisTimeSpice().
Referenced by Isis::Spice::computeSolarLongitude(), GetCenterCoordinate(), LoadCache(), LoadCache(), LoadHermiteCache(), Isis::IsisIlluminator::position(), ReloadCache(), SetPolynomial(), SetPolynomial(), Isis::Spice::setTime(), and Isis::IsisIlluminator::velocity().
|
protected |
This is a protected method that is called by SetEphemerisTime() when Source type is HermiteCache.
It calculates J2000 coordinates (x,y,z) of the body that correspond to a given et in seconds. These coordinates are obtained by using a Hermite spline to interpolate values from an internal reduced cache loaded from an ISIS Table object.
Definition at line 1324 of file SpicePosition.cpp.
References Isis::IException::Io, m_state, p_coordinate, p_et, p_hasVelocity, and p_velocity.
Referenced by HermiteCoordinate(), SetEphemerisTime(), and SetEphemerisTimePolyFunctionOverHermiteConstant().
|
protected |
This is a protected method that is called by SetEphemerisTime() when Source type is Memcache.
It calculates J2000 coordinates (x,y,z) of the body that correspond to a given et in seconds. These coordinates are obtained from an internal cache loaded from an ISIS Table object.
Definition at line 1294 of file SpicePosition.cpp.
References m_state, p_cacheTime, p_coordinate, p_et, p_hasVelocity, and p_velocity.
Referenced by SetEphemerisTime().
|
protected |
This is a protected method that is called by SetEphemerisTime() when Source type is PolyFunction.
It calculates J2000 coordinates (x,y,z) of the body that correspond to a given et in seconds. These coordinates are obtained by using an nth degree polynomial function fit to each coordinate of the position vector.
Definition at line 1355 of file SpicePosition.cpp.
References ComputeVelocityInTime(), m_state, p_baseTime, p_coefficients, p_coordinate, p_degree, p_et, p_hasVelocity, p_timeScale, and p_velocity.
Referenced by SetEphemerisTime(), and SetEphemerisTimePolyFunctionOverHermiteConstant().
|
protected |
This is a protected method that is called by SetEphemerisTime() when Source type is PolyFunctionOverHermiteConstant.
It calculates J2000 coordinates (x,y,z) of the body that correspond to a given et in seconds. These coordinates are obtained by adding a constant cubic Hermite spline added to an nth degree polynomial function fit to each coordinate of the position vector.
Definition at line 1403 of file SpicePosition.cpp.
References p_coordinate, p_velocity, SetEphemerisTimeHermiteCache(), and SetEphemerisTimePolyFunction().
Referenced by SetEphemerisTime().
|
protectedvirtual |
This is a protected method that is called by SetEphemerisTime() when Source type is Spice.
It calculates J2000 coordinates (x,y,z) of the body that correspond to a given et in seconds. The coordinates are obtained from a valid NAIF spk kernel. The SPK kernel must contain positions for the body code specified in the constructor at the given time and it must be loaded using the SpiceKernel class.
Reimplemented in Isis::SpacecraftPosition.
Definition at line 1432 of file SpicePosition.cpp.
References computeStateVector(), GetAberrationCorrection(), getAdjustedEphemerisTime(), getObserverCode(), getTargetCode(), setLightTime(), and setStateVector().
Referenced by SetEphemerisTime(), and Isis::SpacecraftPosition::SetEphemerisTimeSpice().
|
protected |
Inheritors can set the light time if indicated.
Definition at line 1833 of file SpicePosition.cpp.
References m_lt.
Referenced by Isis::SpacecraftPosition::SetEphemerisTimeSpice(), and SetEphemerisTimeSpice().
void Isis::SpicePosition::SetOverrideBaseTime | ( | double | baseTime, |
double | timeScale ) |
Set an override base time to be used with observations on scanners to allow all images in an observation to use the same base time and polynomials for the positions.
[in] | baseTime | The baseTime to use and override the computed base time |
Definition at line 1147 of file SpicePosition.cpp.
References p_override, p_overrideBaseTime, and p_overrideTimeScale.
Referenced by Isis::IsisBundleObservation::initializeExteriorOrientation(), and LoadCache().
void Isis::SpicePosition::SetPolynomial | ( | const Source | type = PolyFunction | ) |
Set the coefficients of a polynomial fit to each of the components (X, Y, Z) of the position vector for the time period covered by the cache, component = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_baseTime) / p_timeScale.
< Basis function fit to X
< Basis function fit to Y
< Basis function fit to Z
Definition at line 930 of file SpicePosition.cpp.
References ComputeBaseTime(), m_state, p_baseTime, p_cacheTime, p_coordinate, p_degree, p_source, p_timeScale, PolyFunction, PolyFunctionOverHermiteConstant, SetEphemerisTime(), and SetPolynomial().
Referenced by Isis::IsisBundleObservation::initializeExteriorOrientation(), LoadCache(), SetPolynomial(), and SetPolynomialDegree().
void Isis::SpicePosition::SetPolynomial | ( | const std::vector< double > & | XC, |
const std::vector< double > & | YC, | ||
const std::vector< double > & | ZC, | ||
const Source | type = PolyFunction ) |
Set the coefficients of a polynomial (parabola) fit to each of the three coordinates of the position vector for the time period covered by the cache, coord = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_baseTime) / p_timeScale.
[in] | XC | Coefficients of fit to X coordinate |
[in] | YC | Coefficients of fit to Y coordinate |
[in] | ZC | Coefficients of fit to Z coordinate |
Definition at line 1054 of file SpicePosition.cpp.
References ComputeBaseTime(), p_coefficients, p_degree, p_degreeApplied, p_et, p_source, and SetEphemerisTime().
void Isis::SpicePosition::SetPolynomialDegree | ( | int | degree | ) |
Set the polynomial degree.
Set the degree of the polynomials to be fit to the three position coordinates for the time period covered by the cache, coordinate = c0 + c1*t + c2*t**2 + ... + cn*t**n, where t = (time - p_baseTime) / p_timeScale, and n = p_degree.
[in] | degree | Degree of the polynomial to be fit |
Definition at line 1502 of file SpicePosition.cpp.
References p_coefficients, p_degree, p_degreeApplied, p_fullCacheSize, and SetPolynomial().
Referenced by Isis::IsisBundleObservation::initializeExteriorOrientation(), and LoadCache().
|
protected |
Sets the state of target relative to observer.
This method sets the state of the target (vector) relative to the observer. Note that is the only place where the swap of observer/target adjustment to the state vector is handled. All contributors to this computation must compute the state vector representing the position and velocity of the target relative to the observer where the first three components of state[] are the x-, y- and z-component cartesian coordinates of the target's position; the last three are the corresponding velocity vector.
This routine maintains the directional integrity of the state vector should the observer/target be swapped. See the documentation for the spkez_c at http://naif.jpl.nasa.gov/pub/naif/toolkit_docs/C/cspice/spkez_c.html.
state | State vector. First three components of this 6 element array is the body fixed coordinates of the vector from the target to the observer. The last three components are the velocity state. |
hasVelocity | If true, then the velocity components of the state vector are valid, otherwise they should be ignored. |
Definition at line 1803 of file SpicePosition.cpp.
References p_coordinate, p_hasVelocity, and p_velocity.
Referenced by Isis::SpacecraftPosition::SetEphemerisTimeSpice(), and SetEphemerisTimeSpice().
void Isis::SpicePosition::SetTimeBias | ( | double | timeBias | ) |
Apply a time bias when invoking SetEphemerisTime method.
The bias is used only when reading from NAIF kernels. It is added to the ephermeris time passed into SetEphemerisTime and then the body position is read from the NAIF kernels and returned. When the cache is loaded from a table the bias is ignored as it is assumed to have already been applied. If this method is never called the default bias is 0.0 seconds.
timeBias | time bias in seconds |
Definition at line 150 of file SpicePosition.cpp.
References p_timeBias.
const std::vector< double > & Isis::SpicePosition::Velocity | ( | ) |
Return the current J2000 velocity.
Return the velocity vector if available.
Definition at line 1269 of file SpicePosition.cpp.
References p_hasVelocity, p_velocity, and Isis::IException::Programmer.
Referenced by Isis::Spice::computeSolarLongitude(), Isis::Spice::instrumentBodyFixedVelocity(), and Isis::IsisIlluminator::velocity().
std::vector< double > Isis::SpicePosition::VelocityPartial | ( | SpicePosition::PartialType | partialVar, |
int | coeffIndex ) |
Compute the derivative of the velocity with respect to the specified variable.
The velocity is the derivative of the coordinate with respect to time.
coordinate = C0 + C1*t + C2*t**2 + ... +Cn*t**n , where t = (time - p_basetime) / p_timeScale. velocity = (1/p_timeScale) * (C1 + 2*C2*t + ... + n*Cn*t**(n-1)) partial(velocity) with respect to C0 = 0. partial(velocity) with respect to C1 = 1/p_timeScale. partial(velocity) with respect to C2 = 2*t/p_timeScale partial(velocity) with respect to CN = n*t**(n-1)/p_timeScale
partialVar | Designated variable of the partial derivative |
Definition at line 1208 of file SpicePosition.cpp.
References p_baseTime, p_et, and p_timeScale.
|
friend |
Definition at line 297 of file SpicePosition.h.
|
private |
!< Swap traditional order
Definition at line 357 of file SpicePosition.h.
Referenced by GetLightTime(), init(), and setLightTime().
|
private |
!< Light time correction
Definition at line 359 of file SpicePosition.h.
Referenced by Cache(), cacheSize(), ClearCache(), init(), IsCached(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), Memcache2HermiteCache(), ReloadCache(), SetEphemerisTimeHermiteCache(), SetEphemerisTimeMemcache(), SetEphemerisTimePolyFunction(), and SetPolynomial().
|
private |
Definition at line 356 of file SpicePosition.h.
|
private |
Light time correction to apply.
Definition at line 331 of file SpicePosition.h.
Referenced by GetAberrationCorrection(), init(), and SetAberrationCorrection().
|
private |
Base time used in fit equations.
Definition at line 341 of file SpicePosition.h.
Referenced by Cache(), ComputeBaseTime(), ComputeVelocityInTime(), DPolynomial(), GetBaseTime(), init(), LoadHermiteCache(), scaledTime(), SetEphemerisTimePolyFunction(), SetPolynomial(), and VelocityPartial().
|
private |
iTime for corresponding position
Definition at line 338 of file SpicePosition.h.
Referenced by Cache(), ClearCache(), ComputeBaseTime(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), LoadTimeCache(), Memcache2HermiteCache(), ReloadCache(), SetEphemerisTimeMemcache(), and SetPolynomial().
|
private |
Coefficients of polynomials fit to 3 coordinates.
Definition at line 339 of file SpicePosition.h.
Referenced by Cache(), ComputeVelocityInTime(), GetPolynomial(), init(), LoadHermiteCache(), SetEphemerisTimePolyFunction(), SetPolynomial(), and SetPolynomialDegree().
|
private |
J2000 position at time et.
Definition at line 334 of file SpicePosition.h.
Referenced by Coordinate(), Extrapolate(), HermiteCoordinate(), init(), LoadCache(), LoadHermiteCache(), ReloadCache(), SetEphemerisTime(), SetEphemerisTimeHermiteCache(), SetEphemerisTimeMemcache(), SetEphemerisTimePolyFunction(), SetEphemerisTimePolyFunctionOverHermiteConstant(), SetPolynomial(), and setStateVector().
|
private |
Degree of polynomial function fit to the coordinates of the position.
Definition at line 346 of file SpicePosition.h.
Referenced by Cache(), ComputeVelocityInTime(), DPolynomial(), init(), LoadHermiteCache(), SetEphemerisTimePolyFunction(), SetPolynomial(), SetPolynomial(), and SetPolynomialDegree().
|
private |
Flag indicating whether or not a polynomial.
Definition at line 343 of file SpicePosition.h.
Referenced by init(), SetPolynomial(), and SetPolynomialDegree().
|
private |
Current ephemeris time.
Definition at line 333 of file SpicePosition.h.
Referenced by ComputeVelocityInTime(), DPolynomial(), EphemerisTime(), Extrapolate(), init(), LoadHermiteCache(), ReloadCache(), scaledTime(), SetEphemerisTime(), SetEphemerisTimeHermiteCache(), SetEphemerisTimeMemcache(), SetEphemerisTimePolyFunction(), SetPolynomial(), and VelocityPartial().
|
private |
Original end time of the complete cache after spiceinit.
Definition at line 348 of file SpicePosition.h.
Referenced by CacheLabel(), GetCenterCoordinate(), init(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), and LoadTimeCache().
|
private |
Orignial size of the complete cache after spiceinit.
Definition at line 349 of file SpicePosition.h.
Referenced by Cache(), CacheLabel(), init(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), LoadTimeCache(), and SetPolynomialDegree().
|
private |
Original start time of the complete cache after spiceinit.
Definition at line 347 of file SpicePosition.h.
Referenced by CacheLabel(), GetCenterCoordinate(), init(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), and LoadTimeCache().
|
private |
Flag to indicate velocity is available.
Definition at line 350 of file SpicePosition.h.
Referenced by Cache(), Extrapolate(), HasVelocity(), init(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), ReloadCache(), SetEphemerisTimeHermiteCache(), SetEphemerisTimeMemcache(), SetEphemerisTimePolyFunction(), setStateVector(), and Velocity().
|
private |
observer body code
Definition at line 328 of file SpicePosition.h.
Referenced by getObserverCode(), and init().
|
private |
Time base and scale override options;.
Definition at line 351 of file SpicePosition.h.
Referenced by ComputeBaseTime(), init(), LoadCache(), and SetOverrideBaseTime().
|
private |
Value set by caller to override computed base time.
Definition at line 352 of file SpicePosition.h.
Referenced by ComputeBaseTime(), and SetOverrideBaseTime().
|
private |
Value set by caller to override computed time scale.
Definition at line 353 of file SpicePosition.h.
Referenced by ComputeBaseTime(), LoadCache(), and SetOverrideBaseTime().
|
private |
Enumerated value for the location of the SPK information used.
Definition at line 337 of file SpicePosition.h.
Referenced by Cache(), CacheLabel(), GetSource(), HermiteCoordinate(), init(), LineCache(), LoadCache(), LoadCache(), LoadCache(), LoadHermiteCache(), Memcache2HermiteCache(), ReloadCache(), ReloadCache(), SetEphemerisTime(), SetPolynomial(), and SetPolynomial().
|
private |
target body code
Definition at line 327 of file SpicePosition.h.
Referenced by getTargetCode(), and init().
|
private |
iTime bias when reading kernels
Definition at line 330 of file SpicePosition.h.
Referenced by GetTimeBias(), init(), and SetTimeBias().
|
private |
Time scale used in fit equations.
Definition at line 342 of file SpicePosition.h.
Referenced by Cache(), ComputeBaseTime(), ComputeVelocityInTime(), DPolynomial(), GetTimeScale(), init(), scaledTime(), SetEphemerisTimePolyFunction(), SetPolynomial(), and VelocityPartial().
|
private |
J2000 velocity at time et.
Definition at line 335 of file SpicePosition.h.
Referenced by Extrapolate(), init(), LoadCache(), LoadHermiteCache(), ReloadCache(), SetEphemerisTimeHermiteCache(), SetEphemerisTimeMemcache(), SetEphemerisTimePolyFunction(), SetEphemerisTimePolyFunctionOverHermiteConstant(), setStateVector(), and Velocity().