1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package com.irurueta.navigation.inertial.calibration.intervals.thresholdfactor;
17
18 import com.irurueta.navigation.LockedException;
19 import com.irurueta.navigation.NavigationException;
20 import com.irurueta.navigation.NotReadyException;
21 import com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence;
22 import com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics;
23 import com.irurueta.navigation.inertial.calibration.StandardDeviationBodyMagneticFluxDensity;
24 import com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics;
25 import com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerCalibratorMeasurementType;
26 import com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator;
27 import com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeCalibratorMeasurementOrSequenceType;
28 import com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator;
29 import com.irurueta.navigation.inertial.calibration.magnetometer.MagnetometerCalibratorMeasurementType;
30 import com.irurueta.navigation.inertial.calibration.magnetometer.MagnetometerNonLinearCalibrator;
31 import com.irurueta.numerical.EvaluationException;
32 import com.irurueta.numerical.InvalidBracketRangeException;
33 import com.irurueta.numerical.NumericalException;
34 import com.irurueta.numerical.SingleDimensionFunctionEvaluatorListener;
35 import com.irurueta.numerical.optimization.BracketedSingleOptimizer;
36 import com.irurueta.numerical.optimization.BrentSingleOptimizer;
37 import com.irurueta.numerical.optimization.OnIterationCompletedListener;
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54 public class BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer extends
55 AccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer {
56
57
58
59
60
61 private BracketedSingleOptimizer mseOptimizer;
62
63
64
65
66 private SingleDimensionFunctionEvaluatorListener optimizerListener;
67
68
69
70
71 private OnIterationCompletedListener iterationCompletedListener;
72
73
74
75
76 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer() {
77 super();
78 initializeOptimizerListeners();
79 try {
80 setMseOptimizer(new BrentSingleOptimizer());
81 } catch (final LockedException ignore) {
82
83 }
84 }
85
86
87
88
89
90
91 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
92 final AccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource) {
93 super(dataSource);
94 initializeOptimizerListeners();
95 try {
96 setMseOptimizer(new BrentSingleOptimizer());
97 } catch (final LockedException ignore) {
98
99 }
100 }
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
120 final AccelerometerNonLinearCalibrator accelerometerCalibrator,
121 final GyroscopeNonLinearCalibrator gyroscopeCalibrator,
122 final MagnetometerNonLinearCalibrator magnetometerCalibrator) {
123 super(accelerometerCalibrator, gyroscopeCalibrator, magnetometerCalibrator);
124 initializeOptimizerListeners();
125 try {
126 setMseOptimizer(new BrentSingleOptimizer());
127 } catch (final LockedException ignore) {
128
129 }
130 }
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
151 final AccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource,
152 final AccelerometerNonLinearCalibrator accelerometerCalibrator,
153 final GyroscopeNonLinearCalibrator gyroscopeCalibrator,
154 final MagnetometerNonLinearCalibrator magnetometerCalibrator) {
155 super(dataSource, accelerometerCalibrator, gyroscopeCalibrator, magnetometerCalibrator);
156 initializeOptimizerListeners();
157 try {
158 setMseOptimizer(new BrentSingleOptimizer());
159 } catch (final LockedException ignore) {
160
161 }
162 }
163
164
165
166
167
168
169
170 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
171 final BracketedSingleOptimizer mseOptimizer) {
172 super();
173 initializeOptimizerListeners();
174 try {
175 setMseOptimizer(mseOptimizer);
176 } catch (final LockedException ignore) {
177
178 }
179 }
180
181
182
183
184
185
186
187
188 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
189 final AccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource,
190 final BracketedSingleOptimizer mseOptimizer) {
191 super(dataSource);
192 initializeOptimizerListeners();
193 try {
194 setMseOptimizer(mseOptimizer);
195 } catch (final LockedException ignore) {
196
197 }
198 }
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
220 final AccelerometerNonLinearCalibrator accelerometerCalibrator,
221 final GyroscopeNonLinearCalibrator gyroscopeCalibrator,
222 final MagnetometerNonLinearCalibrator magnetometerCalibrator,
223 final BracketedSingleOptimizer mseOptimizer) {
224 super(accelerometerCalibrator, gyroscopeCalibrator, magnetometerCalibrator);
225 initializeOptimizerListeners();
226 try {
227 setMseOptimizer(mseOptimizer);
228 } catch (final LockedException ignore) {
229
230 }
231 }
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253 public BracketedAccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizer(
254 final AccelerometerGyroscopeAndMagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource,
255 final AccelerometerNonLinearCalibrator accelerometerCalibrator,
256 final GyroscopeNonLinearCalibrator gyroscopeCalibrator,
257 final MagnetometerNonLinearCalibrator magnetometerCalibrator,
258 final BracketedSingleOptimizer mseOptimizer) {
259 super(dataSource, accelerometerCalibrator, gyroscopeCalibrator, magnetometerCalibrator);
260 initializeOptimizerListeners();
261 try {
262 setMseOptimizer(mseOptimizer);
263 } catch (final LockedException ignore) {
264
265 }
266 }
267
268
269
270
271
272
273
274
275 public BracketedSingleOptimizer getMseOptimizer() {
276 return mseOptimizer;
277 }
278
279
280
281
282
283
284
285
286
287 public void setMseOptimizer(final BracketedSingleOptimizer optimizer)
288 throws LockedException {
289 if (running) {
290 throw new LockedException();
291 }
292
293 try {
294 if (optimizer != null) {
295 optimizer.setBracket(minThresholdFactor, minThresholdFactor, maxThresholdFactor);
296 optimizer.setListener(optimizerListener);
297 optimizer.setOnIterationCompletedListener(iterationCompletedListener);
298 }
299 mseOptimizer = optimizer;
300 } catch (final com.irurueta.numerical.LockedException e) {
301 throw new LockedException(e);
302 } catch (final InvalidBracketRangeException ignore) {
303
304 }
305 }
306
307
308
309
310
311
312 @Override
313 public boolean isReady() {
314 return super.isReady() && mseOptimizer != null;
315 }
316
317
318
319
320
321
322
323
324
325
326
327
328 @Override
329 public double optimize() throws NotReadyException, LockedException,
330 IntervalDetectorThresholdFactorOptimizerException {
331 if (running) {
332 throw new LockedException();
333 }
334
335 if (!isReady()) {
336 throw new NotReadyException();
337 }
338
339 try {
340 running = true;
341
342 initProgress();
343
344 if (listener != null) {
345 listener.onOptimizeStart(this);
346 }
347
348 minMse = Double.MAX_VALUE;
349 mseOptimizer.minimize();
350
351 if (listener != null) {
352 listener.onOptimizeEnd(this);
353 }
354
355 return optimalThresholdFactor;
356 } catch (final NumericalException e) {
357 throw new IntervalDetectorThresholdFactorOptimizerException(e);
358 } finally {
359 running = false;
360 }
361 }
362
363
364
365
366 private void initializeOptimizerListeners() {
367 optimizerListener = point -> {
368 try {
369 return evaluateForThresholdFactor(point);
370 } catch (final NavigationException e) {
371 throw new EvaluationException(e);
372 }
373 };
374
375 iterationCompletedListener = (optimizer, iteration, maxIterations) -> {
376 if (maxIterations == null) {
377 return;
378 }
379
380 progress = (float) iteration / (float) maxIterations;
381 checkAndNotifyProgress();
382 };
383 }
384 }