Class EclipseDetector
- java.lang.Object
-
- org.orekit.propagation.events.AbstractDetector<EclipseDetector>
-
- org.orekit.propagation.events.EclipseDetector
-
- All Implemented Interfaces:
Serializable
,EventDetector
public class EclipseDetector extends AbstractDetector<EclipseDetector>
Finder for satellite eclipse related events.This class finds eclipse events, i.e. satellite within umbra (total eclipse) or penumbra (partial eclipse).
The default implementation behavior is to
continue
propagation when entering the eclipse and tostop
propagation when exiting the eclipse. This can be changed by callingAbstractDetector.withHandler(EventHandler)
after construction.- Author:
- Pascal Parraud
- See Also:
Propagator.addEventDetector(EventDetector)
, Serialized Form
-
-
Field Summary
-
Fields inherited from class org.orekit.propagation.events.AbstractDetector
DEFAULT_MAX_ITER, DEFAULT_MAXCHECK, DEFAULT_THRESHOLD
-
-
Constructor Summary
Constructors Constructor Description EclipseDetector(double maxCheck, double threshold, PVCoordinatesProvider occulted, double occultedRadius, PVCoordinatesProvider occulting, double occultingRadius)
Build a new eclipse detector.EclipseDetector(double maxCheck, PVCoordinatesProvider occulted, double occultedRadius, PVCoordinatesProvider occulting, double occultingRadius)
Build a new eclipse detector.EclipseDetector(PVCoordinatesProvider occulted, double occultedRadius, PVCoordinatesProvider occulting, double occultingRadius)
Build a new eclipse detector.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected EclipseDetector
create(double newMaxCheck, double newThreshold, int nawMaxIter, EventHandler<? super EclipseDetector> newHandler)
Build a new instance.double
g(SpacecraftState s)
Compute the value of the switching function.PVCoordinatesProvider
getOcculted()
Get the occulted body.double
getOccultedRadius()
Get the occulted body radius (m).PVCoordinatesProvider
getOcculting()
Get the occulting body.double
getOccultingRadius()
Get the occulting body radius (m).boolean
getTotalEclipse()
Get the total eclipse detection flag.EclipseDetector
withPenumbra()
Setup the detector to penumbra detection.EclipseDetector
withUmbra()
Setup the detector to full umbra detection.-
Methods inherited from class org.orekit.propagation.events.AbstractDetector
eventOccurred, getHandler, getMaxCheckInterval, getMaxIterationCount, getThreshold, init, isForward, resetState, withHandler, withMaxCheck, withMaxIter, withThreshold
-
-
-
-
Constructor Detail
-
EclipseDetector
public EclipseDetector(PVCoordinatesProvider occulted, double occultedRadius, PVCoordinatesProvider occulting, double occultingRadius)
Build a new eclipse detector.The new instance is a total eclipse (umbra) detector with default values for maximal checking interval (
AbstractDetector.DEFAULT_MAXCHECK
) and convergence threshold (AbstractDetector.DEFAULT_THRESHOLD
).- Parameters:
occulted
- the body to be occultedoccultedRadius
- the radius of the body to be occulted (m)occulting
- the occulting bodyoccultingRadius
- the occulting body radius (m)
-
EclipseDetector
public EclipseDetector(double maxCheck, PVCoordinatesProvider occulted, double occultedRadius, PVCoordinatesProvider occulting, double occultingRadius)
Build a new eclipse detector.The new instance is a total eclipse (umbra) detector with default value for convergence threshold (
AbstractDetector.DEFAULT_THRESHOLD
).The maximal interval between eclipse checks should be smaller than the half duration of the minimal pass to handle, otherwise some short passes could be missed.
- Parameters:
maxCheck
- maximal checking interval (s)occulted
- the body to be occultedoccultedRadius
- the radius of the body to be occulted in metersocculting
- the occulting bodyoccultingRadius
- the occulting body radius in meters
-
EclipseDetector
public EclipseDetector(double maxCheck, double threshold, PVCoordinatesProvider occulted, double occultedRadius, PVCoordinatesProvider occulting, double occultingRadius)
Build a new eclipse detector.The new instance is a total eclipse (umbra) detector.
The maximal interval between eclipse checks should be smaller than the half duration of the minimal pass to handle, otherwise some short passes could be missed.
- Parameters:
maxCheck
- maximal checking interval (s)threshold
- convergence threshold (s)occulted
- the body to be occultedoccultedRadius
- the radius of the body to be occulted in metersocculting
- the occulting bodyoccultingRadius
- the occulting body radius in meters
-
-
Method Detail
-
create
protected EclipseDetector create(double newMaxCheck, double newThreshold, int nawMaxIter, EventHandler<? super EclipseDetector> newHandler)
Build a new instance.- Specified by:
create
in classAbstractDetector<EclipseDetector>
- Parameters:
newMaxCheck
- maximum checking interval (s)newThreshold
- convergence threshold (s)nawMaxIter
- maximum number of iterations in the event time searchnewHandler
- event handler to call at event occurrences- Returns:
- a new instance of the appropriate sub-type
-
withUmbra
public EclipseDetector withUmbra()
Setup the detector to full umbra detection.This will override a penumbra/umbra flag if it has been configured previously.
- Returns:
- a new detector with updated configuration (the instance is not changed)
- Since:
- 6.1
- See Also:
withPenumbra()
-
withPenumbra
public EclipseDetector withPenumbra()
Setup the detector to penumbra detection.This will override a penumbra/umbra flag if it has been configured previously.
- Returns:
- a new detector with updated configuration (the instance is not changed)
- Since:
- 6.1
- See Also:
withUmbra()
-
getOcculting
public PVCoordinatesProvider getOcculting()
Get the occulting body.- Returns:
- the occulting body
-
getOccultingRadius
public double getOccultingRadius()
Get the occulting body radius (m).- Returns:
- the occulting body radius
-
getOcculted
public PVCoordinatesProvider getOcculted()
Get the occulted body.- Returns:
- the occulted body
-
getOccultedRadius
public double getOccultedRadius()
Get the occulted body radius (m).- Returns:
- the occulted body radius
-
getTotalEclipse
public boolean getTotalEclipse()
Get the total eclipse detection flag.- Returns:
- the total eclipse detection flag (true for umbra events detection, false for penumbra events detection)
-
g
public double g(SpacecraftState s)
Compute the value of the switching function. This function becomes negative when entering the region of shadow and positive when exiting.- Specified by:
g
in interfaceEventDetector
- Specified by:
g
in classAbstractDetector<EclipseDetector>
- Parameters:
s
- the current state information: date, kinematics, attitude- Returns:
- value of the switching function
-
-