Package org.hipparchus.ode.events
Class FieldDetectorBasedEventState<T extends CalculusFieldElement<T>>
- java.lang.Object
- 
- org.hipparchus.ode.events.FieldDetectorBasedEventState<T>
 
- 
- Type Parameters:
- T- the type of the field elements
 - All Implemented Interfaces:
- FieldEventState<T>
 
 public class FieldDetectorBasedEventState<T extends CalculusFieldElement<T>> extends Object implements FieldEventState<T> This class handles the state for oneevent handlerduring integration steps.Each time the integrator proposes a step, the event handler switching function should be checked. This class handles the state of one handler during one integration step, with references to the state at the end of the preceding step. This information is used to decide if the handler should trigger an event or not during the proposed step. 
- 
- 
Constructor SummaryConstructors Constructor Description FieldDetectorBasedEventState(FieldODEEventDetector<T> detector)Simple constructor.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description FieldEventOccurrence<T>doEvent(FieldODEStateAndDerivative<T> state)Notify the user's listener of the event.booleanevaluateStep(FieldODEStateInterpolator<T> interpolator)Evaluate the impact of the proposed step on the event handler.FieldODEEventDetector<T>getEventDetector()Get the underlying event detector.TgetEventTime()Get the occurrence time of the event triggered in the current step.voidinit(FieldODEStateAndDerivative<T> s0, T t)Initialize event handler at the start of an integration.voidreinitializeBegin(FieldODEStateInterpolator<T> interpolator)Reinitialize the beginning of the step.booleantryAdvance(FieldODEStateAndDerivative<T> state, FieldODEStateInterpolator<T> interpolator)Try to accept the current history up to the given time.
 
- 
- 
- 
Constructor Detail- 
FieldDetectorBasedEventStatepublic FieldDetectorBasedEventState(FieldODEEventDetector<T> detector) Simple constructor.- Parameters:
- detector- event detector
- Since:
- 3.0
 
 
- 
 - 
Method Detail- 
getEventDetectorpublic FieldODEEventDetector<T> getEventDetector() Get the underlying event detector.- Returns:
- underlying event detector
- Since:
- 3.0
 
 - 
initpublic void init(FieldODEStateAndDerivative<T> s0, T t) Initialize event handler at the start of an integration.This method is called once at the start of the integration. It may be used by the event handler to initialize some internal data if needed. - Specified by:
- initin interface- FieldEventState<T extends CalculusFieldElement<T>>
- Parameters:
- s0- initial state
- t- target time for the integration
 
 - 
reinitializeBeginpublic void reinitializeBegin(FieldODEStateInterpolator<T> interpolator) throws MathIllegalStateException Reinitialize the beginning of the step.- Parameters:
- interpolator- valid for the current step
- Throws:
- MathIllegalStateException- if the interpolator throws one because the number of functions evaluations is exceeded
 
 - 
evaluateSteppublic boolean evaluateStep(FieldODEStateInterpolator<T> interpolator) throws MathIllegalArgumentException, MathIllegalStateException Evaluate the impact of the proposed step on the event handler.- Specified by:
- evaluateStepin interface- FieldEventState<T extends CalculusFieldElement<T>>
- Parameters:
- interpolator- step interpolator for the proposed step
- Returns:
- true if the event handler triggers an event before the end of the proposed step
- Throws:
- MathIllegalStateException- if the interpolator throws one because the number of functions evaluations is exceeded
- MathIllegalArgumentException- if the event cannot be bracketed
 
 - 
tryAdvancepublic boolean tryAdvance(FieldODEStateAndDerivative<T> state, FieldODEStateInterpolator<T> interpolator) Try to accept the current history up to the given time.It is not necessary to call this method before calling doEvent(FieldODEStateAndDerivative)with the same state. It is necessary to call this method before you calldoEvent(FieldODEStateAndDerivative)on some other event detector.- Parameters:
- state- to try to accept.
- interpolator- to use to find the new root, if any.
- Returns:
- if the event detector has an event it has not detected before that is on or
 before the same time as state. In other wordsfalsemeans continue on whiletruemeans stop and handle my event first.
 
 - 
doEventpublic FieldEventOccurrence<T> doEvent(FieldODEStateAndDerivative<T> state) Notify the user's listener of the event. The event occurs wholly within this method call including a call toFieldODEEventHandler.resetState(FieldODEEventDetector, FieldODEStateAndDerivative)if necessary.- Specified by:
- doEventin interface- FieldEventState<T extends CalculusFieldElement<T>>
- Parameters:
- state- the state at the time of the event. This must be at the same time as the current value of- getEventTime().
- Returns:
- the user's requested action and the new state if the action is Action.RESET_STATE. Otherwise the new state isstate. The stop time indicates what time propagation should stop if the action isAction.STOP. This guarantees the integration will stop on or after the root, so that integration may be restarted safely.
 
 - 
getEventTimepublic T getEventTime() Get the occurrence time of the event triggered in the current step.- Specified by:
- getEventTimein interface- FieldEventState<T extends CalculusFieldElement<T>>
- Returns:
- occurrence time of the event triggered in the current step or infinity if no events are triggered
 
 
- 
 
-