Class AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
java.lang.Object
com.irurueta.navigation.inertial.calibration.intervals.thresholdfactor.IntervalDetectorThresholdFactorOptimizer<com.irurueta.navigation.inertial.calibration.TimedBodyKinematics,AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizerDataSource>
com.irurueta.navigation.inertial.calibration.intervals.thresholdfactor.AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
- All Implemented Interfaces:
com.irurueta.navigation.inertial.calibration.AccelerometerNoiseRootPsdSource
,com.irurueta.navigation.inertial.calibration.GyroscopeNoiseRootPsdSource
- Direct Known Subclasses:
BracketedAccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
,ExhaustiveAccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
public abstract class AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
extends IntervalDetectorThresholdFactorOptimizer<com.irurueta.navigation.inertial.calibration.TimedBodyKinematics,AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizerDataSource>
implements com.irurueta.navigation.inertial.calibration.AccelerometerNoiseRootPsdSource, com.irurueta.navigation.inertial.calibration.GyroscopeNoiseRootPsdSource
Optimizes the threshold factor for interval detection of accelerometer and gyroscope
data based on results of calibration.
Implementations of this class will attempt to find the best threshold factor
between the provided range of values.
Only accelerometer calibrators based on unknown orientation are supported (in other terms,
calibrators must be
AccelerometerNonLinearCalibrator
and must support
AccelerometerCalibratorMeasurementType.STANDARD_DEVIATION_BODY_KINEMATICS
).
Only gyroscope calibrators based on unknown orientation are supported (in other terms,
calibrators must be GyroscopeNonLinearCalibrator
and must support
GyroscopeCalibratorMeasurementOrSequenceType.BODY_KINEMATICS_SEQUENCE
).-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator
Accelerometer calibrator.private QualityScoreMapper<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics>
Mapper to convertStandardDeviationBodyKinematics
measurements into quality scores.private double
Estimated norm of gyroscope noise root PSD (Power Spectral Density) expressed as (rad * s^-0.5).private double
Accelerometer base noise level that has been detected during initialization of the best solution that has been found expressed in meters per squared second (m/s^2).static final double
Default maximum threshold factor.static final double
Default minimum threshold factor.private double[]
Estimated accelerometer biases for each IMU axis expressed in meter per squared second (m/s^2).private com.irurueta.algebra.Matrix
Estimated covariance matrix for estimated accelerometer parameters.private com.irurueta.algebra.Matrix
Estimated accelerometer scale factors and cross-coupling errors.private double[]
Estimated angular rate biases for each IMU axis expressed in radians per second (rad/s).private com.irurueta.algebra.Matrix
Estimated covariance matrix for estimated gyroscope 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 com.irurueta.navigation.inertial.calibration.generators.AccelerometerAndGyroscopeMeasurementsGenerator
A measurement generator for accelerometer and gyroscope calibrators.private com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator
Gyroscope calibrator.private QualityScoreMapper<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>>
Mapper to convertBodyKinematicsSequence
sequences ofStandardDeviationTimedBodyKinematics
into quality scores.protected double
Maximum threshold factor.private List<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics>
Generated measurements to be used for accelerometer calibration.protected double
Minimum threshold factor.private AccelerometerAndGyroscopeMseRule
Rule to convert accelerometer and gyroscope MSE values into a single global MSE value.private List<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>>
Generated sequences to be used for gyroscope calibration.private double
Threshold to determine static/dynamic period changes expressed in meters per squared second (m/s^2) for the best calibration solution that has been found.Fields inherited from class com.irurueta.navigation.inertial.calibration.intervals.thresholdfactor.IntervalDetectorThresholdFactorOptimizer
dataSource, DEFAULT_PROGRESS_DELTA, listener, MAX_PROGRESS_DELTA, MIN_PROGRESS_DELTA, minMse, optimalThresholdFactor, previousProgress, progress, progressDelta, running
-
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
Constructor.protected
AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
(com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator accelerometerCalibrator, com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator gyroscopeCalibrator) Constructor.protected
AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
(AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizerDataSource dataSource) Constructor.protected
AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
(AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizerDataSource dataSource, com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator accelerometerCalibrator, com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator gyroscopeCalibrator) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionprivate com.irurueta.units.Acceleration
createMeasurement
(double value, com.irurueta.units.AccelerationUnit unit) Creates an acceleration instance using the provided value and unit.protected double
evaluateForThresholdFactor
(double thresholdFactor) Evaluates calibration Mean Square Error (MSE) for the provided threshold factor.double
Gets accelerometer base noise level that has been detected during initialization of the best solution that has been found expressed in meters per squared second (m/s^2).com.irurueta.units.Acceleration
Gets accelerometer base noise level that has been detected during initialization of the best solution that has been found.void
getAccelerometerBaseNoiseLevelAsMeasurement
(com.irurueta.units.Acceleration result) Gets accelerometer base noise level that has been detected during initialization of the best solution that has been found.double
Gets accelerometer base noise level PSD (Power Spectral Density) expressed in (m^2 * s^-3).double
Gets accelerometer base noise level root PSD (Power Spectral Density) expressed in (m * s^-1.5).com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator
Gets provided accelerometer calibrator to be used to optimize its Mean Square Error (MSE).QualityScoreMapper<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics>
Gets mapper to convertStandardDeviationBodyKinematics
accelerometer measurements into quality scores.double
Gets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.com.irurueta.units.Acceleration
Gets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.void
getBaseNoiseLevelAbsoluteThresholdAsMeasurement
(com.irurueta.units.Acceleration result) Gets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.private com.irurueta.units.AccelerationUnit
Gets the default unit for acceleration, which is meters per squared second (m/s^2).double[]
Gets an array containing x,y,z components of estimated accelerometer biases expressed in meters per squared second (m/s^2).Gets estimated x coordinate variance of accelerometer bias expressed in (m^2/s^4).Gets estimated y coordinate variance of accelerometer bias expressed in (m^2/s^4).Gets estimated z coordinate variance of accelerometer bias expressed in (m^2/s^4).Gets estimated standard deviation norm of accelerometer bias expressed in meters per squared second (m/s^2).com.irurueta.algebra.Matrix
Gets estimated accelerometer scale factors and cross-coupling errors.double[]
Gets the array containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).Gets estimated standard deviation norm of gyroscope bias expressed in radians per second (rad/s).Gets estimated x coordinate variance of gyroscope bias expressed in (rad^2/s^2).Gets estimated y coordinate variance of gyroscope bias expressed in (rad^2/s^2).Gets estimated z coordinate variance of gyroscope bias expressed in (rad^2/s^2).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 gyroscope base noise level PSD (Power Spectral Density) expressed in (rad^2/s).double
Gets gyroscope base noise level root PSD (Power Spectral Density) expressed in (rad * s^-0.5)com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator
Gets provided gyroscope calibrator to be used to optimize its Mean Square Error (MSE).QualityScoreMapper<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>>
Gets mapper to convertBodyKinematicsSequence
gyroscope sequences ofStandardDeviationTimedBodyKinematics
into quality scores.int
Gets number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to be processed initially while keeping the sensor static to find the base noise level when the device is static.double
Gets factor to determine that a sudden movement has occurred during initialization if instantaneous noise level exceeds accumulated noise level by this factor amount.int
Gets maximum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
allowed in dynamic intervals.double
Gets the maximum threshold factor.int
Gets minimum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
required in a static interval to be taken into account.double
Gets the minimum threshold factor.Gets rule to convert accelerometer and gyroscope MSE values into a single global MSE value.double
Gets the threshold to determine static/dynamic period changes expressed in meters per squared second (m/s^2) for the best calibration solution that has been found.com.irurueta.units.Acceleration
Gets the threshold to determine static/dynamic period changes for the best calibration solution that has been found.void
getThresholdAsMeasurement
(com.irurueta.units.Acceleration result) Get the threshold to determine static/dynamic period changes for the best calibration solution that has been found.double
Gets the time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
expressed in seconds (s).com.irurueta.units.Time
Gets the time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
.void
getTimeIntervalAsTime
(com.irurueta.units.Time result) Gets the time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
.int
Gets length of number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to keep within the window being processed to determine instantaneous accelerometer noise level.private void
Initializes accelerometer + gyroscope measurement generator to convert timed body kinematics measurements after interval detection into measurements and sequences used for accelerometer and gyroscope calibration.boolean
isReady()
Indicates whether this optimizer is ready to start optimization.private void
keepBestResult
(double mse, double thresholdFactor) Keeps the best calibration solution found so far.void
setAccelerometerCalibrator
(com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator accelerometerCalibrator) Sets accelerometer calibrator to be used to optimize its Mean Square Error (MSE).void
setAccelerometerQualityScoreMapper
(QualityScoreMapper<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics> accelerometerQualityScoreMapper) Sets mapper to convertStandardDeviationBodyKinematics
accelerometer measurements into quality scores.void
setBaseNoiseLevelAbsoluteThreshold
(double baseNoiseLevelAbsoluteThreshold) Sets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.void
setBaseNoiseLevelAbsoluteThreshold
(com.irurueta.units.Acceleration baseNoiseLevelAbsoluteThreshold) Sets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.void
setGyroscopeCalibrator
(com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator gyroscopeCalibrator) Sets gyroscope calibrator to be used to optimize its Mean Square Error (MSE).void
setGyroscopeQualityScoreMapper
(QualityScoreMapper<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>> gyroscopeQualityScoreMapper) Sets mapper to convertBodyKinematicsSequence
gyroscope sequences ofStandardDeviationTimedBodyKinematics
into quality scores.void
setInitialStaticSamples
(int initialStaticSamples) Sets number of input parameters provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to be processed initially while keeping the sensor static to find the base noise level when the device is static.void
setInstantaneousNoiseLevelFactor
(double instantaneousNoiseLevelFactor) Sets factor to determine that a sudden movement has occurred during initialization if instantaneous noise level exceeds accumulated noise level by this factor amount.void
setMaxDynamicSamples
(int maxDynamicSamples) Sets maximum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
allowed in dynamic intervals.void
setMinStaticSamples
(int minStaticSamples) Sets minimum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
required in a static interval to be taken into account.void
Sets rule to convert accelerometer and gyroscope MSE values into a single global MSE value.void
setThresholdFactorRange
(double minThresholdFactor, double maxThresholdFactor) Sets a range of threshold factor values to get an optimized threshold factor value.void
setTimeInterval
(double timeInterval) Sets time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
expressed in seconds (s).void
setTimeInterval
(com.irurueta.units.Time timeInterval) Sets time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
.void
setWindowSize
(int windowSize) Sets length of number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to keep within the window being processed to determine instantaneous noise level.Methods inherited from class com.irurueta.navigation.inertial.calibration.intervals.thresholdfactor.IntervalDetectorThresholdFactorOptimizer
checkAndNotifyProgress, getDataSource, getListener, getMinMse, getOptimalThresholdFactor, getProgressDelta, initProgress, isRunning, optimize, setDataSource, setListener, setProgressDelta
-
Field Details
-
DEFAULT_MIN_THRESHOLD_FACTOR
public static final double DEFAULT_MIN_THRESHOLD_FACTORDefault minimum threshold factor.- See Also:
-
DEFAULT_MAX_THRESHOLD_FACTOR
public static final double DEFAULT_MAX_THRESHOLD_FACTORDefault maximum threshold factor.- See Also:
-
minThresholdFactor
protected double minThresholdFactorMinimum threshold factor. -
maxThresholdFactor
protected double maxThresholdFactorMaximum threshold factor. -
accelerometerCalibrator
private com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator accelerometerCalibratorAccelerometer calibrator. -
gyroscopeCalibrator
private com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator gyroscopeCalibratorGyroscope calibrator. -
generator
private com.irurueta.navigation.inertial.calibration.generators.AccelerometerAndGyroscopeMeasurementsGenerator generatorA measurement generator for accelerometer and gyroscope calibrators. -
measurements
private List<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics> measurementsGenerated measurements to be used for accelerometer calibration. -
sequences
private List<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>> sequencesGenerated sequences to be used for gyroscope calibration. -
accelerometerQualityScoreMapper
private QualityScoreMapper<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics> accelerometerQualityScoreMapperMapper to convertStandardDeviationBodyKinematics
measurements into quality scores. -
gyroscopeQualityScoreMapper
private QualityScoreMapper<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>> gyroscopeQualityScoreMapperMapper to convertBodyKinematicsSequence
sequences ofStandardDeviationTimedBodyKinematics
into quality scores. -
mseRule
Rule to convert accelerometer and gyroscope MSE values into a single global MSE value. -
angularSpeedNoiseRootPsd
private double angularSpeedNoiseRootPsdEstimated norm of gyroscope noise root PSD (Power Spectral Density) expressed as (rad * s^-0.5). -
baseNoiseLevel
private double baseNoiseLevelAccelerometer base noise level that has been detected during initialization of the best solution that has been found expressed in meters per squared second (m/s^2). This is equal to the standard deviation of the accelerometer measurements during the initialization phase. -
threshold
private double thresholdThreshold to determine static/dynamic period changes expressed in meters per squared second (m/s^2) for the best calibration solution that has been found. -
estimatedAccelerometerCovariance
private com.irurueta.algebra.Matrix estimatedAccelerometerCovarianceEstimated covariance matrix for estimated accelerometer parameters. -
estimatedAccelerometerMa
private com.irurueta.algebra.Matrix estimatedAccelerometerMaEstimated accelerometer scale factors and cross-coupling errors. This is the product of matrix Ta containing cross-coupling errors and Ka containing scaling factors. So that:Ma = [sx mxy mxz] = Ta*Ka [myx sy myz] [mzx mzy sz ]
Where:Ka = [sx 0 0 ] [0 sy 0 ] [0 0 sz]
andTa = [1 -alphaXy alphaXz ] [alphaYx 1 -alphaYz] [-alphaZx alphaZy 1 ]
Hence:Ma = [sx mxy mxz] = Ta*Ka = [sx -sy * alphaXy sz * alphaXz ] [myx sy myz] [sx * alphaYx sy -sz * alphaYz] [mzx mzy sz ] [-sx * alphaZx sy * alphaZy sz ]
This instance allows any 3x3 matrix. However, typically alphaYx, alphaZx and alphaZy are considered to be zero if the accelerometer z-axis is assumed to be the same as the body z-axis. When this is assumed, myx = mzx = mzy = 0 and the Ma matrix becomes upper diagonal:Ma = [sx mxy mxz] [0 sy myz] [0 0 sz ]
Values of this matrix are unit-less. -
estimatedAccelerometerBiases
private double[] estimatedAccelerometerBiasesEstimated accelerometer biases for each IMU axis expressed in meter per squared second (m/s^2). -
estimatedGyroscopeCovariance
private com.irurueta.algebra.Matrix estimatedGyroscopeCovarianceEstimated covariance matrix for estimated gyroscope parameters. -
estimatedGyroscopeBiases
private double[] estimatedGyroscopeBiasesEstimated angular rate biases for each IMU axis expressed in radians per second (rad/s). -
estimatedGyroscopeMg
private com.irurueta.algebra.Matrix estimatedGyroscopeMgEstimated 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. -
estimatedGyroscopeGg
private com.irurueta.algebra.Matrix estimatedGyroscopeGgEstimated G-dependent cross-biases introduced on the gyroscope by the specific forces sensed by the accelerometer. This instance allows any 3x3 matrix.
-
-
Constructor Details
-
AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer
protected AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizer()Constructor.
-
-
Method Details
-
getAccelerometerCalibrator
public com.irurueta.navigation.inertial.calibration.accelerometer.AccelerometerNonLinearCalibrator getAccelerometerCalibrator()Gets provided accelerometer calibrator to be used to optimize its Mean Square Error (MSE).- Returns:
- accelerometer calibrator to be used to optimize its MSE.
-
getGyroscopeCalibrator
public com.irurueta.navigation.inertial.calibration.gyroscope.GyroscopeNonLinearCalibrator getGyroscopeCalibrator()Gets provided gyroscope calibrator to be used to optimize its Mean Square Error (MSE).- Returns:
- gyroscope calibrator to be used to optimize its MSE.
-
getAccelerometerQualityScoreMapper
public QualityScoreMapper<com.irurueta.navigation.inertial.calibration.StandardDeviationBodyKinematics> getAccelerometerQualityScoreMapper()Gets mapper to convertStandardDeviationBodyKinematics
accelerometer measurements into quality scores.- Returns:
- mapper to convert accelerometer measurements into quality scores.
-
getGyroscopeQualityScoreMapper
public QualityScoreMapper<com.irurueta.navigation.inertial.calibration.BodyKinematicsSequence<com.irurueta.navigation.inertial.calibration.StandardDeviationTimedBodyKinematics>> getGyroscopeQualityScoreMapper()Gets mapper to convertBodyKinematicsSequence
gyroscope sequences ofStandardDeviationTimedBodyKinematics
into quality scores.- Returns:
- mapper to convert gyroscope sequences into quality scores.
-
getMseRule
Gets rule to convert accelerometer and gyroscope MSE values into a single global MSE value.- Returns:
- rule to convert accelerometer and gyroscope MSE values into a single global MSE value.
-
getMinThresholdFactor
public double getMinThresholdFactor()Gets the minimum threshold factor.- Returns:
- minimum threshold factor.
-
getMaxThresholdFactor
public double getMaxThresholdFactor()Gets the maximum threshold factor.- Returns:
- maximum threshold factor.
-
setThresholdFactorRange
public void setThresholdFactorRange(double minThresholdFactor, double maxThresholdFactor) throws com.irurueta.navigation.LockedException Sets a range of threshold factor values to get an optimized threshold factor value.- Parameters:
minThresholdFactor
- minimum threshold.maxThresholdFactor
- maximum threshold.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if either minimum or maximum values are negative, or if the minimum value is larger than the maximum one.
-
isReady
public boolean isReady()Indicates whether this optimizer is ready to start optimization.- Overrides:
isReady
in classIntervalDetectorThresholdFactorOptimizer<com.irurueta.navigation.inertial.calibration.TimedBodyKinematics,
AccelerometerAndGyroscopeIntervalDetectorThresholdFactorOptimizerDataSource> - Returns:
- true if this optimizer is ready, false otherwise.
-
getTimeInterval
public double getTimeInterval()Gets the time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
expressed in seconds (s).- Returns:
- time interval between input measurements.
-
setTimeInterval
public void setTimeInterval(double timeInterval) throws com.irurueta.navigation.LockedException Sets time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
expressed in seconds (s).- Parameters:
timeInterval
- time interval between input measurements.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is negative.
-
getTimeIntervalAsTime
public com.irurueta.units.Time getTimeIntervalAsTime()Gets the time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
.- Returns:
- time interval between input measurements.
-
getTimeIntervalAsTime
public void getTimeIntervalAsTime(com.irurueta.units.Time result) Gets the time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
.- Parameters:
result
- instance where the time interval will be stored.
-
setTimeInterval
public void setTimeInterval(com.irurueta.units.Time timeInterval) throws com.irurueta.navigation.LockedException Sets time interval between input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
.- Parameters:
timeInterval
- time interval between input measurements.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is negative.
-
getMinStaticSamples
public int getMinStaticSamples()Gets minimum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
required in a static interval to be taken into account. Smaller static intervals will be discarded.- Returns:
- a minimum number of input measurements required in a static interval to be taken into account.
-
setMinStaticSamples
public void setMinStaticSamples(int minStaticSamples) throws com.irurueta.navigation.LockedException Sets minimum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
required in a static interval to be taken into account. Smaller static intervals will be discarded.- Parameters:
minStaticSamples
- a minimum number of input measurements required in a static interval to be taken into account.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is less than 2.
-
getMaxDynamicSamples
public int getMaxDynamicSamples()Gets maximum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
allowed in dynamic intervals.- Returns:
- maximum number of input measurements allowed in dynamic intervals.
-
setMaxDynamicSamples
public void setMaxDynamicSamples(int maxDynamicSamples) throws com.irurueta.navigation.LockedException Sets maximum number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
allowed in dynamic intervals.- Parameters:
maxDynamicSamples
- maximum number of input measurements allowed in dynamic intervals.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is less than 2.
-
getWindowSize
public int getWindowSize()Gets length of number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to keep within the window being processed to determine instantaneous accelerometer noise level.- Returns:
- length of input measurements to keep within the window.
-
setWindowSize
public void setWindowSize(int windowSize) throws com.irurueta.navigation.LockedException Sets length of number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to keep within the window being processed to determine instantaneous noise level. Window size must always be larger than the allowed minimum value, which is 2 and must have an odd value.- Parameters:
windowSize
- length of number of samples to keep within the window.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is not valid.
-
getInitialStaticSamples
public int getInitialStaticSamples()Gets number of input measurements provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to be processed initially while keeping the sensor static to find the base noise level when the device is static.- Returns:
- number of samples to be processed initially.
-
setInitialStaticSamples
public void setInitialStaticSamples(int initialStaticSamples) throws com.irurueta.navigation.LockedException Sets number of input parameters provided to theIntervalDetectorThresholdFactorOptimizer.getDataSource()
to be processed initially while keeping the sensor static to find the base noise level when the device is static.- Parameters:
initialStaticSamples
- number of samples ot be processed initially.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is less thanTriadStaticIntervalDetector.MINIMUM_INITIAL_STATIC_SAMPLES
.
-
getInstantaneousNoiseLevelFactor
public double getInstantaneousNoiseLevelFactor()Gets factor to determine that a sudden movement has occurred during initialization if instantaneous noise level exceeds accumulated noise level by this factor amount. This factor is unit-less.- Returns:
- factor to determine that a sudden movement has occurred.
-
setInstantaneousNoiseLevelFactor
public void setInstantaneousNoiseLevelFactor(double instantaneousNoiseLevelFactor) throws com.irurueta.navigation.LockedException Sets factor to determine that a sudden movement has occurred during initialization if instantaneous noise level exceeds accumulated noise level by this factor amount. This factor is unit-less.- Parameters:
instantaneousNoiseLevelFactor
- factor to determine that a sudden movement has occurred during initialization.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is zero or negative.
-
getBaseNoiseLevelAbsoluteThreshold
public double getBaseNoiseLevelAbsoluteThreshold()Gets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase. This threshold is expressed in meters per squared second (m/s^2).- Returns:
- overall absolute threshold to determine whether there has been excessive motion.
-
setBaseNoiseLevelAbsoluteThreshold
public void setBaseNoiseLevelAbsoluteThreshold(double baseNoiseLevelAbsoluteThreshold) throws com.irurueta.navigation.LockedException Sets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase. This threshold is expressed in meters per squared second (m/s^2).- Parameters:
baseNoiseLevelAbsoluteThreshold
- overall absolute threshold to determine whether there has been excessive motion.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is zero or negative.
-
getBaseNoiseLevelAbsoluteThresholdAsMeasurement
public com.irurueta.units.Acceleration getBaseNoiseLevelAbsoluteThresholdAsMeasurement()Gets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.- Returns:
- overall absolute threshold to determine whether there has been excessive motion.
-
getBaseNoiseLevelAbsoluteThresholdAsMeasurement
public void getBaseNoiseLevelAbsoluteThresholdAsMeasurement(com.irurueta.units.Acceleration result) Gets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.- Parameters:
result
- instance where the result will be stored.
-
setBaseNoiseLevelAbsoluteThreshold
public void setBaseNoiseLevelAbsoluteThreshold(com.irurueta.units.Acceleration baseNoiseLevelAbsoluteThreshold) throws com.irurueta.navigation.LockedException Sets the overall absolute threshold to determine whether there has been excessive motion during the whole initialization phase.- Parameters:
baseNoiseLevelAbsoluteThreshold
- overall absolute threshold to determine whether there has been excessive motion.- Throws:
com.irurueta.navigation.LockedException
- if optimizer is already running.IllegalArgumentException
- if provided value is zero or negative.
-
getAccelerometerBaseNoiseLevel
public double getAccelerometerBaseNoiseLevel()Gets accelerometer base noise level that has been detected during initialization of the best solution that has been found expressed in meters per squared second (m/s^2). This is equal to the standard deviation of the accelerometer measurements during the initialization phase.- Returns:
- accelerometer base noise level of the best solution that has been found.
-
getAccelerometerBaseNoiseLevelAsMeasurement
public com.irurueta.units.Acceleration getAccelerometerBaseNoiseLevelAsMeasurement()Gets accelerometer base noise level that has been detected during initialization of the best solution that has been found. This is equal to the standard deviation of the accelerometer measurements during the initialization phase.- Returns:
- accelerometer base noise level of the best solution that has been found.
-
getAccelerometerBaseNoiseLevelAsMeasurement
public void getAccelerometerBaseNoiseLevelAsMeasurement(com.irurueta.units.Acceleration result) Gets accelerometer base noise level that has been detected during initialization of the best solution that has been found. This is equal to the standard deviation of the accelerometer measurements during the initialization phase.- Parameters:
result
- instance where the result will be stored.
-
getGyroscopeBaseNoiseLevelPsd
public double getGyroscopeBaseNoiseLevelPsd()Gets gyroscope base noise level PSD (Power Spectral Density) expressed in (rad^2/s).- Returns:
- gyroscope base noise level PSD.
-
getGyroscopeBaseNoiseLevelRootPsd
public double getGyroscopeBaseNoiseLevelRootPsd()Gets gyroscope base noise level root PSD (Power Spectral Density) expressed in (rad * s^-0.5)- Specified by:
getGyroscopeBaseNoiseLevelRootPsd
in interfacecom.irurueta.navigation.inertial.calibration.GyroscopeNoiseRootPsdSource
- Returns:
- gyroscope base noise level root PSD.
-
getAccelerometerBaseNoiseLevelPsd
public double getAccelerometerBaseNoiseLevelPsd()Gets accelerometer base noise level PSD (Power Spectral Density) expressed in (m^2 * s^-3).- Returns:
- accelerometer base noise level PSD.
-
getAccelerometerBaseNoiseLevelRootPsd
public double getAccelerometerBaseNoiseLevelRootPsd()Gets accelerometer base noise level root PSD (Power Spectral Density) expressed in (m * s^-1.5).- Specified by:
getAccelerometerBaseNoiseLevelRootPsd
in interfacecom.irurueta.navigation.inertial.calibration.AccelerometerNoiseRootPsdSource
- Returns:
- accelerometer base noise level root PSD.
-
getThreshold
public double getThreshold()Gets the threshold to determine static/dynamic period changes expressed in meters per squared second (m/s^2) for the best calibration solution that has been found.- Returns:
- threshold to determine static/dynamic period changes for the best solution.
-
getThresholdAsMeasurement
public com.irurueta.units.Acceleration getThresholdAsMeasurement()Gets the threshold to determine static/dynamic period changes for the best calibration solution that has been found.- Returns:
- threshold to determine static/dynamic period changes for the best solution.
-
getThresholdAsMeasurement
public void getThresholdAsMeasurement(com.irurueta.units.Acceleration result) Get the threshold to determine static/dynamic period changes for the best calibration solution that has been found.- Parameters:
result
- instance where the result will be stored.
-
getEstimatedAccelerometerBiasStandardDeviationNorm
Gets estimated standard deviation norm of accelerometer bias expressed in meters per squared second (m/s^2). This can be used as the initial accelerometer bias uncertainty forINSLooselyCoupledKalmanInitializerConfig
orINSTightlyCoupledKalmanInitializerConfig
.- Returns:
- estimated standard deviation norm of accelerometer bias or null if not available.
-
getEstimatedAccelerometerBiasFxVariance
Gets estimated x coordinate variance of accelerometer bias expressed in (m^2/s^4).- Returns:
- estimated x coordinate variance of accelerometer bias or null if not available.
-
getEstimatedAccelerometerBiasFyVariance
Gets estimated y coordinate variance of accelerometer bias expressed in (m^2/s^4).- Returns:
- estimated y coordinate variance of accelerometer bias or null if not available.
-
getEstimatedAccelerometerBiasFzVariance
Gets estimated z coordinate variance of accelerometer bias expressed in (m^2/s^4).- Returns:
- estimated z coordinate variance of accelerometer bias or null if not available.
-
getEstimatedAccelerometerBiases
public double[] getEstimatedAccelerometerBiases()Gets an array containing x,y,z components of estimated accelerometer biases expressed in meters per squared second (m/s^2).- Returns:
- array containing x,y,z components of estimated accelerometer biases.
-
getEstimatedAccelerometerMa
public com.irurueta.algebra.Matrix getEstimatedAccelerometerMa()Gets estimated accelerometer scale factors and cross-coupling errors. This is the product of matrix Ta containing cross-coupling errors and Ka containing scaling factors. So that:Ma = [sx mxy mxz] = Ta*Ka [myx sy myz] [mzx mzy sz ]
Where:Ka = [sx 0 0 ] [0 sy 0 ] [0 0 sz]
andTa = [1 -alphaXy alphaXz ] [alphaYx 1 -alphaYz] [-alphaZx alphaZy 1 ]
Hence:Ma = [sx mxy mxz] = Ta*Ka = [sx -sy * alphaXy sz * alphaXz ] [myx sy myz] [sx * alphaYx sy -sz * alphaYz] [mzx mzy sz ] [-sx * alphaZx sy * alphaZy sz ]
This instance allows any 3x3 matrix. However, typically alphaYx, alphaZx and alphaZy are considered to be zero if the accelerometer z-axis is assumed to be the same as the body z-axis. When this is assumed, myx = mzx = mzy = 0 and the Ma matrix becomes upper diagonal:Ma = [sx mxy mxz] [0 sy myz] [0 0 sz ]
Values of this matrix are unit-less.- Returns:
- estimated accelerometer scale factors and cross-coupling errors, or null if not available.
-
getEstimatedGyroscopeBiasStandardDeviationNorm
Gets estimated standard deviation norm of gyroscope bias expressed in radians per second (rad/s). This can be used as the initial gyroscope bias uncertainty forINSLooselyCoupledKalmanInitializerConfig
orINSTightlyCoupledKalmanInitializerConfig
.- Returns:
- estimated standard deviation norm of gyroscope bias or null if not available.
-
getEstimatedGyroscopeBiasXVariance
Gets estimated x coordinate variance of gyroscope bias expressed in (rad^2/s^2).- Returns:
- estimated x coordinate variance of gyroscope bias or null if not available.
-
getEstimatedGyroscopeBiasYVariance
Gets estimated y coordinate variance of gyroscope bias expressed in (rad^2/s^2).- Returns:
- estimated y coordinate variance of gyroscope bias or null if not available.
-
getEstimatedGyroscopeBiasZVariance
Gets estimated z coordinate variance of gyroscope bias expressed in (rad^2/s^2).- Returns:
- estimated z coordinate variance of gyroscope bias or null if not available.
-
getEstimatedGyroscopeBiases
public double[] getEstimatedGyroscopeBiases()Gets the array containing x,y,z components of estimated gyroscope biases expressed in radians per second (rad/s).- Returns:
- array containing x,y,z components of estimated gyroscope biases.
-
getEstimatedGyroscopeMg
public com.irurueta.algebra.Matrix getEstimatedGyroscopeMg()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.- Returns:
- estimated gyroscope scale factors and cross-coupling errors.
-
getEstimatedGyroscopeGg
public com.irurueta.algebra.Matrix getEstimatedGyroscopeGg()Gets estimated G-dependent cross-biases introduced on the gyroscope by the specific forces sensed by the accelerometer.- Returns:
- a 3x3 matrix containing g-dependent cross biases.
-
evaluateForThresholdFactor
protected double evaluateForThresholdFactor(double thresholdFactor) throws com.irurueta.navigation.LockedException, com.irurueta.navigation.inertial.calibration.CalibrationException, com.irurueta.navigation.NotReadyException, IntervalDetectorThresholdFactorOptimizerException Evaluates calibration Mean Square Error (MSE) for the provided threshold factor.- Parameters:
thresholdFactor
- threshold factor to be used for interval detection and measurement generation to be used for calibration.- Returns:
- calibration MSE.
- Throws:
com.irurueta.navigation.LockedException
- if the generator is busy.com.irurueta.navigation.inertial.calibration.CalibrationException
- if calibration fails.com.irurueta.navigation.NotReadyException
- if the calibrator is not ready.IntervalDetectorThresholdFactorOptimizerException
- interval detection failed.
-
initialize
private void initialize()Initializes accelerometer + gyroscope measurement generator to convert timed body kinematics measurements after interval detection into measurements and sequences used for accelerometer and gyroscope calibration. -
keepBestResult
private void keepBestResult(double mse, double thresholdFactor) Keeps the best calibration solution found so far.- Parameters:
mse
- Estimated Mean Square Error during calibration.thresholdFactor
- threshold factor to be kept.
-
createMeasurement
private com.irurueta.units.Acceleration createMeasurement(double value, com.irurueta.units.AccelerationUnit unit) Creates an acceleration instance using the provided value and unit.- Parameters:
value
- value of measurement.unit
- unit of value.- Returns:
- created acceleration.
-
getDefaultUnit
private com.irurueta.units.AccelerationUnit getDefaultUnit()Gets the default unit for acceleration, which is meters per squared second (m/s^2).- Returns:
- default unit for acceleration.
-