1 package org.djunits.value.vfloat.scalar;
2
3 import java.util.Locale;
4
5 import org.djunits.unit.DimensionlessUnit;
6 import org.djunits.unit.EquivalentDoseUnit;
7 import org.djunits.value.vfloat.scalar.base.FloatScalar;
8 import org.djunits.value.vfloat.scalar.base.FloatScalarRel;
9 import org.djutils.base.NumberParser;
10 import org.djutils.exceptions.Throw;
11
12 import jakarta.annotation.Generated;
13
14
15
16
17
18
19
20
21
22
23 @Generated(value = "org.djunits.generator.GenerateDJUNIT", date = "2023-07-23T14:06:38.224104100Z")
24 public class FloatEquivalentDose extends FloatScalarRel<EquivalentDoseUnit, FloatEquivalentDose>
25 {
26
27 private static final long serialVersionUID = 20150901L;
28
29
30 public static final FloatEquivalentDose ZERO = new FloatEquivalentDose(0.0f, EquivalentDoseUnit.SI);
31
32
33 public static final FloatEquivalentDose ONE = new FloatEquivalentDose(1.0f, EquivalentDoseUnit.SI);
34
35
36 @SuppressWarnings("checkstyle:constantname")
37 public static final FloatEquivalentDose NaN = new FloatEquivalentDose(Float.NaN, EquivalentDoseUnit.SI);
38
39
40 public static final FloatEquivalentDose POSITIVE_INFINITY =
41 new FloatEquivalentDose(Float.POSITIVE_INFINITY, EquivalentDoseUnit.SI);
42
43
44 public static final FloatEquivalentDose NEGATIVE_INFINITY =
45 new FloatEquivalentDose(Float.NEGATIVE_INFINITY, EquivalentDoseUnit.SI);
46
47
48 public static final FloatEquivalentDose POS_MAXVALUE = new FloatEquivalentDose(Float.MAX_VALUE, EquivalentDoseUnit.SI);
49
50
51 public static final FloatEquivalentDose NEG_MAXVALUE = new FloatEquivalentDose(-Float.MAX_VALUE, EquivalentDoseUnit.SI);
52
53
54
55
56
57
58 public FloatEquivalentDose(final float value, final EquivalentDoseUnit unit)
59 {
60 super(value, unit);
61 }
62
63
64
65
66
67 public FloatEquivalentDose(final FloatEquivalentDose value)
68 {
69 super(value);
70 }
71
72
73
74
75
76
77 public FloatEquivalentDose(final double value, final EquivalentDoseUnit unit)
78 {
79 super((float) value, unit);
80 }
81
82
83 @Override
84 public final FloatEquivalentDose instantiateRel(final float value, final EquivalentDoseUnit unit)
85 {
86 return new FloatEquivalentDose(value, unit);
87 }
88
89
90
91
92
93
94 public static final FloatEquivalentDose instantiateSI(final float value)
95 {
96 return new FloatEquivalentDose(value, EquivalentDoseUnit.SI);
97 }
98
99
100
101
102
103
104
105
106 public static FloatEquivalentDose interpolate(final FloatEquivalentDose zero, final FloatEquivalentDose one,
107 final float ratio)
108 {
109 return new FloatEquivalentDose(zero.getInUnit() * (1 - ratio) + one.getInUnit(zero.getDisplayUnit()) * ratio,
110 zero.getDisplayUnit());
111 }
112
113
114
115
116
117
118
119 public static FloatEquivalentDose max(final FloatEquivalentDose r1, final FloatEquivalentDose r2)
120 {
121 return r1.gt(r2) ? r1 : r2;
122 }
123
124
125
126
127
128
129
130
131 public static FloatEquivalentDose max(final FloatEquivalentDose r1, final FloatEquivalentDose r2,
132 final FloatEquivalentDose... rn)
133 {
134 FloatEquivalentDose maxr = r1.gt(r2) ? r1 : r2;
135 for (FloatEquivalentDose r : rn)
136 {
137 if (r.gt(maxr))
138 {
139 maxr = r;
140 }
141 }
142 return maxr;
143 }
144
145
146
147
148
149
150
151 public static FloatEquivalentDose min(final FloatEquivalentDose r1, final FloatEquivalentDose r2)
152 {
153 return r1.lt(r2) ? r1 : r2;
154 }
155
156
157
158
159
160
161
162
163 public static FloatEquivalentDose min(final FloatEquivalentDose r1, final FloatEquivalentDose r2,
164 final FloatEquivalentDose... rn)
165 {
166 FloatEquivalentDose minr = r1.lt(r2) ? r1 : r2;
167 for (FloatEquivalentDose r : rn)
168 {
169 if (r.lt(minr))
170 {
171 minr = r;
172 }
173 }
174 return minr;
175 }
176
177
178
179
180
181
182
183
184
185
186 public static FloatEquivalentDose valueOf(final String text)
187 {
188 Throw.whenNull(text, "Error parsing FloatEquivalentDose: text to parse is null");
189 Throw.when(text.length() == 0, IllegalArgumentException.class,
190 "Error parsing FloatEquivalentDose: empty text to parse");
191 try
192 {
193 NumberParser numberParser = new NumberParser().lenient().trailing();
194 float f = numberParser.parseFloat(text);
195 String unitString = text.substring(numberParser.getTrailingPosition()).trim();
196 EquivalentDoseUnit unit = EquivalentDoseUnit.BASE.getUnitByAbbreviation(unitString);
197 if (unit == null)
198 throw new IllegalArgumentException("Unit " + unitString + " not found");
199 return new FloatEquivalentDose(f, unit);
200 }
201 catch (Exception exception)
202 {
203 throw new IllegalArgumentException("Error parsing FloatEquivalentDose from " + text + " using Locale "
204 + Locale.getDefault(Locale.Category.FORMAT), exception);
205 }
206 }
207
208
209
210
211
212
213
214
215
216 public static FloatEquivalentDose of(final float value, final String unitString)
217 {
218 Throw.whenNull(unitString, "Error parsing FloatEquivalentDose: unitString is null");
219 Throw.when(unitString.length() == 0, IllegalArgumentException.class,
220 "Error parsing FloatEquivalentDose: empty unitString");
221 EquivalentDoseUnit unit = EquivalentDoseUnit.BASE.getUnitByAbbreviation(unitString);
222 if (unit != null)
223 {
224 return new FloatEquivalentDose(value, unit);
225 }
226 throw new IllegalArgumentException("Error parsing FloatEquivalentDose with unit " + unitString);
227 }
228
229
230
231
232
233
234 public final FloatDimensionless divide(final FloatEquivalentDose v)
235 {
236 return new FloatDimensionless(this.si / v.si, DimensionlessUnit.SI);
237 }
238
239
240 @Override
241 public FloatSIScalar reciprocal()
242 {
243 return FloatScalar.divide(FloatDimensionless.ONE, this);
244 }
245
246 }