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.StandardDeviationBodyMagneticFluxDensity;
22 import com.irurueta.navigation.inertial.calibration.magnetometer.MagnetometerCalibratorMeasurementType;
23 import com.irurueta.navigation.inertial.calibration.magnetometer.MagnetometerNonLinearCalibrator;
24 import com.irurueta.numerical.EvaluationException;
25 import com.irurueta.numerical.InvalidBracketRangeException;
26 import com.irurueta.numerical.NumericalException;
27 import com.irurueta.numerical.SingleDimensionFunctionEvaluatorListener;
28 import com.irurueta.numerical.optimization.BracketedSingleOptimizer;
29 import com.irurueta.numerical.optimization.BrentSingleOptimizer;
30 import com.irurueta.numerical.optimization.OnIterationCompletedListener;
31
32
33
34
35
36
37
38
39
40
41 public class BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer extends
42 MagnetometerIntervalDetectorThresholdFactorOptimizer {
43
44
45
46
47
48 private BracketedSingleOptimizer mseOptimizer;
49
50
51
52
53 private SingleDimensionFunctionEvaluatorListener optimizerListener;
54
55
56
57
58 private OnIterationCompletedListener iterationCompletedListener;
59
60
61
62
63 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer() {
64 super();
65 initializeOptimizerListeners();
66 try {
67 setMseOptimizer(new BrentSingleOptimizer());
68 } catch (final LockedException ignore) {
69
70 }
71 }
72
73
74
75
76
77
78 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(
79 final MagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource) {
80 super(dataSource);
81 initializeOptimizerListeners();
82 try {
83 setMseOptimizer(new BrentSingleOptimizer());
84 } catch (final LockedException ignore) {
85
86 }
87 }
88
89
90
91
92
93
94
95
96
97 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(
98 final MagnetometerNonLinearCalibrator calibrator) {
99 super(calibrator);
100 initializeOptimizerListeners();
101 try {
102 setMseOptimizer(new BrentSingleOptimizer());
103 } catch (final LockedException ignore) {
104
105 }
106 }
107
108
109
110
111
112
113
114
115
116
117 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(
118 final MagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource,
119 final MagnetometerNonLinearCalibrator calibrator) {
120 super(dataSource, calibrator);
121 initializeOptimizerListeners();
122 try {
123 setMseOptimizer(new BrentSingleOptimizer());
124 } catch (final LockedException ignore) {
125
126 }
127 }
128
129
130
131
132
133
134
135 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(final BracketedSingleOptimizer mseOptimizer) {
136 initializeOptimizerListeners();
137 try {
138 setMseOptimizer(mseOptimizer);
139 } catch (final LockedException ignore) {
140
141 }
142 }
143
144
145
146
147
148
149
150
151 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(
152 final MagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource,
153 final BracketedSingleOptimizer mseOptimizer) {
154 super(dataSource);
155 initializeOptimizerListeners();
156 try {
157 setMseOptimizer(mseOptimizer);
158 } catch (final LockedException ignore) {
159
160 }
161 }
162
163
164
165
166
167
168
169
170
171
172
173 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(
174 final MagnetometerNonLinearCalibrator calibrator,
175 final BracketedSingleOptimizer mseOptimizer) {
176 super(calibrator);
177 initializeOptimizerListeners();
178 try {
179 setMseOptimizer(mseOptimizer);
180 } catch (final LockedException ignore) {
181
182 }
183 }
184
185
186
187
188
189
190
191
192
193
194
195
196 public BracketedMagnetometerIntervalDetectorThresholdFactorOptimizer(
197 final MagnetometerIntervalDetectorThresholdFactorOptimizerDataSource dataSource,
198 final MagnetometerNonLinearCalibrator calibrator,
199 final BracketedSingleOptimizer mseOptimizer) {
200 super(dataSource, calibrator);
201 initializeOptimizerListeners();
202 try {
203 setMseOptimizer(mseOptimizer);
204 } catch (final LockedException ignore) {
205
206 }
207 }
208
209
210
211
212
213
214
215
216 public BracketedSingleOptimizer getMseOptimizer() {
217 return mseOptimizer;
218 }
219
220
221
222
223
224
225
226
227
228 public void setMseOptimizer(final BracketedSingleOptimizer optimizer) throws LockedException {
229 if (running) {
230 throw new LockedException();
231 }
232
233 try {
234 if (optimizer != null) {
235 optimizer.setBracket(minThresholdFactor, minThresholdFactor, maxThresholdFactor);
236 optimizer.setListener(optimizerListener);
237 optimizer.setOnIterationCompletedListener(iterationCompletedListener);
238 }
239 mseOptimizer = optimizer;
240 } catch (final com.irurueta.numerical.LockedException e) {
241 throw new LockedException(e);
242 } catch (final InvalidBracketRangeException ignore) {
243
244 }
245 }
246
247
248
249
250
251
252 @Override
253 public boolean isReady() {
254 return super.isReady() && mseOptimizer != null;
255 }
256
257
258
259
260
261
262
263
264
265
266
267
268 @Override
269 public double optimize() throws NotReadyException, LockedException,
270 IntervalDetectorThresholdFactorOptimizerException {
271 if (running) {
272 throw new LockedException();
273 }
274
275 if (!isReady()) {
276 throw new NotReadyException();
277 }
278
279 try {
280 running = true;
281
282 initProgress();
283
284 if (listener != null) {
285 listener.onOptimizeStart(this);
286 }
287
288 minMse = Double.MAX_VALUE;
289 mseOptimizer.minimize();
290
291 if (listener != null) {
292 listener.onOptimizeEnd(this);
293 }
294
295 return optimalThresholdFactor;
296 } catch (final NumericalException e) {
297 throw new IntervalDetectorThresholdFactorOptimizerException(e);
298 } finally {
299 running = false;
300 }
301 }
302
303
304
305
306 private void initializeOptimizerListeners() {
307 optimizerListener = point -> {
308 try {
309 return evaluateForThresholdFactor(point);
310 } catch (NavigationException e) {
311 throw new EvaluationException(e);
312 }
313 };
314
315 iterationCompletedListener = (optimizer, iteration, maxIterations) -> {
316 if (maxIterations == null) {
317 return;
318 }
319
320 progress = (float) iteration / (float) maxIterations;
321 checkAndNotifyProgress();
322 };
323 }
324 }