« Events » : différence entre les versions
Aucun résumé des modifications |
Aucun résumé des modifications |
||
Ligne 23 : | Ligne 23 : | ||
</syntaxhighlight> | </syntaxhighlight> | ||
* … or with an initial event for initialization (and it that case, wa have also | * … or with an initial event for initialization (and it that case, wa have also specified the kind of actions raised by this event with RESET actions): | ||
<syntaxhighlight lang="java"> | <syntaxhighlight lang="java"> | ||
final AbsoluteDate date0 = new AbsoluteDate(2010, 1, 1, TimeScalesFactory.getUTC()); | final AbsoluteDate date0 = new AbsoluteDate(2010, 1, 1, TimeScalesFactory.getUTC()); | ||
final CustomDateDetector dateDetector = new CustomDateDetector(date0 | final CustomDateDetector dateDetector = new CustomDateDetector(date0); | ||
date = new GPDateDetector("Absolute date eve nt", dateDetector, Action. | date = new GPDateDetector("Absolute date eve nt", dateDetector, Action.RESET_STATE, Action.RESET_DERIVATIVES); | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Note: we do not use directly [[https://logiciels.cnes.fr/en/node/62?type=desc PATRIUS]] detectors but <font color=#556B2F>'''GENOPUS'''</font> ones as some getter methods, necessary for the widgets, do not exist. | Note: we do not use directly [[https://logiciels.cnes.fr/en/node/62?type=desc PATRIUS]] detectors but <font color=#556B2F>'''GENOPUS'''</font> ones as some getter methods, necessary for the widgets, do not exist. | ||
There is also the possibility to freeze the action associated for such events (for example, if the event is associated to a maneuver, it must be set to '''STOP''' and there must have no possibility to change the action: | There is also the possibility to freeze the action associated for such events (for example, if the event is associated to a maneuver, it must be set to '''STOP''' and there must have no possibility to change the action. In fact, we have just to give oa single action in the constructor and this action will not be displayed. With the previous date event, it will be: | ||
<syntaxhighlight lang="java"> | <syntaxhighlight lang="java"> | ||
date | date = new GPDateDetector("Absolute date eve nt", dateDetector, Action.STOP); | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Version du 25 octobre 2017 à 15:04
Some widgets are corresponding to the most used orbital events as defined with [PATRIUS]. The following list Is not exhaustive but will present the use of a part of them. Moreover such events are also internally used in attitude or maneuver sequences.
How to call it
Some basic event widgets are:
And the following events are specific as they have the possibility to define an occurrence for triggering them.
- GPAOLDetector,
- GPApsideDetector,
- GPEclipseDetector,
- GPLocalTimeDetector,
- GPNodeDetector,
- GPVisibilityFromStationDetector,
It is very simple to call them:
- Using a constructor with a single label:
date = new GPDateDetector("Absolute date event");
- … or with an initial event for initialization (and it that case, wa have also specified the kind of actions raised by this event with RESET actions):
final AbsoluteDate date0 = new AbsoluteDate(2010, 1, 1, TimeScalesFactory.getUTC());
final CustomDateDetector dateDetector = new CustomDateDetector(date0);
date = new GPDateDetector("Absolute date eve nt", dateDetector, Action.RESET_STATE, Action.RESET_DERIVATIVES);
Note: we do not use directly [PATRIUS] detectors but GENOPUS ones as some getter methods, necessary for the widgets, do not exist. There is also the possibility to freeze the action associated for such events (for example, if the event is associated to a maneuver, it must be set to STOP and there must have no possibility to change the action. In fact, we have just to give oa single action in the constructor and this action will not be displayed. With the previous date event, it will be:
date = new GPDateDetector("Absolute date eve nt", dateDetector, Action.STOP);
Moreover, it exists a global GPEventSelector widget proposing a menu to select an event through a redefined list. In the example below, we will propose only an apside and a node event …
eventSelector =
new GPEventSelector("Events:", GPEventsEnum.APSIDE, GPEventsEnum.NODE);
Display
The display just below corresponds to GPAltitudeDetector:
Fichier:GPAltitudeDetector.png
We see that the display is composed of an GPAbsoluteDate widget followed by fields corresponding to the event definition with the type of action (see [PATRIUS] documentation for more information):
… and eventually expert settings including the checking interval and the convergence threshold (see [PATRIUS] documentation for more information):
On the following example (GPAOLDetector), we see another event detector but with a trigger information (i.e. the occurrence of the event):
At last, here is the display when using GPEventSelector widget:
How to use it
To get the corresponding GENOPUS objects, we will just have to call for the getPatriusObject() method as below:
CustomDateDetector dateDetector = date.getPatriusObject();
… or, when using GPEventSelector:
CustomDateDetector dateDetector = eventSelector.getPatriusObject()
How it is stored
Here is an example of XML format for <font GPDateDetector:
<DateDetector name="Absolute_date_event">
<AbsoluteDate name="eventDate">
<String name="date">01/01/2010 00h00m00s</String>
<String name="scale">UTC</String>
</AbsoluteDate>
<String name="actionData">STOP</String>
<Real name="maxCheck" unit="s">1.0E10</Real>
<Real name="threshold" unit="s">1.0E-9</Real>
</DateDetector>