Class AbstractPropagator
- All Implemented Interfaces:
Propagator,PVCoordinatesProvider
- Direct Known Subclasses:
AbstractAnalyticalPropagator,AbstractIntegratedPropagator
Propagator methods for propagators.
This abstract class allows to provide easily the full set of Propagator
methods, including all propagation modes support and discrete events support for
any simple propagation method.
- Author:
- Luc Maisonobe
-
Field Summary
Fields inherited from interface org.orekit.propagation.Propagator
DEFAULT_MASS -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddAdditionalDataProvider(AdditionalDataProvider<?> provider) Add a set of user-specified data to be computed along with the orbit propagation.voidErases the internal matrices harvester.protected AbstractMatricesHarvestercreateHarvester(String stmName, RealMatrix initialStm, DoubleArrayDictionary initialJacobianColumns) Create the harvester suitable for propagator.Get an unmodifiable list of providers for additional data.Get attitude provider.getFrame()Get the frame in which the orbit is propagated.protected AbstractMatricesHarvesterGet the harvester.Get the propagator initial state.String[]Get all the names of all managed additional data.Get the multiplexer holding all step handlers.protected AbsoluteDateGet the start date.protected voidinitializeAdditionalData(AbsoluteDate target) Initialize the additional state providers at the start of propagation.protected voidInitialize propagation.booleanCheck if an additional data is managed.propagate(AbsoluteDate target) Propagate towards a target date.voidRemove an additional data provider.voidresetInitialState(SpacecraftState state) Reset the propagator initial state.voidsetAttitudeProvider(AttitudeProvider attitudeProvider) Set attitude provider.protected voidsetStartDate(AbsoluteDate startDate) Set a start date.setupMatricesComputation(String stmName, RealMatrix initialStm, DoubleArrayDictionary initialJacobianColumns) Set up computation of State Transition Matrix and Jacobians matrix with respect to parameters.protected voidstateChanged(SpacecraftState state) Notify about a state change.updateAdditionalData(SpacecraftState original) Update state by adding all additional data.protected SpacecraftStateupdateUnmanagedData(SpacecraftState original) Update state by adding unmanaged states.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.orekit.propagation.Propagator
addEventDetector, clearEventsDetectors, clearStepHandlers, getEphemerisGenerator, getEventDetectors, getPosition, getPVCoordinates, getVelocity, propagate, setStepHandler, setStepHandler
-
Constructor Details
-
AbstractPropagator
protected AbstractPropagator()Build a new instance.
-
-
Method Details
-
setStartDate
Set a start date.- Parameters:
startDate- start date
-
getStartDate
Get the start date.- Returns:
- start date
-
getAttitudeProvider
Get attitude provider.- Specified by:
getAttitudeProviderin interfacePropagator- Returns:
- attitude provider
-
setAttitudeProvider
Set attitude provider.- Specified by:
setAttitudeProviderin interfacePropagator- Parameters:
attitudeProvider- attitude provider
-
getInitialState
Get the propagator initial state.- Specified by:
getInitialStatein interfacePropagator- Returns:
- initial state
-
getFrame
Get the frame in which the orbit is propagated.The propagation frame is the definition frame of the initial state, so this method should be called after this state has been set, otherwise it may return null.
- Specified by:
getFramein interfacePropagator- Returns:
- frame in which the orbit is propagated
- See Also:
-
resetInitialState
Reset the propagator initial state.- Specified by:
resetInitialStatein interfacePropagator- Parameters:
state- new initial state to consider
-
getMultiplexer
Get the multiplexer holding all step handlers.- Specified by:
getMultiplexerin interfacePropagator- Returns:
- multiplexer holding all step handlers
-
addAdditionalDataProvider
Add a set of user-specified data to be computed along with the orbit propagation.- Specified by:
addAdditionalDataProviderin interfacePropagator- Parameters:
provider- provider for additional data
-
getAdditionalDataProviders
Get an unmodifiable list of providers for additional data.- Specified by:
getAdditionalDataProvidersin interfacePropagator- Returns:
- providers for the additional data
-
removeAdditionalDataProvider
Remove an additional data provider.- Parameters:
name- data name- Since:
- 13.1
-
setupMatricesComputation
public MatricesHarvester setupMatricesComputation(String stmName, RealMatrix initialStm, DoubleArrayDictionary initialJacobianColumns) Set up computation of State Transition Matrix and Jacobians matrix with respect to parameters.If this method is called, both State Transition Matrix and Jacobians with respect to the force models parameters that will be selected when propagation starts will be automatically computed, and the harvester will allow to retrieve them.
The arguments for initial matrices must be compatible with the
orbit typeandposition anglethat will be used by the propagator.- Specified by:
setupMatricesComputationin interfacePropagator- 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- Returns:
- harvester to retrieve computed matrices during and after propagation
-
clearMatricesComputation
public void clearMatricesComputation()Erases the internal matrices harvester.- Since:
- 13.1
-
createHarvester
protected AbstractMatricesHarvester createHarvester(String stmName, RealMatrix initialStm, DoubleArrayDictionary initialJacobianColumns) Create the harvester suitable for 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- Returns:
- harvester to retrieve computed matrices during and after propagation
- Since:
- 11.1
-
getHarvester
Get the harvester.- Returns:
- harvester, or null if it was not created
- Since:
- 11.1
-
updateUnmanagedData
Update state by adding unmanaged states.- Parameters:
original- original state- Returns:
- updated state, with unmanaged states included
- See Also:
-
updateAdditionalData
Update state by adding all additional data.- Parameters:
original- original state- Returns:
- updated state, with all additional data included
(including
unmanageddata) - See Also:
-
initializeAdditionalData
Initialize the additional state providers at the start of propagation.- Parameters:
target- date of propagation. Not equal toinitialState.getDate().- Since:
- 11.2
-
isAdditionalDataManaged
Check if an additional data is managed.Managed data are the ones for which the propagators know how to compute its evolution. They correspond to additional data for which a
providerhas been registered by calling theaddAdditionalDataProvidermethod.Additional data that are present in the
initial statebut have no evolution method registered are not considered as managed data. These unmanaged additional data are not lost during propagation, though. Their value are piecewise constant between state resets that may change them if some event handlerresetStatemethod is called at an event occurrence and happens to change the unmanaged additional data.- Specified by:
isAdditionalDataManagedin interfacePropagator- Parameters:
name- name of the additional data- Returns:
- true if the additional data is managed
-
getManagedAdditionalData
Get all the names of all managed additional data.- Specified by:
getManagedAdditionalDatain interfacePropagator- Returns:
- names of all managed additional data
-
propagate
Propagate towards a target date.Simple propagators use only the target date as the specification for computing the propagated state. More feature rich propagators can consider other information and provide different operating modes or G-stop facilities to stop at pinpointed events occurrences. In these cases, the target date is only a hint, not a mandatory objective.
- Specified by:
propagatein interfacePropagator- Parameters:
target- target date towards which orbit state should be propagated- Returns:
- propagated state
-
initializePropagation
protected void initializePropagation()Initialize propagation.- Since:
- 10.1
-
stateChanged
Notify about a state change.- Parameters:
state- new state
-