Class KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
java.lang.Object
com.irurueta.navigation.inertial.calibration.gyroscope.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
- All Implemented Interfaces:
GyroscopeCalibrator
,GyroscopeNonLinearCalibrator
,KnownFrameGyroscopeCalibrator<StandardDeviationFrameBodyKinematics,
,KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener> UnknownBiasGyroscopeCalibrator
,UnknownBiasNonLinearGyroscopeCalibrator
,UnorderedStandardDeviationFrameBodyKinematicsGyroscopeCalibrator
,GyroscopeBiasUncertaintySource
,GyroscopeCalibrationSource
public class KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
extends Object
implements KnownFrameGyroscopeCalibrator<StandardDeviationFrameBodyKinematics,KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener>, GyroscopeNonLinearCalibrator, UnknownBiasNonLinearGyroscopeCalibrator, GyroscopeCalibrationSource, GyroscopeBiasUncertaintySource, UnorderedStandardDeviationFrameBodyKinematicsGyroscopeCalibrator
Estimates gyroscope biases, cross couplings and scaling factors
along with G-dependent cross biases introduced on the gyroscope by the
specific forces sensed by the accelerometer.
This calibrator uses an iterative approach to find a minimum least squared error solution.
To use this calibrator at least 7 measurements at different known frames must be provided. In other words, accelerometer and gyroscope (i.e. body kinematics) samples must be obtained at 7 different positions, orientations and velocities (although typically velocities are always zero).
Measured gyroscope angular rates is assumed to follow the model shown below:
Ωmeas = bg + (I + Mg) * Ωtrue + Gg * ftrue + wWhere: - Ωmeas is the measured gyroscope angular rates. This is a 3x1 vector. - bg is the gyroscope bias. Ideally, on a perfect gyroscope, this should be a 3x1 zero vector. - I is the 3x3 identity matrix. - Mg is the 3x3 matrix containing cross-couplings and scaling factors. Ideally, on a perfect gyroscope, this should be a 3x3 zero matrix. - Ωtrue is ground-truth gyroscope angular rates. - Gg is the G-dependent cross biases introduced by the specific forces sensed by the accelerometer. Ideally, on a perfect gyroscope, this should be a 3x3 zero matrix. - ftrue is ground-truth specific force. This is a 3x1 vector. - w is measurement noise. This is a 3x1 vector.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final int
Number of unknowns when common z-axis is assumed for both the accelerometer and gyroscope.private boolean
This flag indicates whether z-axis is assumed to be common for accelerometer and gyroscope.static final boolean
Indicates whether by default a common z-axis is assumed for both the accelerometer and gyroscope.private double[]
Estimated angular rate biases for each IMU axis expressed in radians per second (rad/s).private double
Estimated chi square value.private com.irurueta.algebra.Matrix
Estimated covariance matrix for estimated parameters.private com.irurueta.algebra.Matrix
Estimated G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.private com.irurueta.algebra.Matrix
Estimated gyroscope scale factors and cross coupling errors.private double
Estimated mean square error respect to provided measurements.private final com.irurueta.numerical.fitting.LevenbergMarquardtMultiVariateFitter
Levenberg-Marquardt fitter to find a non-linear solution.private static final int
Number of unknowns for the general case.private double
Initial x-coordinate of gyroscope bias to be used to find a solution.private double
Initial y-coordinate of gyroscope bias to be used to find a solution.private double
Initial z-coordinate of gyroscope bias to be used to find a solution.private com.irurueta.algebra.Matrix
Initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.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.Listener to handle events raised by this calibrator.Contains a collections of body kinematics measurements taken at different frames (positions, orientations and velocities) and containing the standard deviations of accelerometer and gyroscope measurements.static final int
Required minimum number of measurements.private boolean
Indicates whether calibrator is running. -
Constructor Summary
ConstructorsConstructorDescriptionConstructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double[] initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double[] initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(double[] initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(double[] initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(double initialBiasX, double initialBiasY, double initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.algebra.Matrix initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.algebra.Matrix initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double[] initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double[] initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double[] initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double[] initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor.KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener listener) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionvoid
Estimates gyroscope calibration parameters containing bias, scale factors, cross-coupling errors and G-dependent coupling.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
convertAngularSpeed
(double value, com.irurueta.units.AngularSpeedUnit unit) Converts angular speed value and unit to radians per second.private static double
convertAngularSpeed
(com.irurueta.units.AngularSpeed angularSpeed) Converts angular speed instance to radians per second.com.irurueta.units.AngularSpeed
Gets x coordinate of estimated gyroscope bias.boolean
getEstimatedBiasAngularSpeedX
(com.irurueta.units.AngularSpeed result) Gets x coordinate of estimated gyroscope bias.com.irurueta.units.AngularSpeed
Gets y coordinate of estimated gyroscope bias.boolean
getEstimatedBiasAngularSpeedY
(com.irurueta.units.AngularSpeed result) Gets y coordinate of estimated gyroscope bias.com.irurueta.units.AngularSpeed
Gets z coordinate of estimated gyroscope bias.boolean
getEstimatedBiasAngularSpeedZ
(com.irurueta.units.AngularSpeed result) Gets z coordinate of estimated gyroscope bias.Gets estimated gyroscope bias.boolean
Gets estimated gyroscope bias.double[]
Gets array containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).boolean
getEstimatedBiases
(double[] result) Gets array containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).com.irurueta.algebra.Matrix
Gets column matrix containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).boolean
getEstimatedBiasesAsMatrix
(com.irurueta.algebra.Matrix result) Gets column matrix containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).Gets standard deviation of estimated gyroscope bias coordinates.boolean
Gets standard deviation of estimated gyroscope bias coordinates.Gets average of estimated standard deviation of gyroscope bias coordinates expressed in radians per second (rad/s).com.irurueta.units.AngularSpeed
Gets average of estimated standard deviation of gyroscope bias coordinates.boolean
getEstimatedBiasStandardDeviationAverageAsAngularSpeed
(com.irurueta.units.AngularSpeed result) Gets average of estimated standard deviation of gyroscope bias coordinates.Gets norm of estimated standard deviation of gyroscope bias expressed in radians per second (rad/s).com.irurueta.units.AngularSpeed
Gets norm of estimated standard deviation of gyroscope bias.boolean
getEstimatedBiasStandardDeviationNormAsAngularSpeed
(com.irurueta.units.AngularSpeed result) Gets norm of estimated standard deviation of gyroscope bias coordinates.Gets x coordinate of estimated gyroscope bias expressed in radians per second (rad/s).Gets standard deviation of estimated x coordinate of gyroscope bias expressed in radians per second (rad/s).com.irurueta.units.AngularSpeed
Gets standard deviation of estimated x coordinate of gyroscope bias.boolean
getEstimatedBiasXStandardDeviationAsAngularSpeed
(com.irurueta.units.AngularSpeed result) Gets standard deviation of estimated x coordinate of gyroscope bias.Gets variance of estimated x coordinate of gyroscope bias expressed in (rad^2/s^2).Gets y coordinate of estimated gyroscope bias expressed in radians per second (rad/s).Gets standard deviation of estimated y coordinate of gyroscope bias expressed in radians per second (rad/s).com.irurueta.units.AngularSpeed
Gets standard deviation of estimated y coordinate of gyroscope bias.boolean
getEstimatedBiasYStandardDeviationAsAngularSpeed
(com.irurueta.units.AngularSpeed result) Gets standard deviation of estimated y coordinate of gyroscope bias.Gets variance of estimated y coordinate of gyroscope bias expressed in (rad^2/s^2).Gets z coordinate of estimated gyroscope bias expressed in radians per second (rad/s).Gets standard deviation of estimated z coordinate of gyroscope bias expressed in radians per second (rad/s).com.irurueta.units.AngularSpeed
Gets standard deviation of estimated z coordinate of gyroscope bias.boolean
getEstimatedBiasZStandardDeviationAsAngularSpeed
(com.irurueta.units.AngularSpeed result) Gets standard deviation of estimated z coordinate of gyroscope bias.Gets variance of estimated z coordinate of gyroscope bias expressed in (rad^2/s^2).double
Gets estimated chi square value.com.irurueta.algebra.Matrix
Gets estimated covariance matrix for estimated parameters.com.irurueta.algebra.Matrix
Gets estimated G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.com.irurueta.algebra.Matrix
Gets estimated gyroscope 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.double[]
Gets initial bias to be used to find a solution as an array.void
getInitialBias
(double[] result) Gets initial bias to be used to find a solution as an array.com.irurueta.units.AngularSpeed
Gets initial x-coordinate of gyroscope bias to be used to find a solution.void
getInitialBiasAngularSpeedX
(com.irurueta.units.AngularSpeed result) Gets initial x-coordinate of gyroscope bias to be used to find a solution.com.irurueta.units.AngularSpeed
Gets initial y-coordinate of gyroscope bias to be used to find a solution.void
getInitialBiasAngularSpeedY
(com.irurueta.units.AngularSpeed result) Gets initial y-coordinate of gyroscope bias to be used to find a solution.com.irurueta.units.AngularSpeed
Gets initial z-coordinate of gyroscope bias to be used to find a solution.void
getInitialBiasAngularSpeedZ
(com.irurueta.units.AngularSpeed result) Gets initial z-coordinate of gyroscope bias to be used to find a solution.com.irurueta.algebra.Matrix
Gets initial bias to be used to find a solution as a column matrix.void
getInitialBiasAsMatrix
(com.irurueta.algebra.Matrix result) Gets initial bias to be used to find a solution as a column matrix.Gets initial bias coordinates of gyroscope used to find a solution.void
Gets initial bias coordinates of gyroscope used to find a solution.double
Gets initial x-coordinate of gyroscope bias to be used to find a solution.double
Gets initial y-coordinate of gyroscope bias to be used to find a solution.double
Gets initial z-coordinate of gyroscope bias to be used to find a solution.com.irurueta.algebra.Matrix
Gets initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.void
getInitialGg
(com.irurueta.algebra.Matrix result) Gets initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.com.irurueta.algebra.Matrix
Gets initial scale factors and cross coupling errors matrix.void
getInitialMg
(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 estimator.Indicates the type of measurement or sequence used by this calibrator.Gets a collection of body kinematics measurements taken at different frames (positions, orientations and velocities) and containing the standard deviations of accelerometer and gyroscope measurements.int
Gets minimum number of required measurements.boolean
Indicates whether z-axis is assumed to be common for accelerometer and gyroscope.boolean
Indicates whether this calibrator requires ordered measurements or sequences in a list or not.boolean
Indicates whether this calibrator requires quality scores for each measurement/sequence or not.boolean
isReady()
Indicates whether calibrator is ready to start.boolean
Indicates whether calibrator is currently running or not.void
setCommonAxisUsed
(boolean commonAxisUsed) Specifies whether z-axis is assumed to be common for accelerometer and gyroscope.void
setInitialBias
(double[] initialBias) Sets initial bias to be used to find a solution as an array.void
setInitialBias
(double initialBiasX, double initialBiasY, double initialBiasZ) Sets initial bias coordinates of gyroscope used to find a solution expressed in radians per second (rad/s).void
setInitialBias
(com.irurueta.algebra.Matrix initialBias) Sets initial bias to be used to find a solution as a column matrix with values expressed in radians per second (rad/s).void
setInitialBias
(AngularSpeedTriad initialBias) Sets initial bias coordinates of gyroscope used to find a solution.void
setInitialBias
(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Sets initial bias coordinates of gyroscope used to find a solution.void
setInitialBiasX
(double initialBiasX) Sets initial x-coordinate of gyroscope bias to be used to find a solution.void
setInitialBiasX
(com.irurueta.units.AngularSpeed initialBiasX) Sets initial x-coordinate of gyroscope bias to be used to find a solution.void
setInitialBiasY
(double initialBiasY) Sets initial y-coordinate of gyroscope bias to be used to find a solution.void
setInitialBiasY
(com.irurueta.units.AngularSpeed initialBiasY) Sets initial y-coordinate of gyroscope bias to be used to find a solution.void
setInitialBiasZ
(double initialBiasZ) Sets initial z-coordinate of gyroscope bias to be used to find a solution.void
setInitialBiasZ
(com.irurueta.units.AngularSpeed initialBiasZ) Sets initial z-coordinate of gyroscope bias to be used to find a solution.void
setInitialCrossCouplingErrors
(double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Sets initial cross coupling errors.void
setInitialGg
(com.irurueta.algebra.Matrix initialGg) Sets initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.void
setInitialMg
(com.irurueta.algebra.Matrix initialMg) 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.private void
Sets input data into Levenberg-Marquardt fitter.void
Sets listener to handle events raised by this estimator.void
setMeasurements
(Collection<? extends StandardDeviationFrameBodyKinematics> measurements) Sets a collection of body kinematics measurements taken at different frames (positions, orientations and velocities) and containing the standard deviations of accelerometer and gyroscope measurements.
-
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 both the accelerometer and gyroscope.- See Also:
-
MINIMUM_MEASUREMENTS
public static final int MINIMUM_MEASUREMENTSRequired minimum number of measurements.- See Also:
-
COMMON_Z_AXIS_UNKNOWNS
private static final int COMMON_Z_AXIS_UNKNOWNSNumber of unknowns when common z-axis is assumed for both the accelerometer and gyroscope.- See Also:
-
GENERAL_UNKNOWNS
private static final int GENERAL_UNKNOWNSNumber of unknowns for the general case.- See Also:
-
fitter
private final com.irurueta.numerical.fitting.LevenbergMarquardtMultiVariateFitter fitterLevenberg-Marquardt fitter to find a non-linear solution. -
initialBiasX
private double initialBiasXInitial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s). -
initialBiasY
private double initialBiasYInitial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s). -
initialBiasZ
private double initialBiasZInitial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s). -
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. -
initialGg
private com.irurueta.algebra.Matrix initialGgInitial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer. -
measurements
Contains a collections of body kinematics measurements taken at different frames (positions, orientations and velocities) and containing the standard deviations of accelerometer and gyroscope measurements. If a single device IMU needs to be calibrated, typically all measurements are taken at the same position, with zero velocity and multiple orientations. However, if we just want to calibrate a given IMU model (e.g. obtain an average and less precise calibration for the IMU of a given phone model), we could take measurements collected throughout the planet at multiple positions while the phone remains static (e.g. while charging), hence each measurement position will change, velocity will remain zero and orientation will be typically constant at horizontal orientation while the phone remains on a flat surface. -
commonAxisUsed
private boolean commonAxisUsedThis flag indicates whether z-axis is assumed to be common for accelerometer and gyroscope. When enabled, this eliminates 3 variables from Ma matrix. -
listener
Listener to handle events raised by this calibrator. -
estimatedBiases
private double[] estimatedBiasesEstimated angular rate biases for each IMU axis expressed in radians per second (rad/s). -
estimatedMg
private com.irurueta.algebra.Matrix estimatedMgEstimated gyroscope scale factors and cross coupling errors. This is the product of matrix Tg containing cross coupling errors and Kg containing scaling factors. So that:Mg = [sx mxy mxz] = Tg*Kg [myx sy myz] [mzx mzy sz ]
Where:Kg = [sx 0 0 ] [0 sy 0 ] [0 0 sz]
andTg = [1 -alphaXy alphaXz ] [alphaYx 1 -alphaYz] [-alphaZx alphaZy 1 ]
Hence:Mg = [sx mxy mxz] = Tg*Kg = [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 gyroscope z-axis is assumed to be the same as the body z-axis. When this is assumed, myx = mzx = mzy = 0 and the Mg matrix becomes upper diagonal:Mg = [sx mxy mxz] [0 sy myz] [0 0 sz ]
Values of this matrix are unit-less. -
estimatedGg
private com.irurueta.algebra.Matrix estimatedGgEstimated G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer. This instance allows any 3x3 matrix. -
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.
-
-
Constructor Details
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator()Constructor. -
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.initialSx
- initial x scaling factor.initialSy
- initial y scaling factor.initialSz
- initial z scaling factor.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double initialBiasX, double initialBiasY, double initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ, double initialSx, double initialSy, double initialSz, double initialMxy, double initialMxz, double initialMyx, double initialMyz, double initialMzx, double initialMzy) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBiasX
- initial x-coordinate of gyroscope bias to be used to find a solution.initialBiasY
- initial y-coordinate of gyroscope bias to be used to find a solution.initialBiasZ
- initial z-coordinate of gyroscope bias to be used to find a solution.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.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(double[] initialBias) Constructor.- Parameters:
initialBias
- initial gyroscope bias to be used to find a solution. This must have length 3 and is expressed in radians per second (rad/s).- Throws:
IllegalArgumentException
- if provided bias array does not have length 3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, double[] initialBias) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBias
- initial gyroscope bias to be used to find a solution. This must have length 3 and is expressed in radians per second (rad/s).- Throws:
IllegalArgumentException
- if provided bias array does not have length 3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, double[] initialBias) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial gyroscope bias to be used to find a solution. This must have length 3 and is expressed in radians per second (rad/s).- Throws:
IllegalArgumentException
- if provided bias array does not have length 3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, double[] initialBias) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial gyroscope bias to be used to find a solution. This must have length 3 and is expressed in radians per second (rad/s).- Throws:
IllegalArgumentException
- if provided bias array does not have length 3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(com.irurueta.algebra.Matrix initialBias) Constructor.- Parameters:
initialBias
- initial bias to find a solution.- Throws:
IllegalArgumentException
- if provided bias matrix is not 3x1.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBias
- initial bias to find a solution.- Throws:
IllegalArgumentException
- if provided bias matrix is not 3x1.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial bias to find a solution.- Throws:
IllegalArgumentException
- if provided bias matrix is not 3x1.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial bias to find a solution.- Throws:
IllegalArgumentException
- if provided bias matrix is not 3x1.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.- Parameters:
initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1 or scaling and coupling error matrix is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1 or scaling and coupling error matrix is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1 or scaling and coupling error matrix is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1 or scaling and coupling error matrix is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.- Parameters:
initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.initialGg
- initial G-dependent cross biases.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1, scaling and coupling error matrix is not 3x3 or g-dependant cross biases is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.initialGg
- initial G-dependent cross biases.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1, scaling and coupling error matrix is not 3x3 or g-dependant cross biases is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.- Parameters:
commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.initialGg
- initial G-dependent cross biases.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1, scaling and coupling error matrix is not 3x3 or g-dependant cross biases is not 3x3.
-
KnownFrameGyroscopeNonLinearLeastSquaresCalibrator
public KnownFrameGyroscopeNonLinearLeastSquaresCalibrator(Collection<StandardDeviationFrameBodyKinematics> measurements, boolean commonAxisUsed, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.- Parameters:
measurements
- collection of body kinematics measurements with standard deviations taken at different frames (positions, orientations and velocities).commonAxisUsed
- indicates whether z-axis is assumed to be common for accelerometer and gyroscope.initialBias
- initial bias to find a solution.initialMg
- initial scale factors and cross coupling errors matrix.initialGg
- initial G-dependent cross biases.- Throws:
IllegalArgumentException
- if either provided bias matrix is not 3x1, scaling and coupling error matrix is not 3x3 or g-dependant cross biases is not 3x3.
-
-
Method Details
-
getInitialBiasX
public double getInitialBiasX()Gets initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).- Specified by:
getInitialBiasX
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial x-coordinate of gyroscope bias.
-
setInitialBiasX
public void setInitialBiasX(double initialBiasX) throws com.irurueta.navigation.LockedException Sets initial x-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).- Specified by:
setInitialBiasX
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialBiasY
public double getInitialBiasY()Gets initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).- Specified by:
getInitialBiasY
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial y-coordinate of gyroscope bias.
-
setInitialBiasY
public void setInitialBiasY(double initialBiasY) throws com.irurueta.navigation.LockedException Sets initial y-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).- Specified by:
setInitialBiasY
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasY
- initial y-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialBiasZ
public double getInitialBiasZ()Gets initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).- Specified by:
getInitialBiasZ
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial z-coordinate of gyroscope bias.
-
setInitialBiasZ
public void setInitialBiasZ(double initialBiasZ) throws com.irurueta.navigation.LockedException Sets initial z-coordinate of gyroscope bias to be used to find a solution. This is expressed in radians per second (rad/s).- Specified by:
setInitialBiasZ
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasZ
- initial z-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialBiasAngularSpeedX
public com.irurueta.units.AngularSpeed getInitialBiasAngularSpeedX()Gets initial x-coordinate of gyroscope bias to be used to find a solution.- Specified by:
getInitialBiasAngularSpeedX
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial x-coordinate of gyroscope bias.
-
getInitialBiasAngularSpeedX
public void getInitialBiasAngularSpeedX(com.irurueta.units.AngularSpeed result) Gets initial x-coordinate of gyroscope bias to be used to find a solution.- Specified by:
getInitialBiasAngularSpeedX
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
result
- instance where result data will be stored.
-
setInitialBiasX
public void setInitialBiasX(com.irurueta.units.AngularSpeed initialBiasX) throws com.irurueta.navigation.LockedException Sets initial x-coordinate of gyroscope bias to be used to find a solution.- Specified by:
setInitialBiasX
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialBiasAngularSpeedY
public com.irurueta.units.AngularSpeed getInitialBiasAngularSpeedY()Gets initial y-coordinate of gyroscope bias to be used to find a solution.- Specified by:
getInitialBiasAngularSpeedY
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial y-coordinate of gyroscope bias.
-
getInitialBiasAngularSpeedY
public void getInitialBiasAngularSpeedY(com.irurueta.units.AngularSpeed result) Gets initial y-coordinate of gyroscope bias to be used to find a solution.- Specified by:
getInitialBiasAngularSpeedY
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
result
- instance where result data will be stored.
-
setInitialBiasY
public void setInitialBiasY(com.irurueta.units.AngularSpeed initialBiasY) throws com.irurueta.navigation.LockedException Sets initial y-coordinate of gyroscope bias to be used to find a solution.- Specified by:
setInitialBiasY
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasY
- initial y-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialBiasAngularSpeedZ
public com.irurueta.units.AngularSpeed getInitialBiasAngularSpeedZ()Gets initial z-coordinate of gyroscope bias to be used to find a solution.- Specified by:
getInitialBiasAngularSpeedZ
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial z-coordinate of gyroscope bias.
-
getInitialBiasAngularSpeedZ
public void getInitialBiasAngularSpeedZ(com.irurueta.units.AngularSpeed result) Gets initial z-coordinate of gyroscope bias to be used to find a solution.- Specified by:
getInitialBiasAngularSpeedZ
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
result
- instance where result data will be stored.
-
setInitialBiasZ
public void setInitialBiasZ(com.irurueta.units.AngularSpeed initialBiasZ) throws com.irurueta.navigation.LockedException Sets initial z-coordinate of gyroscope bias to be used to find a solution.- Specified by:
setInitialBiasZ
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasZ
- initial z-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialBias
public void setInitialBias(double initialBiasX, double initialBiasY, double initialBiasZ) throws com.irurueta.navigation.LockedException Sets initial bias coordinates of gyroscope used to find a solution expressed in radians per second (rad/s).- Specified by:
setInitialBias
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias.initialBiasY
- initial y-coordinate of gyroscope bias.initialBiasZ
- initial z-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setInitialBias
public void setInitialBias(com.irurueta.units.AngularSpeed initialBiasX, com.irurueta.units.AngularSpeed initialBiasY, com.irurueta.units.AngularSpeed initialBiasZ) throws com.irurueta.navigation.LockedException Sets initial bias coordinates of gyroscope used to find a solution.- Specified by:
setInitialBias
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBiasX
- initial x-coordinate of gyroscope bias.initialBiasY
- initial y-coordinate of gyroscope bias.initialBiasZ
- initial z-coordinate of gyroscope bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialSx
public double getInitialSx()Gets initial x scaling factor.- Specified by:
getInitialSx
in interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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 interfaceGyroscopeNonLinearCalibrator
- 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.
-
getInitialBias
public double[] getInitialBias()Gets initial bias to be used to find a solution as an array. Array values are expressed in radians per second (rad/s).- Specified by:
getInitialBias
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- array containing coordinates of initial bias.
-
getInitialBias
public void getInitialBias(double[] result) Gets initial bias to be used to find a solution as an array. Array values are expressed in radians per second (rad/s).- Specified by:
getInitialBias
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
result
- instance where result data will be copied to.- Throws:
IllegalArgumentException
- if provided array does not have length 3.
-
setInitialBias
public void setInitialBias(double[] initialBias) throws com.irurueta.navigation.LockedException Sets initial bias to be used to find a solution as an array. Array values are expressed in radians per second (rad/s).- Specified by:
setInitialBias
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBias
- initial bias to find a solution.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided array does not have length 3.
-
getInitialBiasAsMatrix
public com.irurueta.algebra.Matrix getInitialBiasAsMatrix()Gets initial bias to be used to find a solution as a column matrix. Values are expressed in radians per second (rad/s).- Specified by:
getInitialBiasAsMatrix
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial bias to be used to find a solution as a column matrix.
-
getInitialBiasAsMatrix
public void getInitialBiasAsMatrix(com.irurueta.algebra.Matrix result) Gets initial bias to be used to find a solution as a column matrix. Values are expressed in radians per second (rad/s).- Specified by:
getInitialBiasAsMatrix
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
result
- instance where result data will be copied to.- Throws:
IllegalArgumentException
- if provided matrix is not 3x1.
-
setInitialBias
public void setInitialBias(com.irurueta.algebra.Matrix initialBias) throws com.irurueta.navigation.LockedException Sets initial bias to be used to find a solution as a column matrix with values expressed in radians per second (rad/s).- Specified by:
setInitialBias
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Parameters:
initialBias
- initial bias to find a solution.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided matrix is not 3x1.
-
getInitialBiasAsTriad
Gets initial bias coordinates of gyroscope used to find a solution.- Specified by:
getInitialBiasAsTriad
in interfaceUnknownBiasNonLinearGyroscopeCalibrator
- Returns:
- initial bias coordinates.
-
getInitialMg
public com.irurueta.algebra.Matrix getInitialMg()Gets initial scale factors and cross coupling errors matrix.- Specified by:
getInitialMg
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial scale factors and cross coupling errors matrix.
-
getInitialMg
public void getInitialMg(com.irurueta.algebra.Matrix result) Gets initial scale factors and cross coupling errors matrix.- Specified by:
getInitialMg
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
result
- instance where data will be stored.- Throws:
IllegalArgumentException
- if provided matrix is not 3x3.
-
setInitialMg
public void setInitialMg(com.irurueta.algebra.Matrix initialMg) throws com.irurueta.navigation.LockedException Sets initial scale factors and cross coupling errors matrix.- Specified by:
setInitialMg
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMg
- 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.
-
getInitialGg
public com.irurueta.algebra.Matrix getInitialGg()Gets initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.- Specified by:
getInitialGg
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- a 3x3 matrix containing initial g-dependent cross biases.
-
getInitialGg
public void getInitialGg(com.irurueta.algebra.Matrix result) Gets initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.- Specified by:
getInitialGg
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
result
- instance where data will be stored.- Throws:
IllegalArgumentException
- if provided matrix is not 3x3.
-
setInitialGg
public void setInitialGg(com.irurueta.algebra.Matrix initialGg) throws com.irurueta.navigation.LockedException Sets initial G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer.- Specified by:
setInitialGg
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialGg
- g-dependent cross biases.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided matrix is not 3x3.
-
getMeasurements
Gets a collection of body kinematics measurements taken at different frames (positions, orientations and velocities) and containing the standard deviations of accelerometer and gyroscope measurements. If a single device IMU needs to be calibrated, typically all measurements are taken at the same position, with zero velocity and multiple orientations. However, if we just want to calibrate a given IMU model (e.g. obtain an average and less precise calibration for the IMU of a given phone model), we could take measurements collected throughout the planet at multiple positions while the phone remains static (e.g. while charging), hence each measurement position will change, velocity will remain zero and orientation will be typically constant at horizontal orientation while the phone remains on a flat surface.- Specified by:
getMeasurements
in interfaceKnownFrameGyroscopeCalibrator<StandardDeviationFrameBodyKinematics,
KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener> - Specified by:
getMeasurements
in interfaceUnorderedStandardDeviationFrameBodyKinematicsGyroscopeCalibrator
- Returns:
- a collection of body kinematics measurements taken at different frames (positions, orientations and velocities).
-
setMeasurements
public void setMeasurements(Collection<? extends StandardDeviationFrameBodyKinematics> measurements) throws com.irurueta.navigation.LockedException Sets a collection of body kinematics measurements taken at different frames (positions, orientations and velocities) and containing the standard deviations of accelerometer and gyroscope measurements. If a single device IMU needs to be calibrated, typically all measurements are taken at the same position, with zero velocity and multiple orientations. However, if we just want to calibrate a given IMU model (e.g. obtain an average and less precise calibration for the IMU of a given phone model), we could take measurements collected throughout the planet at multiple positions while the phone remains static (e.g. while charging), hence each measurement position will change, velocity will remain zero and orientation will be typically constant at horizontal orientation while the phone remains on a flat surface.- Specified by:
setMeasurements
in interfaceKnownFrameGyroscopeCalibrator<StandardDeviationFrameBodyKinematics,
KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener> - Specified by:
setMeasurements
in interfaceUnorderedStandardDeviationFrameBodyKinematicsGyroscopeCalibrator
- Parameters:
measurements
- collection of body kinematics measurements taken at different frames (positions, orientations and velocities).- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getMeasurementOrSequenceType
Indicates the type of measurement or sequence used by this calibrator.- Specified by:
getMeasurementOrSequenceType
in interfaceGyroscopeCalibrator
- Returns:
- type of measurement or sequence used by this calibrator.
-
isOrderedMeasurementsOrSequencesRequired
public boolean isOrderedMeasurementsOrSequencesRequired()Indicates whether this calibrator requires ordered measurements or sequences in a list or not.- Specified by:
isOrderedMeasurementsOrSequencesRequired
in interfaceGyroscopeCalibrator
- Returns:
- true if measurements or sequences must be ordered, false otherwise.
-
isQualityScoresRequired
public boolean isQualityScoresRequired()Indicates whether this calibrator requires quality scores for each measurement/sequence or not.- Specified by:
isQualityScoresRequired
in interfaceGyroscopeCalibrator
- Returns:
- true if quality scores are required, false otherwise.
-
isCommonAxisUsed
public boolean isCommonAxisUsed()Indicates whether z-axis is assumed to be common for accelerometer and gyroscope. When enabled, this eliminates 3 variables from Ma matrix.- Specified by:
isCommonAxisUsed
in interfaceGyroscopeCalibrator
- Returns:
- true if z-axis is assumed to be common for accelerometer and gyroscope, 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 Ma matrix.- Specified by:
setCommonAxisUsed
in interfaceGyroscopeCalibrator
- Parameters:
commonAxisUsed
- true if z-axis is assumed to be common for accelerometer and gyroscope, false otherwise.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getListener
Gets listener to handle events raised by this estimator.- Specified by:
getListener
in interfaceKnownFrameGyroscopeCalibrator<StandardDeviationFrameBodyKinematics,
KnownFrameGyroscopeNonLinearLeastSquaresCalibratorListener> - Returns:
- listener to handle events raised by this estimator.
-
getMinimumRequiredMeasurementsOrSequences
public int getMinimumRequiredMeasurementsOrSequences()Gets minimum number of required measurements.- Specified by:
getMinimumRequiredMeasurementsOrSequences
in interfaceGyroscopeCalibrator
- Returns:
- minimum number of required measurements.
-
isReady
public boolean isReady()Indicates whether calibrator is ready to start.- Specified by:
isReady
in interfaceGyroscopeCalibrator
- Returns:
- true if calibrator is ready, false otherwise.
-
isRunning
public boolean isRunning()Indicates whether calibrator is currently running or not.- Specified by:
isRunning
in interfaceGyroscopeCalibrator
- Returns:
- true if calibrator is running, false otherwise.
-
calibrate
public void calibrate() throws com.irurueta.navigation.LockedException, com.irurueta.navigation.NotReadyException, CalibrationExceptionEstimates gyroscope calibration parameters containing bias, scale factors, cross-coupling errors and G-dependent coupling.- Specified by:
calibrate
in interfaceGyroscopeCalibrator
- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.com.irurueta.navigation.NotReadyException
- if calibrator is not ready.CalibrationException
- if estimation fails for numerical reasons.
-
getEstimatedBiases
public double[] getEstimatedBiases()Gets array containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).- Specified by:
getEstimatedBiases
in interfaceGyroscopeCalibrationSource
- Specified by:
getEstimatedBiases
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- array containing x,y,z components of estimated gyroscope biases.
-
getEstimatedBiases
public boolean getEstimatedBiases(double[] result) Gets array containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).- Specified by:
getEstimatedBiases
in interfaceUnknownBiasGyroscopeCalibrator
- Parameters:
result
- instance where estimated gyroscope biases will be stored.- Returns:
- true if result instance was updated, false otherwise (when estimation is not yet available).
-
getEstimatedBiasesAsMatrix
public com.irurueta.algebra.Matrix getEstimatedBiasesAsMatrix()Gets column matrix containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).- Specified by:
getEstimatedBiasesAsMatrix
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- column matrix containing x,y,z components of estimated gyroscope biases.
-
getEstimatedBiasesAsMatrix
public boolean getEstimatedBiasesAsMatrix(com.irurueta.algebra.Matrix result) throws com.irurueta.algebra.WrongSizeException Gets column matrix containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).- Specified by:
getEstimatedBiasesAsMatrix
in interfaceUnknownBiasGyroscopeCalibrator
- 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.
-
getEstimatedBiasX
Gets x coordinate of estimated gyroscope bias expressed in radians per second (rad/s).- Specified by:
getEstimatedBiasX
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- x coordinate of estimated gyroscope bias or null if not available.
-
getEstimatedBiasY
Gets y coordinate of estimated gyroscope bias expressed in radians per second (rad/s).- Specified by:
getEstimatedBiasY
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- y coordinate of estimated gyroscope bias or null if not available.
-
getEstimatedBiasZ
Gets z coordinate of estimated gyroscope bias expressed in radians per second (rad/s).- Specified by:
getEstimatedBiasZ
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- z coordinate of estimated gyroscope bias or null if not available.
-
getEstimatedBiasAngularSpeedX
public com.irurueta.units.AngularSpeed getEstimatedBiasAngularSpeedX()Gets x coordinate of estimated gyroscope bias.- Specified by:
getEstimatedBiasAngularSpeedX
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- x coordinate of estimated gyroscope bias or null if not available.
-
getEstimatedBiasAngularSpeedX
public boolean getEstimatedBiasAngularSpeedX(com.irurueta.units.AngularSpeed result) Gets x coordinate of estimated gyroscope bias.- Specified by:
getEstimatedBiasAngularSpeedX
in interfaceUnknownBiasGyroscopeCalibrator
- Parameters:
result
- instance where result will be stored.- Returns:
- true if result was updated, false if estimation is not available.
-
getEstimatedBiasAngularSpeedY
public com.irurueta.units.AngularSpeed getEstimatedBiasAngularSpeedY()Gets y coordinate of estimated gyroscope bias.- Specified by:
getEstimatedBiasAngularSpeedY
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- y coordinate of estimated gyroscope bias or null if not available.
-
getEstimatedBiasAngularSpeedY
public boolean getEstimatedBiasAngularSpeedY(com.irurueta.units.AngularSpeed result) Gets y coordinate of estimated gyroscope bias.- Specified by:
getEstimatedBiasAngularSpeedY
in interfaceUnknownBiasGyroscopeCalibrator
- Parameters:
result
- instance where result will be stored.- Returns:
- true if result was updated, false if estimation is not available.
-
getEstimatedBiasAngularSpeedZ
public com.irurueta.units.AngularSpeed getEstimatedBiasAngularSpeedZ()Gets z coordinate of estimated gyroscope bias.- Specified by:
getEstimatedBiasAngularSpeedZ
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- z coordinate of estimated gyroscope bias or null if not available.
-
getEstimatedBiasAngularSpeedZ
public boolean getEstimatedBiasAngularSpeedZ(com.irurueta.units.AngularSpeed result) Gets z coordinate of estimated gyroscope bias.- Specified by:
getEstimatedBiasAngularSpeedZ
in interfaceUnknownBiasGyroscopeCalibrator
- Parameters:
result
- instance where result will be stored.- Returns:
- true if result was updated, false if estimation is not available.
-
getEstimatedBiasAsTriad
Gets estimated gyroscope bias.- Specified by:
getEstimatedBiasAsTriad
in interfaceUnknownBiasGyroscopeCalibrator
- Returns:
- estimated gyroscope bias or null if not available.
-
getEstimatedMg
public com.irurueta.algebra.Matrix getEstimatedMg()Gets estimated gyroscope scale factors and cross coupling errors. This is the product of matrix Tg containing cross coupling errors and Kg containing scaling factors. So that:Mg = [sx mxy mxz] = Tg*Kg [myx sy myz] [mzx mzy sz ]
Where:Kg = [sx 0 0 ] [0 sy 0 ] [0 0 sz]
andTg = [1 -alphaXy alphaXz ] [alphaYx 1 -alphaYz] [-alphaZx alphaZy 1 ]
Hence:Mg = [sx mxy mxz] = Tg*Kg = [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 gyroscope z-axis is assumed to be the same as the body z-axis. When this is assumed, myx = mzx = mzy = 0 and the Mg matrix becomes upper diagonal:Mg = [sx mxy mxz] [0 sy myz] [0 0 sz ]
Values of this matrix are unit-less.- Specified by:
getEstimatedMg
in interfaceGyroscopeCalibrationSource
- Specified by:
getEstimatedMg
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope scale factors and cross coupling errors, or null if not available.
-
getEstimatedSx
Gets estimated x-axis scale factor.- Specified by:
getEstimatedSx
in interfaceGyroscopeCalibrator
- Returns:
- estimated x-axis scale factor or null if not available.
-
getEstimatedSy
Gets estimated y-axis scale factor.- Specified by:
getEstimatedSy
in interfaceGyroscopeCalibrator
- Returns:
- estimated y-axis scale factor or null if not available.
-
getEstimatedSz
Gets estimated z-axis scale factor.- Specified by:
getEstimatedSz
in interfaceGyroscopeCalibrator
- Returns:
- estimated z-axis scale factor or null if not available.
-
getEstimatedMxy
Gets estimated x-y cross-coupling error.- Specified by:
getEstimatedMxy
in interfaceGyroscopeCalibrator
- Returns:
- estimated x-y cross-coupling error or null if not available.
-
getEstimatedMxz
Gets estimated x-z cross-coupling error.- Specified by:
getEstimatedMxz
in interfaceGyroscopeCalibrator
- Returns:
- estimated x-z cross-coupling error or null if not available.
-
getEstimatedMyx
Gets estimated y-x cross-coupling error.- Specified by:
getEstimatedMyx
in interfaceGyroscopeCalibrator
- Returns:
- estimated y-x cross-coupling error or null if not available.
-
getEstimatedMyz
Gets estimated y-z cross-coupling error.- Specified by:
getEstimatedMyz
in interfaceGyroscopeCalibrator
- Returns:
- estimated y-z cross-coupling error or null if not available.
-
getEstimatedMzx
Gets estimated z-x cross-coupling error.- Specified by:
getEstimatedMzx
in interfaceGyroscopeCalibrator
- Returns:
- estimated z-x cross-coupling error or null if not available.
-
getEstimatedMzy
Gets estimated z-y cross-coupling error.- Specified by:
getEstimatedMzy
in interfaceGyroscopeCalibrator
- Returns:
- estimated z-y cross-coupling error or null if not available.
-
getEstimatedGg
public com.irurueta.algebra.Matrix getEstimatedGg()Gets estimated G-dependent cross biases introduced on the gyroscope by the specific forces sensed by the accelerometer. This instance allows any 3x3 matrix.- Specified by:
getEstimatedGg
in interfaceGyroscopeCalibrationSource
- Specified by:
getEstimatedGg
in interfaceGyroscopeCalibrator
- Returns:
- estimated G-dependent cross biases.
-
getEstimatedCovariance
public com.irurueta.algebra.Matrix getEstimatedCovariance()Gets estimated covariance matrix for estimated parameters. Diagonal elements of the matrix contains variance for the following parameters (following indicated order): bgx, bgy, bgz, sx, sy, sz, mxy, mxz, myx, myz, mzx, mzy, gg11, gg21, gg31, gg12, gg22, gg32, gg13, gg23, gg33.- Specified by:
getEstimatedCovariance
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- estimated covariance matrix for estimated parameters.
-
getEstimatedChiSq
public double getEstimatedChiSq()Gets estimated chi square value.- Specified by:
getEstimatedChiSq
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- estimated chi square value.
-
getEstimatedMse
public double getEstimatedMse()Gets estimated mean square error respect to provided measurements.- Specified by:
getEstimatedMse
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- estimated mean square error respect to provided measurements.
-
getEstimatedBiasXVariance
Gets variance of estimated x coordinate of gyroscope bias expressed in (rad^2/s^2).- Returns:
- variance of estimated x coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasXStandardDeviation
Gets standard deviation of estimated x coordinate of gyroscope bias expressed in radians per second (rad/s).- Returns:
- standard deviation of estimated x coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasXStandardDeviationAsAngularSpeed
public com.irurueta.units.AngularSpeed getEstimatedBiasXStandardDeviationAsAngularSpeed()Gets standard deviation of estimated x coordinate of gyroscope bias.- Returns:
- standard deviation of estimated x coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasXStandardDeviationAsAngularSpeed
public boolean getEstimatedBiasXStandardDeviationAsAngularSpeed(com.irurueta.units.AngularSpeed result) Gets standard deviation of estimated x coordinate of gyroscope bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if standard deviation of estimated x coordinate of gyroscope bias is available, false otherwise.
-
getEstimatedBiasYVariance
Gets variance of estimated y coordinate of gyroscope bias expressed in (rad^2/s^2).- Returns:
- variance of estimated y coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasYStandardDeviation
Gets standard deviation of estimated y coordinate of gyroscope bias expressed in radians per second (rad/s).- Returns:
- standard deviation of estimated y coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasYStandardDeviationAsAngularSpeed
public com.irurueta.units.AngularSpeed getEstimatedBiasYStandardDeviationAsAngularSpeed()Gets standard deviation of estimated y coordinate of gyroscope bias.- Returns:
- standard deviation of estimated y coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasYStandardDeviationAsAngularSpeed
public boolean getEstimatedBiasYStandardDeviationAsAngularSpeed(com.irurueta.units.AngularSpeed result) Gets standard deviation of estimated y coordinate of gyroscope bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if standard deviation of estimated y coordinate of gyroscope bias is available, false otherwise.
-
getEstimatedBiasZVariance
Gets variance of estimated z coordinate of gyroscope bias expressed in (rad^2/s^2).- Returns:
- variance of estimated z coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasZStandardDeviation
Gets standard deviation of estimated z coordinate of gyroscope bias expressed in radians per second (rad/s).- Returns:
- standard deviation of estimated z coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasZStandardDeviationAsAngularSpeed
public com.irurueta.units.AngularSpeed getEstimatedBiasZStandardDeviationAsAngularSpeed()Gets standard deviation of estimated z coordinate of gyroscope bias.- Returns:
- standard deviation of estimated z coordinate of gyroscope bias or null if not available.
-
getEstimatedBiasZStandardDeviationAsAngularSpeed
public boolean getEstimatedBiasZStandardDeviationAsAngularSpeed(com.irurueta.units.AngularSpeed result) Gets standard deviation of estimated z coordinate of gyroscope bias.- Parameters:
result
- instance where result will be stored.- Returns:
- true if standard deviation of estimated z coordinate of gyroscope bias is available, false otherwise.
-
getEstimatedBiasStandardDeviation
Gets standard deviation of estimated gyroscope bias coordinates.- Returns:
- standard deviation of estimated gyroscope bias coordinates.
-
getEstimatedBiasStandardDeviationAverage
Gets average of estimated standard deviation of gyroscope bias coordinates expressed in radians per second (rad/s).- Returns:
- average of estimated standard deviation of gyroscope bias coordinates or null if not available.
-
getEstimatedBiasStandardDeviationAverageAsAngularSpeed
public com.irurueta.units.AngularSpeed getEstimatedBiasStandardDeviationAverageAsAngularSpeed()Gets average of estimated standard deviation of gyroscope bias coordinates.- Returns:
- average of estimated standard deviation of gyroscope bias coordinates or null.
-
getEstimatedBiasStandardDeviationAverageAsAngularSpeed
public boolean getEstimatedBiasStandardDeviationAverageAsAngularSpeed(com.irurueta.units.AngularSpeed result) Gets average of estimated standard deviation of gyroscope bias coordinates.- Parameters:
result
- instance where result will be stored.- Returns:
- true if average of estimated standard deviation of gyroscope bias is available, false otherwise.
-
getEstimatedBiasStandardDeviationNorm
Gets norm of estimated standard deviation of gyroscope bias expressed in radians per second (rad/s). This can be used as the initial gyroscope bias uncertainty forINSLooselyCoupledKalmanInitializerConfig
orINSTightlyCoupledKalmanInitializerConfig
.- Specified by:
getEstimatedBiasStandardDeviationNorm
in interfaceGyroscopeBiasUncertaintySource
- Returns:
- norm of estimated standard deviation of gyroscope bias or null if not available.
-
getEstimatedBiasStandardDeviationNormAsAngularSpeed
public com.irurueta.units.AngularSpeed getEstimatedBiasStandardDeviationNormAsAngularSpeed()Gets norm of estimated standard deviation of gyroscope bias. This can be used as the initial gyroscope bias uncertainty forINSLooselyCoupledKalmanInitializerConfig
orINSTightlyCoupledKalmanInitializerConfig
.- Returns:
- norm of estimated standard deviation of gyroscope bias or null if not available.
-
getEstimatedBiasStandardDeviationNormAsAngularSpeed
public boolean getEstimatedBiasStandardDeviationNormAsAngularSpeed(com.irurueta.units.AngularSpeed result) Gets norm of estimated standard deviation of gyroscope bias coordinates. This can be used as the initial gyroscope bias uncertainty forINSLooselyCoupledKalmanInitializerConfig
orINSTightlyCoupledKalmanInitializerConfig
.- Parameters:
result
- instance where result will be stored.- Returns:
- true if norm of estimated standard deviation of gyroscope bias is available, false otherwise.
-
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.algebra.AlgebraException
- if there are numerical errors.com.irurueta.numerical.fitting.FittingException
- if no convergence to solution is found.com.irurueta.numerical.NotReadyException
- if fitter is not ready.
-
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.algebra.AlgebraException
- if there are numerical errors.com.irurueta.numerical.fitting.FittingException
- if no convergence to solution is found.com.irurueta.numerical.NotReadyException
- if fitter is not ready.
-
setInputData
private void setInputData() throws com.irurueta.algebra.WrongSizeExceptionSets input data into Levenberg-Marquardt fitter.- Throws:
com.irurueta.algebra.WrongSizeException
- never happens.
-
convertAngularSpeed
private static double convertAngularSpeed(double value, com.irurueta.units.AngularSpeedUnit unit) Converts angular speed value and unit to radians per second.- Parameters:
value
- angular speed value.unit
- unit of angular speed value.- Returns:
- converted value.
-
convertAngularSpeed
private static double convertAngularSpeed(com.irurueta.units.AngularSpeed angularSpeed) Converts angular speed instance to radians per second.- Parameters:
angularSpeed
- angular speed instance to be converted.- Returns:
- converted value.
-