Class AbstractMatricesHarvester
- All Implemented Interfaces:
MatricesHarvester
- Direct Known Subclasses:
AbstractAnalyticalMatricesHarvester,DSSTHarvester
additional state arrays.- Since:
- 11.1
- Author:
- Luc Maisonobe
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intDefault state dimension, equivalent to position and velocity vectors. -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedAbstractMatricesHarvester(String stmName, RealMatrix initialStm, DoubleArrayDictionary initialJacobianColumns) Simple constructor. -
Method Summary
Modifier and TypeMethodDescriptionabstract voidFreeze the names of the Jacobian columns.protected double[][]Get the conversion Jacobian between state parameters and parameters used for derivatives.double[]getInitialJacobianColumn(String columnName) Get the initial column of Jacobian matrix with respect to named parameter.Get the initial State Transition Matrix.Get the Jacobian with respect to propagation parameters.intGetter for the state dimension.Extract state transition matrix from state.Get the State Transition Matrix state name.voidsetReferenceState(SpacecraftState reference) Set up reference state.double[]toArray(double[][] matrix) Set the STM data into an array.toSquareMatrix(double[] array) Convert a flattened array to a square matrix.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.orekit.propagation.MatricesHarvester
getJacobiansColumnsNames, getOrbitType, getPositionAngleType
-
Field Details
-
DEFAULT_STATE_DIMENSION
public static final int DEFAULT_STATE_DIMENSIONDefault state dimension, equivalent to position and velocity vectors.- See Also:
-
-
Constructor Details
-
AbstractMatricesHarvester
protected AbstractMatricesHarvester(String stmName, RealMatrix initialStm, DoubleArrayDictionary initialJacobianColumns) Simple constructor.The arguments for initial matrices must be compatible with the
orbit typeandposition anglethat will be used by propagator- Parameters:
stmName- State Transition Matrix state nameinitialStm- initial State Transition Matrix ∂Y/∂Y₀, if null (which is the most frequent case), assumed to be 6x6 identityinitialJacobianColumns- initial columns of the Jacobians matrix with respect to parameters, if null or if some selected parameters are missing from the dictionary, the corresponding initial column is assumed to be 0
-
-
Method Details
-
getStateDimension
public int getStateDimension()Getter for the state dimension.- Returns:
- state dimension
- Since:
- 13.1
-
getStmName
Get the State Transition Matrix state name.- Returns:
- State Transition Matrix state name
-
getInitialStateTransitionMatrix
Get the initial State Transition Matrix.- Returns:
- initial State Transition Matrix
-
getInitialJacobianColumn
Get the initial column of Jacobian matrix with respect to named parameter.- Parameters:
columnName- name of the column- Returns:
- initial column of the Jacobian matrix
-
toSquareMatrix
Convert a flattened array to a square matrix.- Parameters:
array- input array- Returns:
- the corresponding matrix
- Since:
- 13.1
-
toArray
public double[] toArray(double[][] matrix) Set the STM data into an array.- Parameters:
matrix- STM matrix- Returns:
- an array containing the STM data
- Since:
- 13.1
-
getConversionJacobian
Get the conversion Jacobian between state parameters and parameters used for derivatives.The base implementation returns identity, which is suitable for DSST and TLE propagators, as state parameters and parameters used for derivatives are the same.
For Numerical propagator, parameters used for derivatives are Cartesian and they can be different from state parameters because the numerical propagator can accept different type of orbits, so the method is overridden in derived classes.
- Parameters:
state- spacecraft state- Returns:
- conversion Jacobian
-
setReferenceState
Set up reference state.This method is called whenever the global propagation reference state changes. This corresponds to the start of propagation in batch least squares orbit determination or at prediction step for each measurement in Kalman filtering. Its goal is to allow the harvester to compute some internal data. Analytical models like TLE use it to compute analytical derivatives, semi-analytical models like DSST use it to compute short periodic terms, numerical models do not use it at all.
- Specified by:
setReferenceStatein interfaceMatricesHarvester- Parameters:
reference- reference state to set
-
getStateTransitionMatrix
Extract state transition matrix from state.- Specified by:
getStateTransitionMatrixin interfaceMatricesHarvester- Parameters:
state- spacecraft state- Returns:
- state transition matrix, with semantics consistent with propagation,
or null if no state transition matrix is available
orbit type.
-
getParametersJacobian
Get the Jacobian with respect to propagation parameters.- Specified by:
getParametersJacobianin interfaceMatricesHarvester- Parameters:
state- spacecraft state- Returns:
- Jacobian with respect to propagation parameters, or null if there are no parameters
-
freezeColumnsNames
public abstract void freezeColumnsNames()Freeze the names of the Jacobian columns.This method is called when propagation starts, i.e. when configuration is completed
-