Class BaseMagneticFluxDensityNormMagnetometerCalibrator<C extends BaseMagneticFluxDensityNormMagnetometerCalibrator<?,?>,L extends BaseMagneticFluxDensityNormMagnetometerCalibratorListener<C>>
java.lang.Object
com.irurueta.navigation.inertial.calibration.magnetometer.BaseMagneticFluxDensityNormMagnetometerCalibrator<C,L>
- Type Parameters:
C
- Calibrator type.L
- Listener type.
- All Implemented Interfaces:
MagnetometerCalibrator
,MagnetometerNonLinearCalibrator
,UnknownHardIronMagnetometerCalibrator
,UnknownHardIronNonLinearMagnetometerCalibrator
,UnorderedStandardDeviationBodyMagneticFluxDensityMagnetometerCalibrator
- Direct Known Subclasses:
KnownMagneticFluxDensityNormMagnetometerCalibrator
,KnownPositionAndInstantMagnetometerCalibrator
public abstract class BaseMagneticFluxDensityNormMagnetometerCalibrator<C extends BaseMagneticFluxDensityNormMagnetometerCalibrator<?,?>,L extends BaseMagneticFluxDensityNormMagnetometerCalibratorListener<C>>
extends Object
implements MagnetometerNonLinearCalibrator, UnknownHardIronNonLinearMagnetometerCalibrator, UnorderedStandardDeviationBodyMagneticFluxDensityMagnetometerCalibrator
Abstract class to estimate magnetometer hard-iron biases, cross couplings and scaling factors.
This calibrator uses Levenberg-Marquardt to find a minimum least squared
error solution.
To use this calibrator at least 10 measurements taken at a single unknown position and unknown orientations when common z-axis is assumed, otherwise at least 13 measurements are required.
Measured magnetic flux density is assumed to follow the model shown below:
mBmeas = bm + (I + Mm) * mBtrue + wWhere: - mBmeas is the measured magnetic flux density. This is a 3x1 vector. - bm is magnetometer hard-iron bias. Ideally, on a perfect magnetometer, this should be a 3x1 zero vector. - I is the 3x3 identity matrix. - Mm is the 3x3 soft-iron matrix containing cross-couplings and scaling factors. Ideally, on a perfect magnetometer, this should be a 3x3 zero matrix. - mBtrue is ground-truth magnetic flux density. This is a 3x1 vector. - w is measurement noise. This is a 3x1 vector. Notice that this calibrator assumes that all measurements are taken in a short span of time, where Earth magnetic field can be assumed to be constant.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate com.irurueta.algebra.Matrix
Internally holds biases during calibration.private com.irurueta.algebra.Matrix
Internally holds measured magnetic flux density during calibration expressed as a column matrix.private double
Internally holds x-coordinate of measured magnetic flux density during calibration.private double
Internally holds y-coordinate of measured magnetic flux density during calibration.private double
Internally holds z-coordinate of measured magnetic flux density during calibration.private com.irurueta.algebra.Matrix
Internally holds computed true magnetic flux density during calibration.private static final int
Number of unknowns when common z-axis is assumed for the accelerometer, gyroscope and magnetometer.private boolean
This flag indicates whether z-axis is assumed to be common for accelerometer, gyroscope and magnetometer.static final boolean
Indicates whether by default a common z-axis is assumed for the accelerometer, gyroscope and magnetometer.private double
Estimated chi square value.private com.irurueta.algebra.Matrix
Estimated covariance matrix for estimated parameters.private double[]
Estimated magnetometer hard-iron biases for each magnetometer axis expressed in Teslas (T).private com.irurueta.algebra.Matrix
Estimated magnetometer soft-iron matrix containing scale factors and cross coupling errors.private double
Estimated mean square error respect to provided measurements.private final com.irurueta.numerical.fitting.LevenbergMarquardtMultiDimensionFitter
Levenberg-Marquardt fitter to find a non-linear solution.private static final int
Number of unknowns for the general case.protected Double
Ground truth magnetic flux density norm to be expected at location where measurements have been made, expressed in Teslas (T).private double
Initial x-coordinate of hard-iron bias to be used to find a solution.private double
Initial y-coordinate of hard-iron bias to be used to find a solution.private double
Initial z-coordinate of hard-iron bias to be used to find a solution.private double
Initial x-y cross coupling error.private double
Initial x-z cross coupling error.private double
Initial y-x cross coupling error.private double
Initial y-z cross coupling error.private double
Initial z-x cross coupling error.private double
Initial z-y cross coupling error.private double
Initial x scaling factor.private double
Initial y scaling factor.private double
Initial z scaling factor.private com.irurueta.algebra.Matrix
Internally holds inverse of cross-coupling errors during calibration.private L
Listener to handle events raised by this calibrator.private com.irurueta.algebra.Matrix
Internally holds cross-coupling errors during calibration.Contains a collection of body magnetic flux density measurements taken at a given position with different unknown orientations and containing the standard deviation of magnetometer measurements.static final int
Required minimum number of measurements when common z-axis is assumed.static final int
Required minimum number of measurements for the general case.private boolean
Indicates whether calibrator is running. -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(boolean commonAxisUsed) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(double[] initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(com.irurueta.algebra.Matrix initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, boolean commonAxisUsed) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, double[] initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, com.irurueta.algebra.Matrix initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Double groundTruthMagneticFluxDensityNorm, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.protected
BaseMagneticFluxDensityNormMagnetometerCalibrator
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, L listener) Constructor.protected
Constructor. -
Method Summary
Modifier and TypeMethodDescriptionvoid
Estimates magnetometer calibration parameters containing scale factors and cross-coupling errors.private void
Internal method to perform calibration when common z-axis is assumed for both the accelerometer and gyroscope.private void
Internal method to perform general calibration.private static double
convertMagneticFluxDensity
(double value, com.irurueta.units.MagneticFluxDensityUnit unit) Converts magnetic flux density value and unit to Teslas.private static double
convertMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity magneticFluxDensity) Converts magnetic flux density instance to Teslas.private double
evaluate
(double bx, double by, double bz, double m11, double m21, double m31, double m12, double m22, double m32, double m13, double m23, double m33) Computes estimated true magnetic flux density squared norm using current measured body magnetic flux density and provided parameters.private double
evaluateCommonAxis
(double[] params) Computes estimated true magnetic flux density squared norm using current measured body magnetic flux density and provided parameters when common z-axis is assumed.private double
evaluateGeneral
(double[] params) Computes estimated true magnetic flux density squared norm using current measured body magnetic flux density and provided parameters for the general case.double
Gets estimated chi square value.com.irurueta.algebra.Matrix
Gets estimated covariance matrix for estimated calibration parameters.double[]
Gets array containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).boolean
getEstimatedHardIron
(double[] result) Gets array containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).com.irurueta.algebra.Matrix
Gets column matrix containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).boolean
getEstimatedHardIronAsMatrix
(com.irurueta.algebra.Matrix result) Gets column matrix containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).Gets estimated magnetometer bias.boolean
Gets estimated magnetometer bias.Gets standard deviation of estimated magnetometer bias coordinates.boolean
Gets standard deviation of estimated magnetometer bias coordinates.Gets average of estimated standard deviation of magnetometer bias coordinates expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets average of estimated standard deviation of magnetometer bias coordinates.boolean
getEstimatedHardIronStandardDeviationAverageAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets average of estimated standard deviation of magnetometer bias coordinates.Gets norm of estimated standard deviation of magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets norm of estimated standard deviation of magnetometer bias.boolean
getEstimatedHardIronStandardDeviationNormAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets norm of estimated standard deviation of magnetometer bias.Gets x coordinate of estimated magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets x coordinate of estimated magnetometer bias.boolean
getEstimatedHardIronXAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets x coordinate of estimated magnetometer bias.Gets standard deviation of estimated x coordinate of magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets standard deviation of estimated x coordinate of magnetometer bias.boolean
getEstimatedHardIronXStandardDeviationAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets standard deviation of estimated x coordinate of magnetometer bias.Gets variance of estimated x coordinate of magnetometer bias expressed in squared Teslas (T^2).Gets y coordinate of estimated magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets y coordinate of estimated magnetometer bias.boolean
getEstimatedHardIronYAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets y coordinate of estimated magnetometer bias.Gets standard deviation of estimated y coordinate of magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets standard deviation of estimated y coordinate of magnetometer bias.boolean
getEstimatedHardIronYStandardDeviationAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets standard deviation of estimated y coordinate of magnetometer bias.Gets variance of estimated y coordinate of magnetometer bias expressed in squared Teslas (T^2).Gets z coordinate of estimated magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets z coordinate of estimated magnetometer bias.boolean
getEstimatedHardIronZAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets z coordinate of estimated magnetometer bias.Gets standard deviation of estimated z coordinate of magnetometer bias expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets standard deviation of estimated z coordinate of magnetometer bias.boolean
getEstimatedHardIronZStandardDeviationAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets standard deviation of estimated z coordinate of magnetometer bias.Gets variance of estimated z coordinate of magnetometer bias expressed in squared Teslas (T^2).com.irurueta.algebra.Matrix
Gets estimated magnetometer soft-iron matrix containing scale factors and cross coupling errors.double
Gets estimated mean square error respect to provided measurements.Gets estimated x-y cross-coupling error.Gets estimated x-z cross-coupling error.Gets estimated y-x cross-coupling error.Gets estimated y-z cross-coupling error.Gets estimated z-x cross-coupling error.Gets estimated z-y cross-coupling error.Gets estimated x-axis scale factor.Gets estimated y-axis scale factor.Gets estimated z-axis scale factor.Gets ground truth magnetic flux density norm to be expected at location where measurements have been made, expressed in Teslas (T).com.irurueta.units.MagneticFluxDensity
Gets ground truth magnetic flux density norm to be expected at location where measurements have been made.boolean
getGroundTruthMagneticFluxDensityNormAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets ground truth magnetic flux density norm to be expected at location where measurements have been made.double[]
Gets initial hard-iron bias to be used to find a solution as an array.void
getInitialHardIron
(double[] result) Gets initial hard-iron bias to be used to find a solution as an array.com.irurueta.algebra.Matrix
Gets initial hard-iron bias to be used to find a solution as a column matrix.void
getInitialHardIronAsMatrix
(com.irurueta.algebra.Matrix result) Gets initial hard-iron bias to be used to find a solution as a column matrix.Gets initial hard-iron used to find a solution.void
Gets initial hard-iron used to find a solution.double
Gets initial x-coordinate of magnetometer hard-iron bias to be used to find a solution.com.irurueta.units.MagneticFluxDensity
Gets initial x-coordinate of magnetometer hard iron bias to be used to find a solution.void
getInitialHardIronXAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets initial x-coordinate of magnetometer hard iron bias to be used to find a solution.double
Gets initial y-coordinate of magnetometer hard-iron bias to be used to find a solution.com.irurueta.units.MagneticFluxDensity
Gets initial y-coordinate of magnetometer hard iron bias to be used to find a solution.void
getInitialHardIronYAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets initial y-coordinate of magnetometer hard iron bias to be used to find a solution.double
Gets initial z-coordinate of magnetometer hard-iron bias to be used to find a solution.com.irurueta.units.MagneticFluxDensity
Gets initial z-coordinate of magnetometer hard iron bias to be used to find a solution.void
getInitialHardIronZAsMagneticFluxDensity
(com.irurueta.units.MagneticFluxDensity result) Gets initial z-coordinate of magnetometer hard iron bias to be used to find a solution.com.irurueta.algebra.Matrix
Gets initial scale factors and cross coupling errors matrix.void
getInitialMm
(com.irurueta.algebra.Matrix result) Gets initial scale factors and cross coupling errors matrix.double
Gets initial x-y cross coupling error.double
Gets initial x-z cross coupling error.double
Gets initial y-x cross coupling error.double
Gets initial y-z cross coupling error.double
Gets initial z-x cross coupling error.double
Gets initial z-y cross coupling error.double
Gets initial x scaling factor.double
Gets initial y scaling factor.double
Gets initial z scaling factor.Gets listener to handle events raised by this calibrator.Gets collection of body magnetic flux density measurements taken at a given position with different unknown orientations and containing the standard deviation of magnetometer measurements.Indicates the type of measurement used by this calibrator.int
Gets minimum number of required measurements.protected void
internalSetGroundTruthMagneticFluxDensityNorm
(Double groundTruthMagneticFluxDensityNorm) Internally sets ground truth magnetic flux density norm to be expected at location where measurements have been made, expressed in Teslas (T).boolean
Indicates whether z-axis is assumed to be common for accelerometer, gyroscope and magnetometer.boolean
Indicates whether this calibrator requires ordered measurements in a list or not.boolean
Indicates whether this calibrator requires quality scores for each measurement or not.boolean
isReady()
Indicates whether calibrator is ready to start.boolean
Indicates whether calibrator is currently running or not.protected void
Called before calibration occurs.void
setCommonAxisUsed
(boolean commonAxisUsed) Specifies whether z-axis is assumed to be common for accelerometer and gyroscope.void
setInitialCrossCouplingErrors
(double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Sets initial cross coupling errors.void
setInitialHardIron
(double[] initialHardIron) Sets initial hard-iron bias to be used to find a solution as an array.void
setInitialHardIron
(double initialHardIronX, double initialHardIronY, double initialHardIronZ) Sets initial hard-iron bias coordinates of magnetometer used to find a solution expressed in Teslas (T).void
setInitialHardIron
(com.irurueta.algebra.Matrix initialHardIron) Sets initial hard-iron bias to be used to find a solution as a column matrix with values expressed in Teslas (T).void
setInitialHardIron
(MagneticFluxDensityTriad initialHardIron) Sets initial hard-iron used to find a solution.void
setInitialHardIron
(com.irurueta.units.MagneticFluxDensity initialHardIronX, com.irurueta.units.MagneticFluxDensity initialHardIronY, com.irurueta.units.MagneticFluxDensity initialHardIronZ) Sets initial hard iron coordinates of magnetometer used to find a solution.void
setInitialHardIronX
(double initialHardIronX) Sets initial x-coordinate of magnetometer hard-iron bias to be used to find a solution.void
setInitialHardIronX
(com.irurueta.units.MagneticFluxDensity initialHardIronX) Sets initial x-coordinate of magnetometer hard iron bias to be used to find a solution.void
setInitialHardIronY
(double initialHardIronY) Sets initial y-coordinate of magnetometer hard-iron bias to be used to find a solution.void
setInitialHardIronY
(com.irurueta.units.MagneticFluxDensity initialHardIronY) Sets initial y-coordinate of magnetometer hard iron bias to be used to find a solution.void
setInitialHardIronZ
(double initialHardIronZ) Sets initial z-coordinate of magnetometer hard-iron bias to be used to find a solution.void
setInitialHardIronZ
(com.irurueta.units.MagneticFluxDensity initialHardIronZ) Sets initial z-coordinate of magnetometer hard iron bias to be used to find a solution.void
setInitialMm
(com.irurueta.algebra.Matrix initialMm) Sets initial scale factors and cross coupling errors matrix.void
setInitialMxy
(double initialMxy) Sets initial x-y cross coupling error.void
setInitialMxz
(double initialMxz) Sets initial x-z cross coupling error.void
setInitialMyx
(double initialMyx) Sets initial y-x cross coupling error.void
setInitialMyz
(double initialMyz) Sets initial y-z cross coupling error.void
setInitialMzx
(double initialMzx) Sets initial z-x cross coupling error.void
setInitialMzy
(double initialMzy) Sets initial z-y cross coupling error.void
setInitialScalingFactors
(double initialSx, double initialSy, double initialSz) Sets initial scaling factors.void
setInitialScalingFactorsAndCrossCouplingErrors
(double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Sets initial scaling factors and cross coupling errors.void
setInitialSx
(double initialSx) Sets initial x scaling factor.void
setInitialSy
(double initialSy) Sets initial y scaling factor.void
setInitialSz
(double initialSz) Sets initial z scaling factor.protected void
Sets input data into Levenberg-Marquardt fitter.void
setListener
(L listener) Sets listener to handle events raised by this calibrator.void
setMeasurements
(Collection<StandardDeviationBodyMagneticFluxDensity> measurements) Sets collection of body magnetic flux density measurements taken at a given position with different unknown orientations and containing the standard deviation of magnetometer measurements.private void
setResult
(com.irurueta.algebra.Matrix m, com.irurueta.algebra.Matrix b) Makes proper conversion of internal cross-coupling and bias matrices.
-
Field Details
-
DEFAULT_USE_COMMON_Z_AXIS
public static final boolean DEFAULT_USE_COMMON_Z_AXISIndicates whether by default a common z-axis is assumed for the accelerometer, gyroscope and magnetometer.- See Also:
-
COMMON_Z_AXIS_UNKNOWNS
private static final int COMMON_Z_AXIS_UNKNOWNSNumber of unknowns when common z-axis is assumed for the accelerometer, gyroscope and magnetometer.- See Also:
-
GENERAL_UNKNOWNS
private static final int GENERAL_UNKNOWNSNumber of unknowns for the general case.- See Also:
-
MINIMUM_MEASUREMENTS_COMMON_Z_AXIS
public static final int MINIMUM_MEASUREMENTS_COMMON_Z_AXISRequired minimum number of measurements when common z-axis is assumed.- See Also:
-
MINIMUM_MEASUREMENTS_GENERAL
public static final int MINIMUM_MEASUREMENTS_GENERALRequired minimum number of measurements for the general case.- See Also:
-
groundTruthMagneticFluxDensityNorm
Ground truth magnetic flux density norm to be expected at location where measurements have been made, expressed in Teslas (T). -
fitter
private final com.irurueta.numerical.fitting.LevenbergMarquardtMultiDimensionFitter fitterLevenberg-Marquardt fitter to find a non-linear solution. -
initialHardIronX
private double initialHardIronXInitial x-coordinate of hard-iron bias to be used to find a solution. This is expressed in Teslas (T). -
initialHardIronY
private double initialHardIronYInitial y-coordinate of hard-iron bias to be used to find a solution. This is expressed in Teslas (T). -
initialHardIronZ
private double initialHardIronZInitial z-coordinate of hard-iron bias to be used to find a solution. This is expressed in Teslas (T). -
initialSx
private double initialSxInitial x scaling factor. -
initialSy
private double initialSyInitial y scaling factor. -
initialSz
private double initialSzInitial z scaling factor. -
initialMxy
private double initialMxyInitial x-y cross coupling error. -
initialMxz
private double initialMxzInitial x-z cross coupling error. -
initialMyx
private double initialMyxInitial y-x cross coupling error. -
initialMyz
private double initialMyzInitial y-z cross coupling error. -
initialMzx
private double initialMzxInitial z-x cross coupling error. -
initialMzy
private double initialMzyInitial z-y cross coupling error. -
measurements
Contains a collection of body magnetic flux density measurements taken at a given position with different unknown orientations and containing the standard deviation of magnetometer measurements. -
commonAxisUsed
private boolean commonAxisUsedThis flag indicates whether z-axis is assumed to be common for accelerometer, gyroscope and magnetometer. When enabled, this eliminates 3 variables from Mm matrix. -
listener
Listener to handle events raised by this calibrator. -
estimatedHardIron
private double[] estimatedHardIronEstimated magnetometer hard-iron biases for each magnetometer axis expressed in Teslas (T). -
estimatedMm
private com.irurueta.algebra.Matrix estimatedMmEstimated magnetometer soft-iron matrix containing scale factors and cross coupling errors. This is the product of matrix Tm containing cross coupling errors and Km containing scaling factors. So tat:Mm = [sx mxy mxz] = Tm*Km [myx sy myz] [mzx mzy sz ]
Where:Km = [sx 0 0 ] [0 sy 0 ] [0 0 sz]
andTm = [1 -alphaXy alphaXz ] [alphaYx 1 -alphaYz] [-alphaZx alphaZy 1 ]
Hence:Mm = [sx mxy mxz] = Tm*Km = [sx -sy * alphaXy sz * alphaXz ] [myx sy myz] [sx * alphaYx sy -sz * alphaYz] [mzx mzy sz ] [-sx * alphaZx sy * alphaZy sz ]
This instance allows any 3x3 matrix however, typically alphaYx, alphaZx and alphaZy are considered to be zero if the accelerometer z-axis is assumed to be the same as the body z-axis. When this is assumed, myx = mzx = mzy = 0 and the Mm matrix becomes upper diagonal:Mm = [sx mxy mxz] [0 sy myz] [0 0 sz ]
Values of this matrix are unit-less. -
estimatedCovariance
private com.irurueta.algebra.Matrix estimatedCovarianceEstimated covariance matrix for estimated parameters. -
estimatedChiSq
private double estimatedChiSqEstimated chi square value. -
estimatedMse
private double estimatedMseEstimated mean square error respect to provided measurements. -
running
private boolean runningIndicates whether calibrator is running. -
bmeasX
private double bmeasXInternally holds x-coordinate of measured magnetic flux density during calibration. -
bmeasY
private double bmeasYInternally holds y-coordinate of measured magnetic flux density during calibration. -
bmeasZ
private double bmeasZInternally holds z-coordinate of measured magnetic flux density during calibration. -
bmeas
private com.irurueta.algebra.Matrix bmeasInternally holds measured magnetic flux density during calibration expressed as a column matrix. -
m
private com.irurueta.algebra.Matrix mInternally holds cross-coupling errors during calibration. -
invM
private com.irurueta.algebra.Matrix invMInternally holds inverse of cross-coupling errors during calibration. -
b
private com.irurueta.algebra.Matrix bInternally holds biases during calibration. -
btrue
private com.irurueta.algebra.Matrix btrueInternally holds computed true magnetic flux density during calibration.
-
-
Constructor Details
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator()Constructor. -
BaseMagneticFluxDensityNormMagnetometerCalibrator
Constructor.- Parameters:
listener
- listener to handle events raised by this calibrator.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(boolean commonAxisUsed) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(double[] initialHardIron) Constructor.- Parameters:
initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(com.irurueta.algebra.Matrix initialHardIron) Constructor.- Parameters:
initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.- Parameters:
initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.listener
- listener to handle events raised by this calibrator.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.listener
- listener to handle events raised by this calibrator.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.- Parameters:
measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, boolean commonAxisUsed) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, double[] initialHardIron) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, com.irurueta.algebra.Matrix initialHardIron) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, double[] initialHardIron, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, double[] initialHardIron, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron array does not have length 3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
BaseMagneticFluxDensityNormMagnetometerCalibrator
protected BaseMagneticFluxDensityNormMagnetometerCalibrator(Double groundTruthMagneticFluxDensityNorm, Collection<StandardDeviationBodyMagneticFluxDensity> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialHardIron, com.irurueta.algebra.Matrix initialMm, L listener) Constructor.- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm expressed in Teslas (T).measurements
- collection of body magnetic flux density measurements with standard deviation of magnetometer measurements taken at the same position with zero velocity and unknown different orientations.commonAxisUsed
- indicates whether z-axis is assumed to be common for the accelerometer, gyroscope and magnetometer.initialHardIron
- initial hard-iron to find a solution.initialMm
- initial soft-iron matrix containing scale factors and cross coupling errors.listener
- listener to handle events raised by this calibrator.- Throws:
IllegalArgumentException
- if provided magnetic flux norm value is negative, or if provided hard-iron matrix is not 3x1 or if soft-iron matrix is not 3x3.
-
-
Method Details
-
getGroundTruthMagneticFluxDensityNorm
Gets ground truth magnetic flux density norm to be expected at location where measurements have been made, expressed in Teslas (T).- Returns:
- ground truth magnetic flux density or null.
-
getGroundTruthMagneticFluxDensityNormAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getGroundTruthMagneticFluxDensityNormAsMagneticFluxDensity()Gets ground truth magnetic flux density norm to be expected at location where measurements have been made.- Returns:
- ground truth magnetic flux density or null.
-
getGroundTruthMagneticFluxDensityNormAsMagneticFluxDensity
public boolean getGroundTruthMagneticFluxDensityNormAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets ground truth magnetic flux density norm to be expected at location where measurements have been made.- Parameters:
result
- instance where result will be stored.- Returns:
- true if ground truth magnetic flux density norm has been defined, false if it is not available yet.
-
getInitialHardIronX
public double getInitialHardIronX()Gets initial x-coordinate of magnetometer hard-iron bias to be used to find a solution. This is expressed in Teslas (T).- Specified by:
getInitialHardIronX
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial x-coordinate of magnetometer hard-iron bias.
-
setInitialHardIronX
public void setInitialHardIronX(double initialHardIronX) throws com.irurueta.navigation.LockedException Sets initial x-coordinate of magnetometer hard-iron bias to be used to find a solution. This is expressed in Teslas (T).- Specified by:
setInitialHardIronX
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronX
- initial x-coordinate of magnetometer hard-iron bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIronY
public double getInitialHardIronY()Gets initial y-coordinate of magnetometer hard-iron bias to be used to find a solution. This is expressed in Teslas (T).- Specified by:
getInitialHardIronY
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial y-coordinate of magnetometer hard-iron bias.
-
setInitialHardIronY
public void setInitialHardIronY(double initialHardIronY) throws com.irurueta.navigation.LockedException Sets initial y-coordinate of magnetometer hard-iron bias to be used to find a solution. This is expressed in Teslas (T).- Specified by:
setInitialHardIronY
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronY
- initial y-coordinate of magnetometer hard-iron bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIronZ
public double getInitialHardIronZ()Gets initial z-coordinate of magnetometer hard-iron bias to be used to find a solution. This is expressed in Teslas (T).- Specified by:
getInitialHardIronZ
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial z-coordinate of magnetometer hard-iron bias.
-
setInitialHardIronZ
public void setInitialHardIronZ(double initialHardIronZ) throws com.irurueta.navigation.LockedException Sets initial z-coordinate of magnetometer hard-iron bias to be used to find a solution. This is expressed in meters Teslas (T).- Specified by:
setInitialHardIronZ
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronZ
- initial z-coordinate of magnetometer hard-iron bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIronXAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getInitialHardIronXAsMagneticFluxDensity()Gets initial x-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
getInitialHardIronXAsMagneticFluxDensity
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial x-coordinate of magnetometer hard-iron bias.
-
getInitialHardIronXAsMagneticFluxDensity
public void getInitialHardIronXAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets initial x-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
getInitialHardIronXAsMagneticFluxDensity
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
result
- instance where result will be stored.
-
setInitialHardIronX
public void setInitialHardIronX(com.irurueta.units.MagneticFluxDensity initialHardIronX) throws com.irurueta.navigation.LockedException Sets initial x-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
setInitialHardIronX
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronX
- initial x-coordinate of magnetometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIronYAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getInitialHardIronYAsMagneticFluxDensity()Gets initial y-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
getInitialHardIronYAsMagneticFluxDensity
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial y-coordinate of magnetometer hard-iron bias.
-
getInitialHardIronYAsMagneticFluxDensity
public void getInitialHardIronYAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets initial y-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
getInitialHardIronYAsMagneticFluxDensity
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
result
- instance where result will be stored.
-
setInitialHardIronY
public void setInitialHardIronY(com.irurueta.units.MagneticFluxDensity initialHardIronY) throws com.irurueta.navigation.LockedException Sets initial y-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
setInitialHardIronY
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronY
- initial y-coordinate of magnetometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIronZAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getInitialHardIronZAsMagneticFluxDensity()Gets initial z-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
getInitialHardIronZAsMagneticFluxDensity
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial z-coordinate of magnetometer hard-iron bias.
-
getInitialHardIronZAsMagneticFluxDensity
public void getInitialHardIronZAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets initial z-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
getInitialHardIronZAsMagneticFluxDensity
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
result
- instance where result will be stored.
-
setInitialHardIronZ
public void setInitialHardIronZ(com.irurueta.units.MagneticFluxDensity initialHardIronZ) throws com.irurueta.navigation.LockedException Sets initial z-coordinate of magnetometer hard iron bias to be used to find a solution.- Specified by:
setInitialHardIronZ
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronZ
- initial z-coordinate of magnetometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialHardIron
public void setInitialHardIron(double initialHardIronX, double initialHardIronY, double initialHardIronZ) throws com.irurueta.navigation.LockedException Sets initial hard-iron bias coordinates of magnetometer used to find a solution expressed in Teslas (T).- Specified by:
setInitialHardIron
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronX
- initial x-coordinate of magnetometer hard-iron bias.initialHardIronY
- initial y-coordinate of magnetometer hard-iron bias.initialHardIronZ
- initial z-coordinate of magnetometer hard-iron bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialHardIron
public void setInitialHardIron(com.irurueta.units.MagneticFluxDensity initialHardIronX, com.irurueta.units.MagneticFluxDensity initialHardIronY, com.irurueta.units.MagneticFluxDensity initialHardIronZ) throws com.irurueta.navigation.LockedException Sets initial hard iron coordinates of magnetometer used to find a solution.- Specified by:
setInitialHardIron
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIronX
- initial x-coordinate of magnetometer bias.initialHardIronY
- initial y-coordinate of magnetometer bias.initialHardIronZ
- initial z-coordinate of magnetometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIronAsTriad
Gets initial hard-iron used to find a solution.- Specified by:
getInitialHardIronAsTriad
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial hard-iron.
-
getInitialSx
public double getInitialSx()Gets initial x scaling factor.- Specified by:
getInitialSx
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial x scaling factor.
-
setInitialSx
public void setInitialSx(double initialSx) throws com.irurueta.navigation.LockedException Sets initial x scaling factor.- Specified by:
setInitialSx
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialSx
- initial x scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialSy
public double getInitialSy()Gets initial y scaling factor.- Specified by:
getInitialSy
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial y scaling factor.
-
setInitialSy
public void setInitialSy(double initialSy) throws com.irurueta.navigation.LockedException Sets initial y scaling factor.- Specified by:
setInitialSy
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialSy
- initial y scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialSz
public double getInitialSz()Gets initial z scaling factor.- Specified by:
getInitialSz
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial z scaling factor.
-
setInitialSz
public void setInitialSz(double initialSz) throws com.irurueta.navigation.LockedException Sets initial z scaling factor.- Specified by:
setInitialSz
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialSz
- initial z scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMxy
public double getInitialMxy()Gets initial x-y cross coupling error.- Specified by:
getInitialMxy
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial x-y cross coupling error.
-
setInitialMxy
public void setInitialMxy(double initialMxy) throws com.irurueta.navigation.LockedException Sets initial x-y cross coupling error.- Specified by:
setInitialMxy
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMxy
- initial x-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMxz
public double getInitialMxz()Gets initial x-z cross coupling error.- Specified by:
getInitialMxz
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial x-z cross coupling error.
-
setInitialMxz
public void setInitialMxz(double initialMxz) throws com.irurueta.navigation.LockedException Sets initial x-z cross coupling error.- Specified by:
setInitialMxz
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMxz
- initial x-z cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMyx
public double getInitialMyx()Gets initial y-x cross coupling error.- Specified by:
getInitialMyx
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial y-x cross coupling error.
-
setInitialMyx
public void setInitialMyx(double initialMyx) throws com.irurueta.navigation.LockedException Sets initial y-x cross coupling error.- Specified by:
setInitialMyx
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMyx
- initial y-x cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMyz
public double getInitialMyz()Gets initial y-z cross coupling error.- Specified by:
getInitialMyz
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial y-z cross coupling error.
-
setInitialMyz
public void setInitialMyz(double initialMyz) throws com.irurueta.navigation.LockedException Sets initial y-z cross coupling error.- Specified by:
setInitialMyz
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMyz
- initial y-z cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMzx
public double getInitialMzx()Gets initial z-x cross coupling error.- Specified by:
getInitialMzx
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial z-x cross coupling error.
-
setInitialMzx
public void setInitialMzx(double initialMzx) throws com.irurueta.navigation.LockedException Sets initial z-x cross coupling error.- Specified by:
setInitialMzx
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMzx
- initial z-x cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMzy
public double getInitialMzy()Gets initial z-y cross coupling error.- Specified by:
getInitialMzy
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial z-y cross coupling error.
-
setInitialMzy
public void setInitialMzy(double initialMzy) throws com.irurueta.navigation.LockedException Sets initial z-y cross coupling error.- Specified by:
setInitialMzy
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMzy
- initial z-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialScalingFactors
public void setInitialScalingFactors(double initialSx, double initialSy, double initialSz) throws com.irurueta.navigation.LockedException Sets initial scaling factors.- Specified by:
setInitialScalingFactors
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialCrossCouplingErrors
public void setInitialCrossCouplingErrors(double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) throws com.irurueta.navigation.LockedException Sets initial cross coupling errors.- Specified by:
setInitialCrossCouplingErrors
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMxy
- initial x-y cross coupling error.initialMxz
- initial x-z cross coupling error.initialMyx
- initial y-x cross coupling error.initialMyz
- initial y-z cross coupling error.initialMzx
- initial z-x cross coupling error.initialMzy
- initial z-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialScalingFactorsAndCrossCouplingErrors
public void setInitialScalingFactorsAndCrossCouplingErrors(double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) throws com.irurueta.navigation.LockedException Sets initial scaling factors and cross coupling errors.- Specified by:
setInitialScalingFactorsAndCrossCouplingErrors
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.initialMxy
- initial x-y cross coupling error.initialMxz
- initial x-z cross coupling error.initialMyx
- initial y-x cross coupling error.initialMyz
- initial y-z cross coupling error.initialMzx
- initial z-x cross coupling error.initialMzy
- initial z-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialHardIron
public double[] getInitialHardIron()Gets initial hard-iron bias to be used to find a solution as an array. Array values are expressed in Teslas (T).- Specified by:
getInitialHardIron
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- array containing coordinates of initial bias.
-
getInitialHardIron
public void getInitialHardIron(double[] result) Gets initial hard-iron bias to be used to find a solution as an array. Array values are expressed in Teslas (T).- Specified by:
getInitialHardIron
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
result
- instance where result data will be copied to.- Throws:
IllegalArgumentException
- if provided array does not have length 3.
-
setInitialHardIron
public void setInitialHardIron(double[] initialHardIron) throws com.irurueta.navigation.LockedException Sets initial hard-iron bias to be used to find a solution as an array. Array values are expressed in Teslas (T).- Specified by:
setInitialHardIron
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIron
- initial hard-iron to find a solution.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided array does not have length 3.
-
getInitialHardIronAsMatrix
public com.irurueta.algebra.Matrix getInitialHardIronAsMatrix()Gets initial hard-iron bias to be used to find a solution as a column matrix. Values are expressed in Teslas (T).- Specified by:
getInitialHardIronAsMatrix
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Returns:
- initial hard-iron bias to be used to find a solution as a column matrix.
-
getInitialHardIronAsMatrix
public void getInitialHardIronAsMatrix(com.irurueta.algebra.Matrix result) Gets initial hard-iron bias to be used to find a solution as a column matrix. Values are expressed in Teslas (T).- Specified by:
getInitialHardIronAsMatrix
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
result
- instance where result data will be copied to.- Throws:
IllegalArgumentException
- if provided matrix is not 3x1.
-
setInitialHardIron
public void setInitialHardIron(com.irurueta.algebra.Matrix initialHardIron) throws com.irurueta.navigation.LockedException Sets initial hard-iron bias to be used to find a solution as a column matrix with values expressed in Teslas (T).- Specified by:
setInitialHardIron
in interfaceUnknownHardIronNonLinearMagnetometerCalibrator
- Parameters:
initialHardIron
- initial hard-iron bias to find a solution.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided matrix is not 3x1.
-
getInitialMm
public com.irurueta.algebra.Matrix getInitialMm()Gets initial scale factors and cross coupling errors matrix.- Specified by:
getInitialMm
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- initial scale factors and cross coupling errors matrix.
-
getInitialMm
public void getInitialMm(com.irurueta.algebra.Matrix result) Gets initial scale factors and cross coupling errors matrix.- Specified by:
getInitialMm
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
result
- instance where data will be stored.- Throws:
IllegalArgumentException
- if provided matrix is not 3x3.
-
setInitialMm
public void setInitialMm(com.irurueta.algebra.Matrix initialMm) throws com.irurueta.navigation.LockedException Sets initial scale factors and cross coupling errors matrix.- Specified by:
setInitialMm
in interfaceMagnetometerNonLinearCalibrator
- Parameters:
initialMm
- initial scale factors and cross coupling errors matrix.- Throws:
IllegalArgumentException
- if provided matrix is not 3x3.com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getMeasurements
Gets collection of body magnetic flux density measurements taken at a given position with different unknown orientations and containing the standard deviation of magnetometer measurements.- Specified by:
getMeasurements
in interfaceUnorderedStandardDeviationBodyMagneticFluxDensityMagnetometerCalibrator
- Returns:
- collection of body magnetic flux density measurements at a known position and timestamp with unknown orientations.
-
setMeasurements
public void setMeasurements(Collection<StandardDeviationBodyMagneticFluxDensity> measurements) throws com.irurueta.navigation.LockedException Sets collection of body magnetic flux density measurements taken at a given position with different unknown orientations and containing the standard deviation of magnetometer measurements.- Specified by:
setMeasurements
in interfaceUnorderedStandardDeviationBodyMagneticFluxDensityMagnetometerCalibrator
- Parameters:
measurements
- collection of body magnetic flux density measurements at a known position and timestamp with unknown orientations.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getMeasurementType
Indicates the type of measurement used by this calibrator.- Specified by:
getMeasurementType
in interfaceMagnetometerCalibrator
- Returns:
- type of measurement used by this calibrator.
-
isOrderedMeasurementsRequired
public boolean isOrderedMeasurementsRequired()Indicates whether this calibrator requires ordered measurements in a list or not.- Specified by:
isOrderedMeasurementsRequired
in interfaceMagnetometerCalibrator
- Returns:
- true if measurements must be ordered, false otherwise.
-
isQualityScoresRequired
public boolean isQualityScoresRequired()Indicates whether this calibrator requires quality scores for each measurement or not.- Specified by:
isQualityScoresRequired
in interfaceMagnetometerCalibrator
- Returns:
- true if quality scores are required, false otherwise.
-
isCommonAxisUsed
public boolean isCommonAxisUsed()Indicates whether z-axis is assumed to be common for accelerometer, gyroscope and magnetometer. When enabled, this eliminates 3 variables from Mm (soft-iron) matrix.- Specified by:
isCommonAxisUsed
in interfaceMagnetometerCalibrator
- Returns:
- true if z-axis is assumed to be common for accelerometer, gyroscope and magnetometer, false otherwise.
-
setCommonAxisUsed
public void setCommonAxisUsed(boolean commonAxisUsed) throws com.irurueta.navigation.LockedException Specifies whether z-axis is assumed to be common for accelerometer and gyroscope. When enabled, this eliminates 3 variables from Mm matrix.- Specified by:
setCommonAxisUsed
in interfaceMagnetometerCalibrator
- Parameters:
commonAxisUsed
- true if z-axis is assumed to be common for accelerometer, gyroscope and magnetometer, false otherwise.- Throws:
com.irurueta.navigation.LockedException
- if estimator is currently running.
-
getListener
Gets listener to handle events raised by this calibrator.- Returns:
- listener to handle events raised by this calibrator.
-
setListener
Sets listener to handle events raised by this calibrator.- Parameters:
listener
- listener to handle events raised by this calibrator.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getMinimumRequiredMeasurements
public int getMinimumRequiredMeasurements()Gets minimum number of required measurements.- Specified by:
getMinimumRequiredMeasurements
in interfaceMagnetometerCalibrator
- Returns:
- minimum number of required measurements.
-
isReady
public boolean isReady()Indicates whether calibrator is ready to start.- Specified by:
isReady
in interfaceMagnetometerCalibrator
- Returns:
- true if calibrator is ready, false otherwise.
-
isRunning
public boolean isRunning()Indicates whether calibrator is currently running or not.- Specified by:
isRunning
in interfaceMagnetometerCalibrator
- Returns:
- true if calibrator is running, false otherwise.
-
calibrate
public void calibrate() throws com.irurueta.navigation.LockedException, com.irurueta.navigation.NotReadyException, CalibrationExceptionEstimates magnetometer calibration parameters containing scale factors and cross-coupling errors.- Specified by:
calibrate
in interfaceMagnetometerCalibrator
- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.com.irurueta.navigation.NotReadyException
- if calibrator is not ready.CalibrationException
- if calibration fails for numerical reasons.
-
getEstimatedHardIron
public double[] getEstimatedHardIron()Gets array containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).- Specified by:
getEstimatedHardIron
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- array containing x,y,z components of estimated magnetometer hard-iron biases.
-
getEstimatedHardIron
public boolean getEstimatedHardIron(double[] result) Gets array containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).- Specified by:
getEstimatedHardIron
in interfaceUnknownHardIronMagnetometerCalibrator
- Parameters:
result
- instance where estimated magnetometer biases will be stored.- Returns:
- true if result instance was updated, false otherwise (when estimation is not yet available).
-
getEstimatedHardIronAsMatrix
public com.irurueta.algebra.Matrix getEstimatedHardIronAsMatrix()Gets column matrix containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).- Specified by:
getEstimatedHardIronAsMatrix
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- column matrix containing x,y,z components of estimated magnetometer hard-iron biases.
-
getEstimatedHardIronAsMatrix
public boolean getEstimatedHardIronAsMatrix(com.irurueta.algebra.Matrix result) throws com.irurueta.algebra.WrongSizeException Gets column matrix containing x,y,z components of estimated magnetometer hard-iron biases expressed in Teslas (T).- Specified by:
getEstimatedHardIronAsMatrix
in interfaceUnknownHardIronMagnetometerCalibrator
- Parameters:
result
- instance where result data will be stored.- Returns:
- true if result was updated, false otherwise.
- Throws:
com.irurueta.algebra.WrongSizeException
- if provided result instance has invalid size.
-
getEstimatedHardIronX
Gets x coordinate of estimated magnetometer bias expressed in Teslas (T).- Specified by:
getEstimatedHardIronX
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- x coordinate of estimated magnetometer bias or null if not available.
-
getEstimatedHardIronY
Gets y coordinate of estimated magnetometer bias expressed in Teslas (T).- Specified by:
getEstimatedHardIronY
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- y coordinate of estimated magnetometer bias or null if not available.
-
getEstimatedHardIronZ
Gets z coordinate of estimated magnetometer bias expressed in Teslas (T).- Specified by:
getEstimatedHardIronZ
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- z coordinate of estimated magnetometer bias or null if not available.
-
getEstimatedHardIronXAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronXAsMagneticFluxDensity()Gets x coordinate of estimated magnetometer bias.- Specified by:
getEstimatedHardIronXAsMagneticFluxDensity
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- x coordinate of estimated magnetometer bias.
-
getEstimatedHardIronXAsMagneticFluxDensity
public boolean getEstimatedHardIronXAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets x coordinate of estimated magnetometer bias.- Specified by:
getEstimatedHardIronXAsMagneticFluxDensity
in interfaceUnknownHardIronMagnetometerCalibrator
- Parameters:
result
- instance where result will be stored.- Returns:
- true if estimated magnetometer bias is available, false otherwise.
-
getEstimatedHardIronYAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronYAsMagneticFluxDensity()Gets y coordinate of estimated magnetometer bias.- Specified by:
getEstimatedHardIronYAsMagneticFluxDensity
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- y coordinate of estimated magnetometer bias.
-
getEstimatedHardIronYAsMagneticFluxDensity
public boolean getEstimatedHardIronYAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets y coordinate of estimated magnetometer bias.- Specified by:
getEstimatedHardIronYAsMagneticFluxDensity
in interfaceUnknownHardIronMagnetometerCalibrator
- Parameters:
result
- instance where result will be stored.- Returns:
- true if estimated magnetometer bias is available, false otherwise.
-
getEstimatedHardIronZAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronZAsMagneticFluxDensity()Gets z coordinate of estimated magnetometer bias.- Specified by:
getEstimatedHardIronZAsMagneticFluxDensity
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- z coordinate of estimated magnetometer bias.
-
getEstimatedHardIronZAsMagneticFluxDensity
public boolean getEstimatedHardIronZAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets z coordinate of estimated magnetometer bias.- Specified by:
getEstimatedHardIronZAsMagneticFluxDensity
in interfaceUnknownHardIronMagnetometerCalibrator
- Parameters:
result
- instance where result will be stored.- Returns:
- true if estimated magnetometer bias is available, false otherwise.
-
getEstimatedHardIronAsTriad
Gets estimated magnetometer bias.- Specified by:
getEstimatedHardIronAsTriad
in interfaceUnknownHardIronMagnetometerCalibrator
- Returns:
- estimated magnetometer bias or null if not available.
-
getEstimatedMm
public com.irurueta.algebra.Matrix getEstimatedMm()Gets estimated magnetometer soft-iron matrix containing scale factors and cross coupling errors. This is the product of matrix Tm containing cross coupling errors and Km containing scaling factors. So tat:Mm = [sx mxy mxz] = Tm*Km [myx sy myz] [mzx mzy sz ]
Where:Km = [sx 0 0 ] [0 sy 0 ] [0 0 sz]
andTm = [1 -alphaXy alphaXz ] [alphaYx 1 -alphaYz] [-alphaZx alphaZy 1 ]
Hence:Mm = [sx mxy mxz] = Tm*Km = [sx -sy * alphaXy sz * alphaXz ] [myx sy myz] [sx * alphaYx sy -sz * alphaYz] [mzx mzy sz ] [-sx * alphaZx sy * alphaZy sz ]
This instance allows any 3x3 matrix however, typically alphaYx, alphaZx and alphaZy are considered to be zero if the accelerometer z-axis is assumed to be the same as the body z-axis. When this is assumed, myx = mzx = mzy = 0 and the Mm matrix becomes upper diagonal:Mm = [sx mxy mxz] [0 sy myz] [0 0 sz ]
Values of this matrix are unit-less.- Specified by:
getEstimatedMm
in interfaceMagnetometerCalibrator
- Returns:
- estimated magnetometer soft-iron scale factors and cross coupling errors, or null if not available.
-
getEstimatedSx
Gets estimated x-axis scale factor.- Specified by:
getEstimatedSx
in interfaceMagnetometerCalibrator
- Returns:
- estimated x-axis scale factor or null if not available.
-
getEstimatedSy
Gets estimated y-axis scale factor.- Specified by:
getEstimatedSy
in interfaceMagnetometerCalibrator
- Returns:
- estimated y-axis scale factor or null if not available.
-
getEstimatedSz
Gets estimated z-axis scale factor.- Specified by:
getEstimatedSz
in interfaceMagnetometerCalibrator
- Returns:
- estimated z-axis scale factor or null if not available.
-
getEstimatedMxy
Gets estimated x-y cross-coupling error.- Specified by:
getEstimatedMxy
in interfaceMagnetometerCalibrator
- Returns:
- estimated x-y cross-coupling error or null if not available.
-
getEstimatedMxz
Gets estimated x-z cross-coupling error.- Specified by:
getEstimatedMxz
in interfaceMagnetometerCalibrator
- Returns:
- estimated x-z cross-coupling error or null if not available.
-
getEstimatedMyx
Gets estimated y-x cross-coupling error.- Specified by:
getEstimatedMyx
in interfaceMagnetometerCalibrator
- Returns:
- estimated y-x cross-coupling error or null if not available.
-
getEstimatedMyz
Gets estimated y-z cross-coupling error.- Specified by:
getEstimatedMyz
in interfaceMagnetometerCalibrator
- Returns:
- estimated y-z cross-coupling error or null if not available.
-
getEstimatedMzx
Gets estimated z-x cross-coupling error.- Specified by:
getEstimatedMzx
in interfaceMagnetometerCalibrator
- Returns:
- estimated z-x cross-coupling error or null if not available.
-
getEstimatedMzy
Gets estimated z-y cross-coupling error.- Specified by:
getEstimatedMzy
in interfaceMagnetometerCalibrator
- Returns:
- estimated z-y cross-coupling error or null if not available.
-
getEstimatedCovariance
public com.irurueta.algebra.Matrix getEstimatedCovariance()Gets estimated covariance matrix for estimated calibration parameters. Diagonal elements of the matrix contains variance for the following parameters (following indicated order): bx, by, bz, sx, sy, sz, mxy, mxz, myx, myz, mzx, mzy.- Specified by:
getEstimatedCovariance
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- estimated covariance matrix for estimated calibration parameters.
-
getEstimatedChiSq
public double getEstimatedChiSq()Gets estimated chi square value.- Specified by:
getEstimatedChiSq
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- estimated chi square value.
-
getEstimatedMse
public double getEstimatedMse()Gets estimated mean square error respect to provided measurements.- Specified by:
getEstimatedMse
in interfaceMagnetometerNonLinearCalibrator
- Returns:
- estimated mean square error respect to provided measurements.
-
getEstimatedHardIronXVariance
Gets variance of estimated x coordinate of magnetometer bias expressed in squared Teslas (T^2).- Returns:
- variance of estimated x coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronXStandardDeviation
Gets standard deviation of estimated x coordinate of magnetometer bias expressed in Teslas (T).- Returns:
- standard deviation of estimated x coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronXStandardDeviationAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronXStandardDeviationAsMagneticFluxDensity()Gets standard deviation of estimated x coordinate of magnetometer bias.- Returns:
- standard deviation of estimated x coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronXStandardDeviationAsMagneticFluxDensity
public boolean getEstimatedHardIronXStandardDeviationAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets standard deviation of estimated x coordinate of magnetometer bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if standard deviation of estimated x coordinate of magnetometer bias is available, false otherwise.
-
getEstimatedHardIronYVariance
Gets variance of estimated y coordinate of magnetometer bias expressed in squared Teslas (T^2).- Returns:
- variance of estimated y coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronYStandardDeviation
Gets standard deviation of estimated y coordinate of magnetometer bias expressed in Teslas (T).- Returns:
- standard deviation of estimated y coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronYStandardDeviationAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronYStandardDeviationAsMagneticFluxDensity()Gets standard deviation of estimated y coordinate of magnetometer bias.- Returns:
- standard deviation of estimated y coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronYStandardDeviationAsMagneticFluxDensity
public boolean getEstimatedHardIronYStandardDeviationAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets standard deviation of estimated y coordinate of magnetometer bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if standard deviation of estimated y coordinate of magnetometer bias is available, false otherwise.
-
getEstimatedHardIronZVariance
Gets variance of estimated z coordinate of magnetometer bias expressed in squared Teslas (T^2).- Returns:
- variance of estimated z coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronZStandardDeviation
Gets standard deviation of estimated z coordinate of magnetometer bias expressed in Teslas (T).- Returns:
- standard deviation of estimated z coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronZStandardDeviationAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronZStandardDeviationAsMagneticFluxDensity()Gets standard deviation of estimated z coordinate of magnetometer bias.- Returns:
- standard deviation of estimated z coordinate of magnetometer bias or null if not available.
-
getEstimatedHardIronZStandardDeviationAsMagneticFluxDensity
public boolean getEstimatedHardIronZStandardDeviationAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets standard deviation of estimated z coordinate of magnetometer bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if standard deviation of estimated z coordinate of magnetometer bias is available, false otherwise.
-
getEstimatedHardIronStandardDeviation
Gets standard deviation of estimated magnetometer bias coordinates.- Returns:
- standard deviation of estimated magnetometer bias coordinates.
-
getEstimatedHardIronStandardDeviationAverage
Gets average of estimated standard deviation of magnetometer bias coordinates expressed in Teslas (T).- Returns:
- average of estimated standard deviation of magnetometer bias coordinates, or null if not available.
-
getEstimatedHardIronStandardDeviationAverageAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronStandardDeviationAverageAsMagneticFluxDensity()Gets average of estimated standard deviation of magnetometer bias coordinates.- Returns:
- average of estimated standard deviation of magnetometer bias coordinates, or null if not available.
-
getEstimatedHardIronStandardDeviationAverageAsMagneticFluxDensity
public boolean getEstimatedHardIronStandardDeviationAverageAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets average of estimated standard deviation of magnetometer bias coordinates.- Parameters:
result
- instance where result will be stored.- Returns:
- true if average of estimated standard deviation of magnetometer bias is available, false otherwise.
-
getEstimatedHardIronStandardDeviationNorm
Gets norm of estimated standard deviation of magnetometer bias expressed in Teslas (T).- Returns:
- norm of estimated standard deviation of magnetometer bias or null if not available.
-
getEstimatedHardIronStandardDeviationNormAsMagneticFluxDensity
public com.irurueta.units.MagneticFluxDensity getEstimatedHardIronStandardDeviationNormAsMagneticFluxDensity()Gets norm of estimated standard deviation of magnetometer bias.- Returns:
- norm of estimated standard deviation of magnetometer bias or null if not available.
-
getEstimatedHardIronStandardDeviationNormAsMagneticFluxDensity
public boolean getEstimatedHardIronStandardDeviationNormAsMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity result) Gets norm of estimated standard deviation of magnetometer bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if norm of estimated standard deviation of magnetometer bias is available, false otherwise.
-
onBeforeCalibrate
Called before calibration occurs. This can be overridden by subclasses.- Throws:
CalibrationException
- if anything fails.
-
internalSetGroundTruthMagneticFluxDensityNorm
protected void internalSetGroundTruthMagneticFluxDensityNorm(Double groundTruthMagneticFluxDensityNorm) Internally sets ground truth magnetic flux density norm to be expected at location where measurements have been made, expressed in Teslas (T).- Parameters:
groundTruthMagneticFluxDensityNorm
- ground truth magnetic flux density norm or null if undefined.- Throws:
IllegalArgumentException
- if provided value is negative.
-
setInputData
protected void setInputData() throws com.irurueta.algebra.WrongSizeExceptionSets input data into Levenberg-Marquardt fitter.- Throws:
com.irurueta.algebra.WrongSizeException
- never happens.
-
calibrateGeneral
private void calibrateGeneral() throws com.irurueta.algebra.AlgebraException, com.irurueta.numerical.fitting.FittingException, com.irurueta.numerical.NotReadyExceptionInternal method to perform general calibration.- Throws:
com.irurueta.numerical.fitting.FittingException
- if Levenberg-Marquardt fails for numerical reasons.com.irurueta.algebra.AlgebraException
- if there are numerical instabilities that prevent matrix inversion.com.irurueta.numerical.NotReadyException
- never happens.
-
calibrateCommonAxis
private void calibrateCommonAxis() throws com.irurueta.algebra.AlgebraException, com.irurueta.numerical.fitting.FittingException, com.irurueta.numerical.NotReadyExceptionInternal method to perform calibration when common z-axis is assumed for both the accelerometer and gyroscope.- Throws:
com.irurueta.numerical.fitting.FittingException
- if Levenberg-Marquardt fails for numerical reasons.com.irurueta.algebra.AlgebraException
- if there are numerical instabilities that prevent matrix inversion.com.irurueta.numerical.NotReadyException
- never happens.
-
setResult
private void setResult(com.irurueta.algebra.Matrix m, com.irurueta.algebra.Matrix b) throws com.irurueta.algebra.AlgebraException Makes proper conversion of internal cross-coupling and bias matrices.- Parameters:
m
- internal cross-coupling matrix.b
- internal bias matrix.- Throws:
com.irurueta.algebra.AlgebraException
- if a numerical instability occurs.
-
evaluateGeneral
private double evaluateGeneral(double[] params) throws com.irurueta.numerical.EvaluationException Computes estimated true magnetic flux density squared norm using current measured body magnetic flux density and provided parameters for the general case. This method is internally executed during gradient estimation and Levenberg-Marquardt fitting needed for calibration computation.- Parameters:
params
- array containing current parameters for the general purpose case. Must have length 12.- Returns:
- estimated true specific force squared norm.
- Throws:
com.irurueta.numerical.EvaluationException
- if there are numerical instabilities.
-
evaluateCommonAxis
private double evaluateCommonAxis(double[] params) throws com.irurueta.numerical.EvaluationException Computes estimated true magnetic flux density squared norm using current measured body magnetic flux density and provided parameters when common z-axis is assumed. This method is internally executed during gradient estimation and Levenberg-Marquardt fitting needed for calibration computation.- Parameters:
params
- array containing current parameters for the common z-axis case. Must have length 9.- Returns:
- estimated true specific force squared norm.
- Throws:
com.irurueta.numerical.EvaluationException
- if there are numerical instabilities.
-
evaluate
private double evaluate(double bx, double by, double bz, double m11, double m21, double m31, double m12, double m22, double m32, double m13, double m23, double m33) throws com.irurueta.numerical.EvaluationException Computes estimated true magnetic flux density squared norm using current measured body magnetic flux density and provided parameters. This method is internally executed during gradient estimation and Levenberg-Marquardt fitting needed for calibration computation.- Parameters:
bx
- x-coordinate of bias.by
- y-coordinate of bias.bz
- z-coordinate of bias.m11
- element 1,1 of cross-coupling error matrix.m21
- element 2,1 of cross-coupling error matrix.m31
- element 3,1 of cross-coupling error matrix.m12
- element 1,2 of cross-coupling error matrix.m22
- element 2,2 of cross-coupling error matrix.m32
- element 3,2 of cross-coupling error matrix.m13
- element 1,3 of cross-coupling error matrix.m23
- element 2,3 of cross-coupling error matrix.m33
- element 3,3 of cross-coupling error matrix.- Returns:
- estimated true specific force squared norm.
- Throws:
com.irurueta.numerical.EvaluationException
- if there are numerical instabilities.
-
convertMagneticFluxDensity
private static double convertMagneticFluxDensity(double value, com.irurueta.units.MagneticFluxDensityUnit unit) Converts magnetic flux density value and unit to Teslas.- Parameters:
value
- magnetic flux density value.unit
- unit of magnetic flux density value.- Returns:
- converted value.
-
convertMagneticFluxDensity
private static double convertMagneticFluxDensity(com.irurueta.units.MagneticFluxDensity magneticFluxDensity) Converts magnetic flux density instance to Teslas.- Parameters:
magneticFluxDensity
- magnetic flux density instance to be converted.- Returns:
- converted value.
-