T
- the type of the field elementspublic interface FieldPropagator<T extends CalculusFieldElement<T>> extends FieldPVCoordinatesProvider<T>
This interface is the top-level abstraction for orbit propagation. It only allows propagation to a predefined date. It is implemented by analytical models which have no time limit, by orbit readers based on external data files, by numerical integrators using rich force models and by continuous models built after numerical integration has been completed and dense output data as been gathered.
Modifier and Type | Field and Description |
---|---|
static double |
DEFAULT_MASS
Default mass.
|
Modifier and Type | Method and Description |
---|---|
void |
addAdditionalStateProvider(FieldAdditionalStateProvider<T> additionalStateProvider)
Add a set of user-specified state parameters to be computed along with the orbit propagation.
|
<D extends FieldEventDetector<T>> |
addEventDetector(D detector)
Add an event detector.
|
void |
clearEventsDetectors()
Remove all events detectors.
|
default void |
clearStepHandlers()
Remove all step handlers.
|
List<FieldAdditionalStateProvider<T>> |
getAdditionalStateProviders()
Get an unmodifiable list of providers for additional state.
|
AttitudeProvider |
getAttitudeProvider()
Get attitude provider.
|
FieldEphemerisGenerator<T> |
getEphemerisGenerator()
Set up an ephemeris generator that will monitor the propagation for building
an ephemeris from it once completed.
|
Collection<FieldEventDetector<T>> |
getEventsDetectors()
Get all the events detectors that have been added.
|
Frame |
getFrame()
Get the frame in which the orbit is propagated.
|
FieldSpacecraftState<T> |
getInitialState()
Get the propagator initial state.
|
String[] |
getManagedAdditionalStates()
Get all the names of all managed states.
|
FieldStepHandlerMultiplexer<T> |
getMultiplexer()
Get the multiplexer holding all step handlers.
|
boolean |
isAdditionalStateManaged(String name)
Check if an additional state is managed.
|
FieldSpacecraftState<T> |
propagate(FieldAbsoluteDate<T> target)
Propagate towards a target date.
|
FieldSpacecraftState<T> |
propagate(FieldAbsoluteDate<T> start,
FieldAbsoluteDate<T> target)
Propagate from a start date towards a target date.
|
void |
resetInitialState(FieldSpacecraftState<T> state)
Reset the propagator initial state.
|
void |
setAttitudeProvider(AttitudeProvider attitudeProvider)
Set attitude provider.
|
default void |
setStepHandler(FieldOrekitStepHandler<T> handler)
Set a single handler for variable stepsizes.
|
default void |
setStepHandler(T h,
FieldOrekitFixedStepHandler<T> handler)
Set a single handler for fixed stepsizes.
|
getPVCoordinates
static final double DEFAULT_MASS
FieldStepHandlerMultiplexer<T> getMultiplexer()
default void clearStepHandlers()
This convenience method is equivalent to call getMultiplexer().clear()
getMultiplexer()
,
FieldStepHandlerMultiplexer.clear()
default void setStepHandler(T h, FieldOrekitFixedStepHandler<T> handler)
This convenience method is equivalent to call getMultiplexer().clear()
followed by getMultiplexer().add(h, handler)
h
- fixed stepsize (s)handler
- handler called at the end of each finalized stepgetMultiplexer()
,
FieldStepHandlerMultiplexer.add(CalculusFieldElement, FieldOrekitFixedStepHandler)
default void setStepHandler(FieldOrekitStepHandler<T> handler)
This convenience method is equivalent to call getMultiplexer().clear()
followed by getMultiplexer().add(handler)
handler
- handler called at the end of each finalized stepgetMultiplexer()
,
FieldStepHandlerMultiplexer.add(FieldOrekitStepHandler)
FieldEphemerisGenerator<T> getEphemerisGenerator()
This generator can be used when the user needs fast random access to the orbit state at any time between the initial and target times. A typical example is the implementation of search and iterative algorithms that may navigate forward and backward inside the propagation range before finding their result even if the propagator used is integration-based and only goes from one initial time to one target time.
Beware that when used with integration-based propagators, the generator will store all intermediate results. It is therefore memory intensive for long integration-based ranges and high precision/short time steps. When used with analytical propagators, the generator only stores start/stop time and a reference to the analytical propagator itself to call it back as needed, so it is less memory intensive.
The returned ephemeris generator will be initially empty, it will be filled
with propagation data when a subsequent call to either propagate(target)
or propagate(start, target)
is called. The proper way to use this method is
therefore to do:
FieldEphemerisGenerator<T> generator = propagator.getEphemerisGenerator(); propagator.propagate(target); FieldBoundedPropagator<T> ephemeris = generator.getGeneratedEphemeris();
FieldSpacecraftState<T> getInitialState()
void resetInitialState(FieldSpacecraftState<T> state)
state
- new initial state to considervoid addAdditionalStateProvider(FieldAdditionalStateProvider<T> additionalStateProvider)
additionalStateProvider
- provider for additional stateList<FieldAdditionalStateProvider<T>> getAdditionalStateProviders()
boolean isAdditionalStateManaged(String name)
Managed states are states for which the propagators know how to compute
its evolution. They correspond to additional states for which an
additional state provider
has been registered
by calling the addAdditionalStateProvider
method. If the propagator is an integrator-based
propagator
, the states for which a set of additional equations
has
been registered by calling the addAdditionalEquations
method are also counted as managed additional states.
Additional states that are present in the initial state
but have no evolution method registered are not considered as managed states.
These unmanaged additional states are not lost during propagation, though. Their
value are piecewise constant between state resets that may change them if some
event handler resetState
method is called at an event occurrence and happens
to change the unmanaged additional state.
name
- name of the additional stateString[] getManagedAdditionalStates()
<D extends FieldEventDetector<T>> void addEventDetector(D detector)
D
- class type for the generic versiondetector
- event detector to addclearEventsDetectors()
,
getEventsDetectors()
Collection<FieldEventDetector<T>> getEventsDetectors()
addEventDetector(FieldEventDetector)
,
clearEventsDetectors()
void clearEventsDetectors()
AttitudeProvider getAttitudeProvider()
void setAttitudeProvider(AttitudeProvider attitudeProvider)
attitudeProvider
- attitude providerFrame getFrame()
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.
resetInitialState(FieldSpacecraftState)
FieldSpacecraftState<T> propagate(FieldAbsoluteDate<T> target)
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.
target
- target date towards which orbit state should be propagatedFieldSpacecraftState<T> propagate(FieldAbsoluteDate<T> start, FieldAbsoluteDate<T> target)
Those propagators use a start date and a target date to compute the propagated state. For propagators using event detection mechanism, if the provided start date is different from the initial state date, a first, simple propagation is performed, without processing any event computation. Then complete propagation is performed from start date to target date.
start
- start date from which orbit state should be propagatedtarget
- target date to which orbit state should be propagatedCopyright © 2002-2023 CS GROUP. All rights reserved.