1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.files.ccsds.ndm.adm.acm;
18
19 import org.orekit.files.ccsds.definitions.Units;
20 import org.orekit.files.ccsds.utils.ContextBinding;
21 import org.orekit.files.ccsds.utils.lexical.ParseToken;
22 import org.orekit.files.ccsds.utils.lexical.TokenType;
23 import org.orekit.utils.units.Unit;
24
25
26
27
28
29
30 public enum AttitudePhysicalPropertiesKey {
31
32
33 COMMENT((token, context, container) ->
34 token.getType() == TokenType.ENTRY ? container.addComment(token.getContentAsNormalizedString()) : true),
35
36
37 DRAG_COEFF((token, context, container) -> token.processAsDouble(Unit.ONE, context.getParsedUnitsBehavior(),
38 container::setDragCoefficient)),
39
40
41 WET_MASS((token, context, container) -> token.processAsDouble(Unit.KILOGRAM, context.getParsedUnitsBehavior(),
42 container::setWetMass)),
43
44
45 DRY_MASS((token, context, container) -> token.processAsDouble(Unit.KILOGRAM, context.getParsedUnitsBehavior(),
46 container::setDryMass)),
47
48
49 CP_REF_FRAME((token, context, container) -> token.processAsFrame(container::setCenterOfPressureReferenceFrame, context, false, false, true)),
50
51
52 CP((token, context, container) -> token.processAsVector(Unit.METRE, context.getParsedUnitsBehavior(),
53 container::setCenterOfPressure)),
54
55
56 INERTIA_REF_FRAME((token, context, container) -> token.processAsFrame(container::setInertiaReferenceFrame, context, false, false, true)),
57
58
59 IXX((token, context, container) -> token.processAsDoublyIndexedDouble(0, 0, Units.KG_M2, context.getParsedUnitsBehavior(),
60 container::setInertiaMatrixEntry)),
61
62
63 IYY((token, context, container) -> token.processAsDoublyIndexedDouble(1, 1, Units.KG_M2, context.getParsedUnitsBehavior(),
64 container::setInertiaMatrixEntry)),
65
66
67 IZZ((token, context, container) -> token.processAsDoublyIndexedDouble(2, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
68 container::setInertiaMatrixEntry)),
69
70
71 IXY((token, context, container) -> token.processAsDoublyIndexedDouble(0, 1, Units.KG_M2, context.getParsedUnitsBehavior(),
72 container::setInertiaMatrixEntry)),
73
74
75 IXZ((token, context, container) -> token.processAsDoublyIndexedDouble(0, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
76 container::setInertiaMatrixEntry)),
77
78
79 IYZ((token, context, container) -> token.processAsDoublyIndexedDouble(1, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
80 container::setInertiaMatrixEntry));
81
82
83 private final transient TokenProcessor processor;
84
85
86
87
88 AttitudePhysicalPropertiesKey(final TokenProcessor processor) {
89 this.processor = processor;
90 }
91
92
93
94
95
96
97
98 public boolean process(final ParseToken token, final ContextBinding context, final AttitudePhysicalProperties data) {
99 return processor.process(token, context, data);
100 }
101
102
103 interface TokenProcessor {
104
105
106
107
108
109
110 boolean process(ParseToken token, ContextBinding context, AttitudePhysicalProperties data);
111 }
112
113 }