Class RobustTurntableGyroscopeCalibrator
- All Implemented Interfaces:
AccelerometerDependentGyroscopeCalibrator
,GyroscopeCalibrator
,GyroscopeNonLinearCalibrator
,OrderedStandardDeviationBodyKinematicsGyroscopeCalibrator
,QualityScoredGyroscopeCalibrator
,UnknownBiasGyroscopeCalibrator
,GyroscopeBiasUncertaintySource
,GyroscopeCalibrationSource
- Direct Known Subclasses:
LMedSRobustTurntableGyroscopeCalibrator
,MSACRobustTurntableGyroscopeCalibrator
,PROMedSRobustTurntableGyroscopeCalibrator
,PROSACRobustTurntableGyroscopeCalibrator
,RANSACRobustTurntableGyroscopeCalibrator
This calibrator assumes that the IMU is placed flat on a turntable spinning at constant speed, but absolute orientation or position of IMU is unknown. Turntable must rotate fast enough so that Earth rotation effects can be neglected, bus slow enough so that gyroscope readings can be properly made.
To use this calibrator at least 10 measurements are needed when common z-axis is assumed and G-dependent cross biases are ignored, otherwise at least 13 measurements are required when common z-axis is not assumed. If G-dependent cross biases are being estimated, then at least 19 measurements are needed when common z-axis is assumed, otherwise at least 22 measurements are required when common z-axis is not assumed.
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.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprotected static class
Internal class containing estimated preliminary result. -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate double
Known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer x-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Know accelerometer x-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer y-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer y-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer z-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer z-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer x scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer y scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.private double
Known accelerometer z scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.private boolean
This flag indicates whether z-axis is assumed to be common for accelerometer and gyroscope.protected double
Amount of confidence expressed as a value between 0.0 and 1.0 (which is equivalent to 100%).static final double
Constant defining default confidence of the estimated result, which is 99%.static final boolean
Indicates that by default G-dependent cross biases introduced by the accelerometer on the gyroscope are estimated.static final boolean
Indicates that covariance is kept by default after refining result.static final int
Default maximum allowed number of iterations.static final float
Default amount of progress variation before notifying a change in estimation progress.static final boolean
Indicates that result is refined by default using a non-linear calibrator (which uses a Levenberg-Marquardt fitter).static final com.irurueta.numerical.robust.RobustEstimatorMethod
Default robust estimator method when none is provided.static final double
Default time interval between measurements expressed in seconds (s).static final double
Default turntable rotation rate.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 boolean
This flag indicates whether G-dependent cross biases are being estimated or not.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 gyroscope x-y cross coupling error.private double
Initial gyroscope x-z cross coupling error.private double
Initial gyroscope y-x cross coupling error.private double
Initial gyroscope y-z cross coupling error.private double
Initial gyroscope z-x cross coupling error.private double
Initial gyroscope z-y cross coupling error.private double
Initial gyroscope x scaling factor.private double
Initial gyroscope y scaling factor.private double
Initial gyroscope z scaling factor.protected com.irurueta.numerical.robust.InliersData
Data related to inliers found after calibration.private final TurntableGyroscopeCalibrator
Inner non-robust calibrator.private boolean
Indicates whether covariance must be kept after refining result.Listener to be notified of events such as when calibration starts, ends or its progress significantly changes.static final double
Maximum allowed confidence value.static final float
Maximum allowed value for progress delta.protected int
Maximum allowed number of iterations.protected List<StandardDeviationBodyKinematics>
Contains a collection of body kinematics measurements taken at a given position with different unknown orientations and containing the standard deviations of accelerometer and gyroscope measurements.static final double
Minimum allowed confidence value.static final int
Minimum allowed number of iterations.static final float
Minimum allowed value for progress delta.private com.irurueta.navigation.frames.ECEFPosition
Position where body kinematics measures have been taken.protected int
Size of subsets to be checked during robust estimation.protected float
Amount of progress variation before notifying a progress change during calibration.protected boolean
Indicates whether result must be refined using a non linear calibrator over found inliers.protected boolean
Indicates whether calibrator is running.private double
Time interval between measurements being captured expressed in second (s).private double
Constant rotation rate at which the turntable is spinning. -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Constructor.protected
RobustTurntableGyroscopeCalibrator
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionprotected void
attemptRefine
(RobustTurntableGyroscopeCalibrator.PreliminaryResult preliminaryResult) Attempts to refine calibration parameters if refinement is requested.protected double
computeError
(StandardDeviationBodyKinematics measurement, RobustTurntableGyroscopeCalibrator.PreliminaryResult preliminaryResult) Computes error of a preliminary result respect a given measurement.protected void
computePreliminarySolutions
(int[] samplesIndices, List<RobustTurntableGyroscopeCalibrator.PreliminaryResult> solutions) Computes a preliminary solution for a subset of samples picked by a robust estimator.private static double
convertAcceleration
(com.irurueta.units.Acceleration acceleration) Converts acceleration instance to meters per squared second.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.private static com.irurueta.navigation.frames.ECEFPosition
convertPosition
(com.irurueta.navigation.frames.NEDPosition position) Converts provided NED position expressed in terms of latitude, longitude and height respect mean Earth surface, to position expressed in ECEF coordinates.private static double
convertTime
(com.irurueta.units.Time time) Converts time instance to seconds.create()
Creates a robust gyroscope calibrator using default robust method.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(double[] qualityScores, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.ECEFPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, boolean commonAxisUsed, boolean estimateGDependentCrossBiases, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, double[] accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, double[] initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.algebra.Matrix accelerometerBias, com.irurueta.algebra.Matrix accelerometerMa, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener) Creates a robust gyroscope calibrator using default robust method.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, RobustTurntableGyroscopeCalibratorListener listener, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.navigation.frames.NEDPosition position, double turntableRotationRate, double timeInterval, List<StandardDeviationBodyKinematics> measurements, com.irurueta.algebra.Matrix initialBias, com.irurueta.algebra.Matrix initialMg, com.irurueta.algebra.Matrix initialGg, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.create
(com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.double[]
Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
getAccelerometerBias
(double[] result) Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.com.irurueta.algebra.Matrix
Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
getAccelerometerBiasAsMatrix
(com.irurueta.algebra.Matrix result) Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.com.irurueta.units.Acceleration
Gets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
getAccelerometerBiasXAsAcceleration
(com.irurueta.units.Acceleration result) Gets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.com.irurueta.units.Acceleration
Gets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
getAccelerometerBiasYAsAcceleration
(com.irurueta.units.Acceleration result) Gets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.com.irurueta.units.Acceleration
Gets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
getAccelerometerBiasZAsAcceleration
(com.irurueta.units.Acceleration result) Gets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.com.irurueta.algebra.Matrix
Gets known accelerometer scale factors and cross coupling errors matrix.void
getAccelerometerMa
(com.irurueta.algebra.Matrix result) Gets known accelerometer scale factors and cross coupling errors matrix.double
Gets known accelerometer x-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer x-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer y-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer y-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer z-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer z-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer x scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer y scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Gets known accelerometer z scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.double
Returns amount of confidence expressed as a value between 0.0 and 1.0 (which is equivalent to 100%).com.irurueta.navigation.frames.ECEFPosition
Gets position where body kinematics measures have been taken expressed in ECEF coordinates.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 gyroscope x-y cross-coupling error.Gets estimated gyroscope x-z cross-coupling error.Gets estimated gyroscope y-x cross-coupling error.Gets estimated gyroscope y-z cross-coupling error.Gets estimated gyroscope z-x cross-coupling error.Gets estimated gyroscope z-y cross-coupling error.Gets estimated gyroscope x-axis scale factor.Gets estimated gyroscope y-axis scale factor.Gets estimated gyroscope z-axis scale factor.double[]
Gets initial gyroscope bias to be used to find a solution as an array.void
getInitialBias
(double[] result) Gets initial gyroscope 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 gyroscope bias to be used to find a solution as a column matrix.void
getInitialBiasAsMatrix
(com.irurueta.algebra.Matrix result) Gets initial gyroscope 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 ot 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 gyroscope scale factors and cross coupling errors matrix.void
getInitialMg
(com.irurueta.algebra.Matrix result) Gets initial gyroscope scale factors and cross coupling errors matrix.double
Gets initial x-y cross coupling error of gyroscope.double
Gets initial x-z cross coupling error of gyroscope.double
Gets initial y-x cross coupling error of gyroscope.double
Gets initial y-z cross coupling error of gyroscope.double
Gets initial z-x cross coupling error of gyroscope.double
Gets initial z-y cross coupling error of gyroscope.double
Gets initial x scaling factor of gyroscope.double
Gets initial y scaling factor of gyroscope.double
Gets initial z scaling factor of gyroscope.com.irurueta.numerical.robust.InliersData
Gets data related to inliers found after estimation.Gets listener to handle events raised by this estimator.int
Returns maximum allowed number of iterations.Indicates the type of measurement or sequence used by this calibrator.Gets a collection of body kinematics measurements taken at a given position with different unknown orientations and containing the standard deviations of accelerometer and gyroscope measurements.abstract com.irurueta.numerical.robust.RobustEstimatorMethod
Returns method being used for robust estimation.int
Gets minimum number of required measurements.com.irurueta.navigation.frames.NEDPosition
Gets position where body kinematics measures have been taken expressed in NED coordinates.boolean
getNedPosition
(com.irurueta.navigation.frames.NEDPosition result) Gets position where body kinematics measures have been taken expressed in NED coordinates.int
Gets size of subsets to be checked during robust estimation.float
Returns amount of progress variation before notifying a progress change during calibration.double[]
Returns quality scores corresponding to each measurement.double
Gets time interval between measurements being captured expressed in seconds (s).com.irurueta.units.Time
Gets time interval between measurements being captured.void
getTimeIntervalAsTime
(com.irurueta.units.Time result) Gets time interval between measurements being captured.double
Gets constant rotation rate at which the turntable is spinning.com.irurueta.units.AngularSpeed
Gets constant rotation rate at which the turntable is spinning.void
getTurntableRotationRateAsAngularSpeed
(com.irurueta.units.AngularSpeed result) Gets constant rotation rate at which the turntable is spinning.boolean
Indicates whether z-axis is assumed to be common for accelerometer and gyroscope.boolean
Indicates whether covariance must be kept after refining result.boolean
Indicates whether G-dependent cross biases are being estimated or not.boolean
Indicates whether this calibrator requires ordered measurements or sequences in a list or not.boolean
isReady()
Indicates whether calibrator is ready to start.boolean
Indicates whether result must be refined using a non-linear solver over found inliers.boolean
Indicates whether calibrator is currently running or not.void
setAccelerometerBias
(double[] accelerometerBias) Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBias
(double accelerometerBiasX, double accelerometerBiasY, double accelerometerBiasZ) Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBias
(com.irurueta.algebra.Matrix accelerometerBias) Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBias
(com.irurueta.units.Acceleration accelerometerBiasX, com.irurueta.units.Acceleration accelerometerBiasY, com.irurueta.units.Acceleration accelerometerBiasZ) Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBiasX
(double accelerometerBiasX) Sets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBiasX
(com.irurueta.units.Acceleration accelerometerBiasX) Sets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBiasY
(double accelerometerBiasY) Sets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBiasY
(com.irurueta.units.Acceleration accelerometerBiasY) Sets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBiasZ
(double accelerometerBiasZ) Sets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerBiasZ
(com.irurueta.units.Acceleration accelerometerBiasZ) Sets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerCrossCouplingErrors
(double accelerometerMxy, double accelerometerMxz, double accelerometerMyx, double accelerometerMyz, double accelerometerMzx, double accelerometerMzy) Sets known accelerometer cross coupling errors to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerMa
(com.irurueta.algebra.Matrix accelerometerMa) Sets known accelerometer scale factors and cross coupling errors matrix.void
setAccelerometerMxy
(double accelerometerMxy) Sets known accelerometer x-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerMxz
(double accelerometerMxz) Sets known accelerometer x-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerMyx
(double accelerometerMyx) Sets known accelerometer y-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerMyz
(double accelerometerMyz) Sets known accelerometer y-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerMzx
(double accelerometerMzx) Sets known accelerometer z-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerMzy
(double accelerometerMzy) Sets known accelerometer z-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerScalingFactors
(double accelerometerSx, double accelerometerSy, double accelerometerSz) Sets known accelerometer scaling factors to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerScalingFactorsAndCrossCouplingErrors
(double accelerometerSx, double accelerometerSy, double accelerometerSz, double accelerometerMxy, double accelerometerMxz, double accelerometerMyx, double accelerometerMyz, double accelerometerMzx, double accelerometerMzy) Sets known accelerometer scaling factors and cross coupling errors to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerSx
(double accelerometerSx) Sets known accelerometer x scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerSy
(double accelerometerSy) Sets known accelerometer y scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setAccelerometerSz
(double accelerometerSz) Sets known accelerometer z scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.void
setCommonAxisUsed
(boolean commonAxisUsed) Specifies whether z-axis is assumed to be common for accelerometer and gyroscope.void
setConfidence
(double confidence) Sets amount of confidence expressed as a value between 0.0 and 1.0 (which is equivalent to 100%).void
setCovarianceKept
(boolean keepCovariance) Specifies whether covariance must be kept after refining result.void
setGDependentCrossBiasesEstimated
(boolean estimateGDependentCrossBiases) Specifies whether G-dependent cross biases are being estimated or not.void
setInitialBias
(double[] initialBias) Sets initial gyroscope 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 gyroscope 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 of gyroscope.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 gyroscope scale factors and cross coupling errors matrix.void
setInitialMxy
(double initialMxy) Sets initial x-y cross coupling error of gyroscope.void
setInitialMxz
(double initialMxz) Sets initial x-z cross coupling error of gyroscope.void
setInitialMyx
(double initialMyx) Sets initial y-x cross coupling error of gyroscope.void
setInitialMyz
(double initialMyz) Sets initial y-z cross coupling error of gyroscope.void
setInitialMzx
(double initialMzx) Sets initial z-x cross coupling error of gyroscope.void
setInitialMzy
(double initialMzy) Sets initial z-y cross coupling error of gyroscope.void
setInitialScalingFactors
(double initialSx, double initialSy, double initialSz) Sets initial scaling factors of gyroscope.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 of gyroscope.void
setInitialSx
(double initialSx) Sets initial x scaling factor of gyroscope.void
setInitialSy
(double initialSy) Sets initial y scaling factor of gyroscope.void
setInitialSz
(double initialSz) Sets initial z scaling factor of gyroscope.void
Sets listener to handle events raised by this estimator.void
setMaxIterations
(int maxIterations) Sets maximum allowed number of iterations.void
setMeasurements
(List<StandardDeviationBodyKinematics> measurements) Sets a collection of body kinematics measurements taken at a given position with different unknown orientations and containing the standard deviations of accelerometer and gyroscope measurements.void
setPosition
(com.irurueta.navigation.frames.ECEFPosition position) Gets position where body kinematics measures have been taken expressed in ECEF coordinates.void
setPosition
(com.irurueta.navigation.frames.NEDPosition position) Sets position where body kinematics measures have been taken expressed in NED coordinates.void
setPreliminarySubsetSize
(int preliminarySubsetSize) Sets size of subsets to be checked during robust estimation.void
setProgressDelta
(float progressDelta) Sets amount of progress variation before notifying a progress change during calibration.void
setQualityScores
(double[] qualityScores) Sets quality scores corresponding to each measurement.void
setResultRefined
(boolean refineResult) Specifies whether result must be refined using a non-linear solver over found inliers.void
setTimeInterval
(double timeInterval) Sets time interval between measurements being captured expressed in seconds (s).void
setTimeInterval
(com.irurueta.units.Time timeInterval) Sets time interval between measurements being captured.void
setTurntableRotationRate
(double turntableRotationRate) Sets constant rotation rate at which the turntable is spinning.void
setTurntableRotationRate
(com.irurueta.units.AngularSpeed turntableRotationRate) Sets constant rotation rate at which the turntable is spinning.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeCalibrator
calibrate, isQualityScoresRequired
-
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:
-
DEFAULT_ESTIMATE_G_DEPENDENT_CROSS_BIASES
public static final boolean DEFAULT_ESTIMATE_G_DEPENDENT_CROSS_BIASESIndicates that by default G-dependent cross biases introduced by the accelerometer on the gyroscope are estimated.- See Also:
-
DEFAULT_TURNTABLE_ROTATION_RATE
public static final double DEFAULT_TURNTABLE_ROTATION_RATEDefault turntable rotation rate.- See Also:
-
DEFAULT_TIME_INTERVAL
public static final double DEFAULT_TIME_INTERVALDefault time interval between measurements expressed in seconds (s). This is a typical value when we have 50 samples per second.- See Also:
-
DEFAULT_ROBUST_METHOD
public static final com.irurueta.numerical.robust.RobustEstimatorMethod DEFAULT_ROBUST_METHODDefault robust estimator method when none is provided. -
DEFAULT_REFINE_RESULT
public static final boolean DEFAULT_REFINE_RESULTIndicates that result is refined by default using a non-linear calibrator (which uses a Levenberg-Marquardt fitter).- See Also:
-
DEFAULT_KEEP_COVARIANCE
public static final boolean DEFAULT_KEEP_COVARIANCEIndicates that covariance is kept by default after refining result.- See Also:
-
DEFAULT_PROGRESS_DELTA
public static final float DEFAULT_PROGRESS_DELTADefault amount of progress variation before notifying a change in estimation progress. By default this is set to 5%.- See Also:
-
MIN_PROGRESS_DELTA
public static final float MIN_PROGRESS_DELTAMinimum allowed value for progress delta.- See Also:
-
MAX_PROGRESS_DELTA
public static final float MAX_PROGRESS_DELTAMaximum allowed value for progress delta.- See Also:
-
DEFAULT_CONFIDENCE
public static final double DEFAULT_CONFIDENCEConstant defining default confidence of the estimated result, which is 99%. This means that with a probability of 99% estimation will be accurate because chosen sub-samples will be inliers.- See Also:
-
DEFAULT_MAX_ITERATIONS
public static final int DEFAULT_MAX_ITERATIONSDefault maximum allowed number of iterations.- See Also:
-
MIN_CONFIDENCE
public static final double MIN_CONFIDENCEMinimum allowed confidence value.- See Also:
-
MAX_CONFIDENCE
public static final double MAX_CONFIDENCEMaximum allowed confidence value.- See Also:
-
MIN_ITERATIONS
public static final int MIN_ITERATIONSMinimum allowed number of iterations.- See Also:
-
accelerometerBiasX
private double accelerometerBiasXKnown x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2). -
accelerometerBiasY
private double accelerometerBiasYKnown y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2). -
accelerometerBiasZ
private double accelerometerBiasZKnown z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2). -
accelerometerSx
private double accelerometerSxKnown accelerometer x scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerSy
private double accelerometerSyKnown accelerometer y scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerSz
private double accelerometerSzKnown accelerometer z scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerMxy
private double accelerometerMxyKnown accelerometer x-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerMxz
private double accelerometerMxzKnow accelerometer x-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerMyx
private double accelerometerMyxKnown accelerometer y-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerMyz
private double accelerometerMyzKnown accelerometer y-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerMzx
private double accelerometerMzxKnown accelerometer z-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
accelerometerMzy
private double accelerometerMzyKnown accelerometer z-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer. -
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 gyroscope x scaling factor. -
initialSy
private double initialSyInitial gyroscope y scaling factor. -
initialSz
private double initialSzInitial gyroscope z scaling factor. -
initialMxy
private double initialMxyInitial gyroscope x-y cross coupling error. -
initialMxz
private double initialMxzInitial gyroscope x-z cross coupling error. -
initialMyx
private double initialMyxInitial gyroscope y-x cross coupling error. -
initialMyz
private double initialMyzInitial gyroscope y-z cross coupling error. -
initialMzx
private double initialMzxInitial gyroscope z-x cross coupling error. -
initialMzy
private double initialMzyInitial gyroscope 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. -
turntableRotationRate
private double turntableRotationRateConstant rotation rate at which the turntable is spinning. This is expressed in radians per second (rad/s). -
timeInterval
private double timeIntervalTime interval between measurements being captured expressed in second (s). -
measurements
Contains a collection of body kinematics measurements taken at a given position with different unknown orientations and containing the standard deviations of accelerometer and gyroscope measurements. -
position
private com.irurueta.navigation.frames.ECEFPosition positionPosition where body kinematics measures have been taken. -
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 Mg matrix. -
estimateGDependentCrossBiases
private boolean estimateGDependentCrossBiasesThis flag indicates whether G-dependent cross biases are being estimated or not. When enabled, this adds 9 variables from Gg matrix. -
listener
Listener to be notified of events such as when calibration starts, ends or its progress significantly changes. -
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
protected boolean runningIndicates whether calibrator is running. -
progressDelta
protected float progressDeltaAmount of progress variation before notifying a progress change during calibration. -
confidence
protected double confidenceAmount of confidence expressed as a value between 0.0 and 1.0 (which is equivalent to 100%). The amount of confidence indicates the probability that the estimated result is correct. Usually this value will be close to 1.0, but not exactly 1.0. -
maxIterations
protected int maxIterationsMaximum allowed number of iterations. When the maximum number of iterations is exceeded, result will not be available, however an approximate result will be available for retrieval. -
inliersData
protected com.irurueta.numerical.robust.InliersData inliersDataData related to inliers found after calibration. -
refineResult
protected boolean refineResultIndicates whether result must be refined using a non linear calibrator over found inliers. If true, inliers will be computed and kept in any implementation regardless of the settings. -
preliminarySubsetSize
protected int preliminarySubsetSizeSize of subsets to be checked during robust estimation. -
keepCovariance
private boolean keepCovarianceIndicates whether covariance must be kept after refining result. This setting is only taken into account if result is refined. -
innerCalibrator
Inner non-robust calibrator.
-
-
Constructor Details
-
RobustTurntableGyroscopeCalibrator
protected RobustTurntableGyroscopeCalibrator()Constructor.
-
-
Method Details
-
getAccelerometerBiasX
public double getAccelerometerBiasX()Gets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBiasX
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known x-coordinate of accelerometer bias.
-
setAccelerometerBiasX
public void setAccelerometerBiasX(double accelerometerBiasX) throws com.irurueta.navigation.LockedException Sets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
setAccelerometerBiasX
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasX
- known x-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerBiasY
public double getAccelerometerBiasY()Gets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBiasY
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known y-coordinate of accelerometer bias.
-
setAccelerometerBiasY
public void setAccelerometerBiasY(double accelerometerBiasY) throws com.irurueta.navigation.LockedException Sets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
setAccelerometerBiasY
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasY
- known y-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerBiasZ
public double getAccelerometerBiasZ()Gets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBiasZ
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known z-coordinate of accelerometer bias.
-
setAccelerometerBiasZ
public void setAccelerometerBiasZ(double accelerometerBiasZ) throws com.irurueta.navigation.LockedException Sets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
setAccelerometerBiasZ
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasZ
- known z-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerBiasXAsAcceleration
public com.irurueta.units.Acceleration getAccelerometerBiasXAsAcceleration()Gets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerBiasXAsAcceleration
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known x-coordinate of accelerometer bias.
-
getAccelerometerBiasXAsAcceleration
public void getAccelerometerBiasXAsAcceleration(com.irurueta.units.Acceleration result) Gets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerBiasXAsAcceleration
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
result
- instance where result data will be stored.
-
setAccelerometerBiasX
public void setAccelerometerBiasX(com.irurueta.units.Acceleration accelerometerBiasX) throws com.irurueta.navigation.LockedException Sets known x-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerBiasX
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasX
- x-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerBiasYAsAcceleration
public com.irurueta.units.Acceleration getAccelerometerBiasYAsAcceleration()Gets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerBiasYAsAcceleration
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known y-coordinate of accelerometer bias.
-
getAccelerometerBiasYAsAcceleration
public void getAccelerometerBiasYAsAcceleration(com.irurueta.units.Acceleration result) Gets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerBiasYAsAcceleration
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
result
- instance where result data will be stored.
-
setAccelerometerBiasY
public void setAccelerometerBiasY(com.irurueta.units.Acceleration accelerometerBiasY) throws com.irurueta.navigation.LockedException Sets known y-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerBiasY
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasY
- y-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerBiasZAsAcceleration
public com.irurueta.units.Acceleration getAccelerometerBiasZAsAcceleration()Gets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerBiasZAsAcceleration
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known z-coordinate of accelerometer bias.
-
getAccelerometerBiasZAsAcceleration
public void getAccelerometerBiasZAsAcceleration(com.irurueta.units.Acceleration result) Gets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerBiasZAsAcceleration
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
result
- instance where result data will be stored.
-
setAccelerometerBiasZ
public void setAccelerometerBiasZ(com.irurueta.units.Acceleration accelerometerBiasZ) throws com.irurueta.navigation.LockedException Sets known z-coordinate of accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerBiasZ
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasZ
- z-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setAccelerometerBias
public void setAccelerometerBias(double accelerometerBiasX, double accelerometerBiasY, double accelerometerBiasZ) throws com.irurueta.navigation.LockedException Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
setAccelerometerBias
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasX
- x-coordinate of accelerometer bias.accelerometerBiasY
- y-coordinate of accelerometer bias.accelerometerBiasZ
- z-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setAccelerometerBias
public void setAccelerometerBias(com.irurueta.units.Acceleration accelerometerBiasX, com.irurueta.units.Acceleration accelerometerBiasY, com.irurueta.units.Acceleration accelerometerBiasZ) throws com.irurueta.navigation.LockedException Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerBias
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBiasX
- x-coordinate of accelerometer bias.accelerometerBiasY
- y-coordinate of accelerometer bias.accelerometerBiasZ
- z-coordinate of accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerBias
public double[] getAccelerometerBias()Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBias
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer bias.
-
getAccelerometerBias
public void getAccelerometerBias(double[] result) Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBias
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
result
- instance where result data will be copied to.- Throws:
IllegalArgumentException
- if provided array does not have length 3.
-
setAccelerometerBias
public void setAccelerometerBias(double[] accelerometerBias) throws com.irurueta.navigation.LockedException Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
setAccelerometerBias
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBias
- known accelerometer bias.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided array does not have length 3.
-
getAccelerometerBiasAsMatrix
public com.irurueta.algebra.Matrix getAccelerometerBiasAsMatrix()Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBiasAsMatrix
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer bias.
-
getAccelerometerBiasAsMatrix
public void getAccelerometerBiasAsMatrix(com.irurueta.algebra.Matrix result) Gets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
getAccelerometerBiasAsMatrix
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
result
- instance where result data will be copied to.- Throws:
IllegalArgumentException
- if provided matrix is not 3x1.
-
setAccelerometerBias
public void setAccelerometerBias(com.irurueta.algebra.Matrix accelerometerBias) throws com.irurueta.navigation.LockedException Sets known accelerometer bias to be used to fix measured specific force and find cross biases introduced by the accelerometer. This is expressed in meters per squared second (m/s^2).- Specified by:
setAccelerometerBias
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerBias
- known accelerometer bias. Must be 3x1.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided matrix is not 3x1.
-
getAccelerometerSx
public double getAccelerometerSx()Gets known accelerometer x scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerSx
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer x scaling factor.
-
setAccelerometerSx
public void setAccelerometerSx(double accelerometerSx) throws com.irurueta.navigation.LockedException Sets known accelerometer x scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerSx
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerSx
- known accelerometer x scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerSy
public double getAccelerometerSy()Gets known accelerometer y scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerSy
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer y scaling factor.
-
setAccelerometerSy
public void setAccelerometerSy(double accelerometerSy) throws com.irurueta.navigation.LockedException Sets known accelerometer y scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerSy
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerSy
- known accelerometer y scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerSz
public double getAccelerometerSz()Gets known accelerometer z scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerSz
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer z scaling factor.
-
setAccelerometerSz
public void setAccelerometerSz(double accelerometerSz) throws com.irurueta.navigation.LockedException Sets known accelerometer z scaling factor to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerSz
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerSz
- known accelerometer z scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMxy
public double getAccelerometerMxy()Gets known accelerometer x-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerMxy
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer x-y cross coupling error.
-
setAccelerometerMxy
public void setAccelerometerMxy(double accelerometerMxy) throws com.irurueta.navigation.LockedException Sets known accelerometer x-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerMxy
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMxy
- known accelerometer x-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMxz
public double getAccelerometerMxz()Gets known accelerometer x-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerMxz
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer x-z cross coupling error.
-
setAccelerometerMxz
public void setAccelerometerMxz(double accelerometerMxz) throws com.irurueta.navigation.LockedException Sets known accelerometer x-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerMxz
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMxz
- known accelerometer x-z cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMyx
public double getAccelerometerMyx()Gets known accelerometer y-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerMyx
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer y-x cross coupling error.
-
setAccelerometerMyx
public void setAccelerometerMyx(double accelerometerMyx) throws com.irurueta.navigation.LockedException Sets known accelerometer y-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerMyx
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMyx
- known accelerometer y-x cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMyz
public double getAccelerometerMyz()Gets known accelerometer y-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerMyz
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer y-z cross coupling error.
-
setAccelerometerMyz
public void setAccelerometerMyz(double accelerometerMyz) throws com.irurueta.navigation.LockedException Sets known accelerometer y-z cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerMyz
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMyz
- known accelerometer y-z cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMzx
public double getAccelerometerMzx()Gets known accelerometer z-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerMzx
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer z-x cross coupling error.
-
setAccelerometerMzx
public void setAccelerometerMzx(double accelerometerMzx) throws com.irurueta.navigation.LockedException Sets known accelerometer z-x cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerMzx
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMzx
- known accelerometer z-x cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMzy
public double getAccelerometerMzy()Gets known accelerometer z-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
getAccelerometerMzy
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer z-y cross coupling error.
-
setAccelerometerMzy
public void setAccelerometerMzy(double accelerometerMzy) throws com.irurueta.navigation.LockedException Sets known accelerometer z-y cross coupling error to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerMzy
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMzy
- known accelerometer z-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setAccelerometerScalingFactors
public void setAccelerometerScalingFactors(double accelerometerSx, double accelerometerSy, double accelerometerSz) throws com.irurueta.navigation.LockedException Sets known accelerometer scaling factors to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerScalingFactors
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerSx
- known accelerometer x scaling factor.accelerometerSy
- known accelerometer y scaling factor.accelerometerSz
- known accelerometer z scaling factor.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setAccelerometerCrossCouplingErrors
public void setAccelerometerCrossCouplingErrors(double accelerometerMxy, double accelerometerMxz, double accelerometerMyx, double accelerometerMyz, double accelerometerMzx, double accelerometerMzy) throws com.irurueta.navigation.LockedException Sets known accelerometer cross coupling errors to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerCrossCouplingErrors
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMxy
- known accelerometer x-y cross coupling error.accelerometerMxz
- known accelerometer x-z cross coupling error.accelerometerMyx
- known accelerometer y-x cross coupling error.accelerometerMyz
- known accelerometer y-z cross coupling error.accelerometerMzx
- known accelerometer z-x cross coupling error.accelerometerMzy
- known accelerometer z-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
setAccelerometerScalingFactorsAndCrossCouplingErrors
public void setAccelerometerScalingFactorsAndCrossCouplingErrors(double accelerometerSx, double accelerometerSy, double accelerometerSz, double accelerometerMxy, double accelerometerMxz, double accelerometerMyx, double accelerometerMyz, double accelerometerMzx, double accelerometerMzy) throws com.irurueta.navigation.LockedException Sets known accelerometer scaling factors and cross coupling errors to be used to fix measured specific force and find cross biases introduced by the accelerometer.- Specified by:
setAccelerometerScalingFactorsAndCrossCouplingErrors
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerSx
- known accelerometer x scaling factor.accelerometerSy
- known accelerometer y scaling factor.accelerometerSz
- known accelerometer z scaling factor.accelerometerMxy
- known accelerometer x-y cross coupling error.accelerometerMxz
- known accelerometer x-z cross coupling error.accelerometerMyx
- known accelerometer y-x cross coupling error.accelerometerMyz
- known accelerometer y-z cross coupling error.accelerometerMzx
- known accelerometer z-x cross coupling error.accelerometerMzy
- known accelerometer z-y cross coupling error.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getAccelerometerMa
public com.irurueta.algebra.Matrix getAccelerometerMa()Gets known accelerometer scale factors and cross coupling errors matrix.- Specified by:
getAccelerometerMa
in interfaceAccelerometerDependentGyroscopeCalibrator
- Returns:
- known accelerometer scale factors and cross coupling errors matrix.
-
getAccelerometerMa
public void getAccelerometerMa(com.irurueta.algebra.Matrix result) Gets known accelerometer scale factors and cross coupling errors matrix.- Specified by:
getAccelerometerMa
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
result
- instance where data will be stored.- Throws:
IllegalArgumentException
- if provided matrix is not 3x3.
-
setAccelerometerMa
public void setAccelerometerMa(com.irurueta.algebra.Matrix accelerometerMa) throws com.irurueta.navigation.LockedException Sets known accelerometer scale factors and cross coupling errors matrix.- Specified by:
setAccelerometerMa
in interfaceAccelerometerDependentGyroscopeCalibrator
- Parameters:
accelerometerMa
- known accelerometer scale factors and cross coupling errors matrix. Must be 3x3.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided matrix is not 3x3.
-
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).- 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).- 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).- 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).- 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 ot be used to find a solution. This is expressed in radians per second (rad/s).- 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).- 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.- 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.- 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.- 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.- 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.- 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.- 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.- 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.- 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.- 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).- 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.- 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 of gyroscope.- Specified by:
getInitialSx
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial x scaling factor of gyroscope.
-
setInitialSx
public void setInitialSx(double initialSx) throws com.irurueta.navigation.LockedException Sets initial x scaling factor of gyroscope.- Specified by:
setInitialSx
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialSx
- initial x scaling factor of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialSy
public double getInitialSy()Gets initial y scaling factor of gyroscope.- Specified by:
getInitialSy
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial y scaling factor of gyroscope.
-
setInitialSy
public void setInitialSy(double initialSy) throws com.irurueta.navigation.LockedException Sets initial y scaling factor of gyroscope.- Specified by:
setInitialSy
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialSy
- initial y scaling factor of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialSz
public double getInitialSz()Gets initial z scaling factor of gyroscope.- Specified by:
getInitialSz
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial z scaling factor of gyroscope.
-
setInitialSz
public void setInitialSz(double initialSz) throws com.irurueta.navigation.LockedException Sets initial z scaling factor of gyroscope.- Specified by:
setInitialSz
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialSz
- initial z scaling factor of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMxy
public double getInitialMxy()Gets initial x-y cross coupling error of gyroscope.- Specified by:
getInitialMxy
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial x-y cross coupling error of gyroscope.
-
setInitialMxy
public void setInitialMxy(double initialMxy) throws com.irurueta.navigation.LockedException Sets initial x-y cross coupling error of gyroscope.- Specified by:
setInitialMxy
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMxy
- initial x-y cross coupling error of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMxz
public double getInitialMxz()Gets initial x-z cross coupling error of gyroscope.- Specified by:
getInitialMxz
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial x-z cross coupling error of gyroscope.
-
setInitialMxz
public void setInitialMxz(double initialMxz) throws com.irurueta.navigation.LockedException Sets initial x-z cross coupling error of gyroscope.- Specified by:
setInitialMxz
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMxz
- initial x-z cross coupling error of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMyx
public double getInitialMyx()Gets initial y-x cross coupling error of gyroscope.- Specified by:
getInitialMyx
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial y-x cross coupling error of gyroscope.
-
setInitialMyx
public void setInitialMyx(double initialMyx) throws com.irurueta.navigation.LockedException Sets initial y-x cross coupling error of gyroscope.- Specified by:
setInitialMyx
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMyx
- initial y-x cross coupling error of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMyz
public double getInitialMyz()Gets initial y-z cross coupling error of gyroscope.- Specified by:
getInitialMyz
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial y-z cross coupling error of gyroscope.
-
setInitialMyz
public void setInitialMyz(double initialMyz) throws com.irurueta.navigation.LockedException Sets initial y-z cross coupling error of gyroscope.- Specified by:
setInitialMyz
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMyz
- initial y-z cross coupling error of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMzx
public double getInitialMzx()Gets initial z-x cross coupling error of gyroscope.- Specified by:
getInitialMzx
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial z-x cross coupling error of gyroscope.
-
setInitialMzx
public void setInitialMzx(double initialMzx) throws com.irurueta.navigation.LockedException Sets initial z-x cross coupling error of gyroscope.- Specified by:
setInitialMzx
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMzx
- initial z-x cross coupling error of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialMzy
public double getInitialMzy()Gets initial z-y cross coupling error of gyroscope.- Specified by:
getInitialMzy
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial z-y cross coupling error of gyroscope.
-
setInitialMzy
public void setInitialMzy(double initialMzy) throws com.irurueta.navigation.LockedException Sets initial z-y cross coupling error of gyroscope.- Specified by:
setInitialMzy
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMzy
- initial z-y cross coupling error of gyroscope.- 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 of gyroscope.- Specified by:
setInitialScalingFactors
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialSx
- initial x scaling factor of gyroscope.initialSy
- initial y scaling factor of gyroscope.initialSz
- initial z scaling factor of gyroscope.- 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 of gyroscope.- Specified by:
setInitialCrossCouplingErrors
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialMxy
- initial x-y cross coupling error of gyroscope.initialMxz
- initial x-z cross coupling error of gyroscope.initialMyx
- initial y-x cross coupling error of gyroscope.initialMyz
- initial y-z cross coupling error of gyroscope.initialMzx
- initial z-x cross coupling error of gyroscope.initialMzy
- initial z-y cross coupling error of gyroscope.- 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 of gyroscope.- Specified by:
setInitialScalingFactorsAndCrossCouplingErrors
in interfaceGyroscopeNonLinearCalibrator
- Parameters:
initialSx
- initial x scaling factor of gyroscope.initialSy
- initial y scaling factor of gyroscope.initialSz
- initial z scaling factor of gyroscope.initialMxy
- initial x-y cross coupling error of gyroscope.initialMxz
- initial x-z cross coupling error of gyroscope.initialMyx
- initial y-x cross coupling error of gyroscope.initialMyz
- initial y-z cross coupling error of gyroscope.initialMzx
- initial z-x cross coupling error of gyroscope.initialMzy
- initial z-y cross coupling error of gyroscope.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInitialBias
public double[] getInitialBias()Gets initial gyroscope bias to be used to find a solution as an array. Array values are expressed in radians per second (rad/s).- Returns:
- array containing coordinates of initial gyroscope bias.
-
getInitialBias
public void getInitialBias(double[] result) Gets initial gyroscope bias to be used to find a solution as an array. Array values are expressed in radians per second (rad/s).- 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 gyroscope bias to be used to find a solution as an array. Array values are expressed in radians per second (rad/s).- 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 gyroscope bias to be used to find a solution as a column matrix. Values are expressed in radians per second (rad/s).- Returns:
- initial gyroscope bias to be used to find a solution as a column matrix.
-
getInitialBiasAsMatrix
public void getInitialBiasAsMatrix(com.irurueta.algebra.Matrix result) Gets initial gyroscope bias to be used to find a solution as a column matrix. Values are expressed in radians per second (rad/s).- 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 gyroscope bias to be used to find a solution as a column matrix with values expressed in radians per second (rad/s).- Parameters:
initialBias
- initial gyroscope 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.- Returns:
- initial bias coordinates.
-
getInitialMg
public com.irurueta.algebra.Matrix getInitialMg()Gets initial gyroscope scale factors and cross coupling errors matrix.- Specified by:
getInitialMg
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- initial gyroscope scale factors and cross coupling errors matrix.
-
getInitialMg
public void getInitialMg(com.irurueta.algebra.Matrix result) Gets initial gyroscope 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 gyroscope 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.
-
getTurntableRotationRate
public double getTurntableRotationRate()Gets constant rotation rate at which the turntable is spinning. This is expressed in radians per second (rad/s).- Returns:
- constant rotation rate of turntable.
-
setTurntableRotationRate
public void setTurntableRotationRate(double turntableRotationRate) throws com.irurueta.navigation.LockedException Sets constant rotation rate at which the turntable is spinning. This is expressed in radians per second (rad/s).- Parameters:
turntableRotationRate
- constant rotation rate of turntable.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently runningIllegalArgumentException
- if provided value is zero or negative.
-
getTurntableRotationRateAsAngularSpeed
public com.irurueta.units.AngularSpeed getTurntableRotationRateAsAngularSpeed()Gets constant rotation rate at which the turntable is spinning.- Returns:
- constant rotation rate of turntable.
-
getTurntableRotationRateAsAngularSpeed
public void getTurntableRotationRateAsAngularSpeed(com.irurueta.units.AngularSpeed result) Gets constant rotation rate at which the turntable is spinning.- Parameters:
result
- instance where result will be stored.
-
setTurntableRotationRate
public void setTurntableRotationRate(com.irurueta.units.AngularSpeed turntableRotationRate) throws com.irurueta.navigation.LockedException Sets constant rotation rate at which the turntable is spinning.- Parameters:
turntableRotationRate
- constant rotation rate of turntable.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided value is zero or negative.
-
getTimeInterval
public double getTimeInterval()Gets time interval between measurements being captured expressed in seconds (s).- Returns:
- time interval between measurements.
-
setTimeInterval
public void setTimeInterval(double timeInterval) throws com.irurueta.navigation.LockedException Sets time interval between measurements being captured expressed in seconds (s).- Parameters:
timeInterval
- time interval between measurements.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided value is zero or negative.
-
getTimeIntervalAsTime
public com.irurueta.units.Time getTimeIntervalAsTime()Gets time interval between measurements being captured.- Returns:
- time interval between measurements.
-
getTimeIntervalAsTime
public void getTimeIntervalAsTime(com.irurueta.units.Time result) Gets time interval between measurements being captured.- Parameters:
result
- instance where result will be stored.
-
setTimeInterval
public void setTimeInterval(com.irurueta.units.Time timeInterval) throws com.irurueta.navigation.LockedException Sets time interval between measurements being captured.- Parameters:
timeInterval
- time interval between measurements.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getMeasurements
Gets a collection of body kinematics measurements taken at a given position with different unknown orientations and containing the standard deviations of accelerometer and gyroscope measurements.- Specified by:
getMeasurements
in interfaceOrderedStandardDeviationBodyKinematicsGyroscopeCalibrator
- Returns:
- collection of body kinematics measurements at a known position with unknown orientations.
-
setMeasurements
public void setMeasurements(List<StandardDeviationBodyKinematics> measurements) throws com.irurueta.navigation.LockedException Sets a collection of body kinematics measurements taken at a given position with different unknown orientations and containing the standard deviations of accelerometer and gyroscope measurements.- Specified by:
setMeasurements
in interfaceOrderedStandardDeviationBodyKinematicsGyroscopeCalibrator
- Parameters:
measurements
- collection of body kinematics measurements at a known position with unknown orientations.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getEcefPosition
public com.irurueta.navigation.frames.ECEFPosition getEcefPosition()Gets position where body kinematics measures have been taken expressed in ECEF coordinates.- Returns:
- position where body kinematics measures have been taken.
-
getNedPosition
public com.irurueta.navigation.frames.NEDPosition getNedPosition()Gets position where body kinematics measures have been taken expressed in NED coordinates.- Returns:
- position where body kinematics measures have been taken or null if not available.
-
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.
-
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.
-
isGDependentCrossBiasesEstimated
public boolean isGDependentCrossBiasesEstimated()Indicates whether G-dependent cross biases are being estimated or not. When enabled, this adds 9 variables from Gg matrix.- Returns:
- true if G-dependent cross biases will be estimated, false otherwise.
-
setGDependentCrossBiasesEstimated
public void setGDependentCrossBiasesEstimated(boolean estimateGDependentCrossBiases) throws com.irurueta.navigation.LockedException Specifies whether G-dependent cross biases are being estimated or not. When enabled, this adds 9 variables from Gg matrix.- Parameters:
estimateGDependentCrossBiases
- true if G-dependent cross biases will be estimated, false otherwise.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getListener
Gets listener to handle events raised by this estimator.- 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.
-
getProgressDelta
public float getProgressDelta()Returns amount of progress variation before notifying a progress change during calibration.- Returns:
- amount of progress variation before notifying a progress change during calibration.
-
setProgressDelta
public void setProgressDelta(float progressDelta) throws com.irurueta.navigation.LockedException Sets amount of progress variation before notifying a progress change during calibration.- Parameters:
progressDelta
- amount of progress variation before notifying a progress change during calibration.- Throws:
IllegalArgumentException
- if progress delta is less than zero or greater than 1.com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getConfidence
public double getConfidence()Returns amount of confidence expressed as a value between 0.0 and 1.0 (which is equivalent to 100%). The amount of confidence indicates the probability that the estimated result is correct. Usually this value will be close to 1.0, but not exactly 1.0.- Returns:
- amount of confidence as a value between 0.0 and 1.0.
-
setConfidence
public void setConfidence(double confidence) throws com.irurueta.navigation.LockedException Sets amount of confidence expressed as a value between 0.0 and 1.0 (which is equivalent to 100%). The amount of confidence indicates the probability that the estimated result is correct. Usually this value will be close to 1.0, but not exactly 1.0.- Parameters:
confidence
- confidence to be set as a value between 0.0 and 1.0.- Throws:
IllegalArgumentException
- if provided value is not between 0.0 and 1.0.com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getMaxIterations
public int getMaxIterations()Returns maximum allowed number of iterations. If maximum allowed number of iterations is achieved without converging to a result when calling calibrate(), a RobustEstimatorException will be raised.- Returns:
- maximum allowed number of iterations.
-
setMaxIterations
public void setMaxIterations(int maxIterations) throws com.irurueta.navigation.LockedException Sets maximum allowed number of iterations. When the maximum number of iterations is exceeded, result will not be available, however an approximate result will be available for retrieval.- Parameters:
maxIterations
- maximum allowed number of iterations to be set.- Throws:
IllegalArgumentException
- if provided value is less than 1.com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getInliersData
public com.irurueta.numerical.robust.InliersData getInliersData()Gets data related to inliers found after estimation.- Returns:
- data related to inliers found after estimation.
-
isResultRefined
public boolean isResultRefined()Indicates whether result must be refined using a non-linear solver over found inliers.- Returns:
- true to refine result, false to simply use result found by robust estimator without further refining.
-
setResultRefined
public void setResultRefined(boolean refineResult) throws com.irurueta.navigation.LockedException Specifies whether result must be refined using a non-linear solver over found inliers.- Parameters:
refineResult
- true to refine result, false to simply use result found by robust estimator without further refining.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
isCovarianceKept
public boolean isCovarianceKept()Indicates whether covariance must be kept after refining result. This setting is only taken into account if result is refined.- Returns:
- true if covariance must be kept after refining result, false otherwise.
-
setCovarianceKept
public void setCovarianceKept(boolean keepCovariance) throws com.irurueta.navigation.LockedException Specifies whether covariance must be kept after refining result. This setting is only taken into account if result is refined.- Parameters:
keepCovariance
- true if covariance must be kept after refining result, false otherwise.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
getQualityScores
public double[] getQualityScores()Returns quality scores corresponding to each measurement. The larger the score value the better the quality of the sample. This implementation always returns null. Subclasses using quality scores must implement proper behavior.- Specified by:
getQualityScores
in interfaceQualityScoredGyroscopeCalibrator
- Returns:
- quality scores corresponding to each sample.
-
setQualityScores
public void setQualityScores(double[] qualityScores) throws com.irurueta.navigation.LockedException Sets quality scores corresponding to each measurement. The larger the score value the better the quality of the sample. This implementation makes no action. Subclasses using quality scores must implement proper behaviour.- Specified by:
setQualityScores
in interfaceQualityScoredGyroscopeCalibrator
- Parameters:
qualityScores
- quality scores corresponding to each sample.- Throws:
IllegalArgumentException
- if provided quality scores length is smaller than minimum required samples.com.irurueta.navigation.LockedException
- if calibrator is currently running.
-
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 gyroscope x-axis scale factor.- Specified by:
getEstimatedSx
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope x-axis scale factor or null if not available.
-
getEstimatedSy
Gets estimated gyroscope y-axis scale factor.- Specified by:
getEstimatedSy
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope y-axis scale factor or null if not available.
-
getEstimatedSz
Gets estimated gyroscope z-axis scale factor.- Specified by:
getEstimatedSz
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope z-axis scale factor or null if not available.
-
getEstimatedMxy
Gets estimated gyroscope x-y cross-coupling error.- Specified by:
getEstimatedMxy
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope x-y cross-coupling error or null if not available.
-
getEstimatedMxz
Gets estimated gyroscope x-z cross-coupling error.- Specified by:
getEstimatedMxz
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope x-z cross-coupling error or null if not available.
-
getEstimatedMyx
Gets estimated gyroscope y-x cross-coupling error.- Specified by:
getEstimatedMyx
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope y-x cross-coupling error or null if not available.
-
getEstimatedMyz
Gets estimated gyroscope y-z cross-coupling error.- Specified by:
getEstimatedMyz
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope y-z cross-coupling error or null if not available.
-
getEstimatedMzx
Gets estimated gyroscope z-x cross-coupling error.- Specified by:
getEstimatedMzx
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope z-x cross-coupling error or null if not available.
-
getEstimatedMzy
Gets estimated gyroscope z-y cross-coupling error.- Specified by:
getEstimatedMzy
in interfaceGyroscopeCalibrator
- Returns:
- estimated gyroscope 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.
-
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.
-
getEstimatedChiSq
public double getEstimatedChiSq()Gets estimated chi square value.- Specified by:
getEstimatedChiSq
in interfaceGyroscopeNonLinearCalibrator
- Returns:
- estimated chi square value.
-
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.
-
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.
-
getPreliminarySubsetSize
public int getPreliminarySubsetSize()Gets size of subsets to be checked during robust estimation. This has to be at leastgetMinimumRequiredMeasurementsOrSequences()
.- Returns:
- size of subsets to be checked during robust estimation.
-
setPreliminarySubsetSize
public void setPreliminarySubsetSize(int preliminarySubsetSize) throws com.irurueta.navigation.LockedException Sets size of subsets to be checked during robust estimation. This has to be at leastgetMinimumRequiredMeasurementsOrSequences()
.- Parameters:
preliminarySubsetSize
- size of subsets to be checked during robust estimation.- Throws:
com.irurueta.navigation.LockedException
- if calibrator is currently running.IllegalArgumentException
- if provided value is less thangetMinimumRequiredMeasurementsOrSequences()
.
-
getMethod
public abstract com.irurueta.numerical.robust.RobustEstimatorMethod getMethod()Returns method being used for robust estimation.- Returns:
- method being used for robust estimation.
-
create
public static RobustTurntableGyroscopeCalibrator create(com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.- Parameters:
method
- robust estimator method.- Returns:
- a robust gyroscope calibrator.
-
create
public static RobustTurntableGyroscopeCalibrator create(double[] qualityScores, com.irurueta.numerical.robust.RobustEstimatorMethod method) Creates a robust gyroscope calibrator.- Parameters:
qualityScores
- quality scores corresponding to each provided measurement. The larger the score value the better the quality of the sample.method
- robust estimator method.- Returns:
- a robust gyroscope calibrator.
- Throws:
IllegalArgumentException
- if provided quality scores length is smaller than 10 samples.
-
create
Creates a robust gyroscope calibrator using default robust method.- Returns:
- a robust gyroscope calibrator.
-
computePreliminarySolutions
protected void computePreliminarySolutions(int[] samplesIndices, List<RobustTurntableGyroscopeCalibrator.PreliminaryResult> solutions) Computes a preliminary solution for a subset of samples picked by a robust estimator.- Parameters:
samplesIndices
- indices of samples picked by the robust estimator.solutions
- list where estimated preliminary solution will be stored.
-
convertAcceleration
private static double convertAcceleration(com.irurueta.units.Acceleration acceleration) Converts acceleration instance to meters per squared second.- Parameters:
acceleration
- acceleration instance to be converted.- Returns:
- converted value.
-
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.
-
convertTime
private static double convertTime(com.irurueta.units.Time time) Converts time instance to seconds.- Parameters:
time
- time instance to be converted.- Returns:
- converted value.
-