1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.utils.units;
18
19 import org.orekit.errors.OrekitException;
20 import org.orekit.errors.OrekitMessages;
21
22
23
24
25
26
27
28
29 public class UnitsConverter {
30
31
32 public static final UnitsConverter IDENTITY =
33 new UnitsConverter(Unit.ONE, Unit.ONE);
34
35
36 public static final UnitsConverter PERCENTS_TO_UNIT =
37 new UnitsConverter(Unit.PERCENT, Unit.ONE);
38
39
40 public static final UnitsConverter ARC_SECONDS_TO_RADIANS =
41 new UnitsConverter(Unit.parse("as"), Unit.RADIAN);
42
43
44 public static final UnitsConverter MILLI_ARC_SECONDS_TO_RADIANS =
45 new UnitsConverter(Unit.parse("mas"), Unit.RADIAN);
46
47
48 public static final UnitsConverter MILLI_SECONDS_TO_SECONDS =
49 new UnitsConverter(Unit.parse("ms"), Unit.SECOND);
50
51
52 public static final UnitsConverter DAYS_TO_SECONDS =
53 new UnitsConverter(Unit.DAY, Unit.SECOND);
54
55
56 public static final UnitsConverter KILOMETRES_TO_METRES =
57 new UnitsConverter(Unit.KILOMETRE, Unit.METRE);
58
59
60 public static final UnitsConverter KILOMETRES_2_TO_METRES_2 =
61 new UnitsConverter(Unit.parse("km²"), Unit.parse("m²"));
62
63
64 public static final UnitsConverter KM3_P_S2_TO_M3_P_S2 =
65 new UnitsConverter(Unit.parse("km³/s²"), Unit.parse("m³/s²"));
66
67
68 private final Unit from;
69
70
71 private final Unit to;
72
73
74 private final double factor;
75
76
77
78
79
80 public UnitsConverter(final Unit from, final Unit to) {
81 this.from = from;
82 this.to = to;
83 if (!from.sameDimension(to)) {
84 throw new OrekitException(OrekitMessages.INCOMPATIBLE_UNITS,
85 from.getName(), to.getName());
86 }
87 this.factor = from.getScale() / to.getScale();
88 }
89
90
91
92
93 public Unit getFrom() {
94 return from;
95 }
96
97
98
99
100 public Unit getTo() {
101 return to;
102 }
103
104
105
106
107
108 public double convert(final double value) {
109 return factor * value;
110 }
111
112
113 @Override
114 public String toString() {
115 return from.getName() + " → " + to.getName();
116 }
117
118 }