accel/gyro/mag calibration set default priority uninitialized

- this allows the default priority to be set differently for internal/external sensors
 - accel and gyro initialize default priority like mag in preparation for fully supporting external sensors
 - fixes #15652
This commit is contained in:
Daniel Agar
2020-09-13 21:02:53 -04:00
committed by GitHub
parent d70e183f5b
commit 13db2ebb2b
18 changed files with 86 additions and 36 deletions
+25 -4
View File
@@ -48,21 +48,42 @@ Accelerometer::Accelerometer()
Reset(); Reset();
} }
Accelerometer::Accelerometer(uint32_t device_id) Accelerometer::Accelerometer(uint32_t device_id, bool external)
{ {
Reset(); Reset();
set_device_id(device_id); set_device_id(device_id, external);
} }
void Accelerometer::set_device_id(uint32_t device_id) void Accelerometer::set_device_id(uint32_t device_id, bool external)
{ {
if (_device_id != device_id) { if (_device_id != device_id || _external != external) {
set_external(external);
_device_id = device_id; _device_id = device_id;
ParametersUpdate(); ParametersUpdate();
SensorCorrectionsUpdate(true); SensorCorrectionsUpdate(true);
} }
} }
void Accelerometer::set_external(bool external)
{
// update priority default appropriately if not set
if (_calibration_index < 0 || _priority < 0) {
if ((_priority < 0) || (_priority > 100)) {
_priority = external ? DEFAULT_EXTERNAL_PRIORITY : DEFAULT_PRIORITY;
} else if (!_external && external && (_priority == DEFAULT_PRIORITY)) {
// internal -> external
_priority = DEFAULT_EXTERNAL_PRIORITY;
} else if (_external && !external && (_priority == DEFAULT_EXTERNAL_PRIORITY)) {
// external -> internal
_priority = DEFAULT_PRIORITY;
}
}
_external = external;
}
void Accelerometer::SensorCorrectionsUpdate(bool force) void Accelerometer::SensorCorrectionsUpdate(bool force)
{ {
// check if the selected sensor has updated // check if the selected sensor has updated
+4 -4
View File
@@ -53,15 +53,15 @@ public:
static constexpr const char *SensorString() { return "ACC"; } static constexpr const char *SensorString() { return "ACC"; }
Accelerometer(); Accelerometer();
explicit Accelerometer(uint32_t device_id); explicit Accelerometer(uint32_t device_id, bool external = false);
~Accelerometer() = default; ~Accelerometer() = default;
void PrintStatus(); void PrintStatus();
void set_calibration_index(uint8_t calibration_index) { _calibration_index = calibration_index; } void set_calibration_index(uint8_t calibration_index) { _calibration_index = calibration_index; }
void set_device_id(uint32_t device_id); void set_device_id(uint32_t device_id, bool external = false);
void set_external(bool external = true) { _external = external; } void set_external(bool external = true);
void set_offset(const matrix::Vector3f &offset) { _offset = offset; } void set_offset(const matrix::Vector3f &offset) { _offset = offset; }
void set_scale(const matrix::Vector3f &scale) { _scale = scale; } void set_scale(const matrix::Vector3f &scale) { _scale = scale; }
@@ -95,7 +95,7 @@ private:
int8_t _calibration_index{-1}; int8_t _calibration_index{-1};
uint32_t _device_id{0}; uint32_t _device_id{0};
int32_t _priority{DEFAULT_PRIORITY}; int32_t _priority{-1};
bool _external{false}; bool _external{false};
}; };
+25 -4
View File
@@ -48,21 +48,42 @@ Gyroscope::Gyroscope()
Reset(); Reset();
} }
Gyroscope::Gyroscope(uint32_t device_id) Gyroscope::Gyroscope(uint32_t device_id, bool external)
{ {
Reset(); Reset();
set_device_id(device_id); set_device_id(device_id, external);
} }
void Gyroscope::set_device_id(uint32_t device_id) void Gyroscope::set_device_id(uint32_t device_id, bool external)
{ {
if (_device_id != device_id) { if (_device_id != device_id || _external != external) {
set_external(external);
_device_id = device_id; _device_id = device_id;
ParametersUpdate(); ParametersUpdate();
SensorCorrectionsUpdate(true); SensorCorrectionsUpdate(true);
} }
} }
void Gyroscope::set_external(bool external)
{
// update priority default appropriately if not set
if (_calibration_index < 0 || _priority < 0) {
if ((_priority < 0) || (_priority > 100)) {
_priority = external ? DEFAULT_EXTERNAL_PRIORITY : DEFAULT_PRIORITY;
} else if (!_external && external && (_priority == DEFAULT_PRIORITY)) {
// internal -> external
_priority = DEFAULT_EXTERNAL_PRIORITY;
} else if (_external && !external && (_priority == DEFAULT_EXTERNAL_PRIORITY)) {
// external -> internal
_priority = DEFAULT_PRIORITY;
}
}
_external = external;
}
void Gyroscope::SensorCorrectionsUpdate(bool force) void Gyroscope::SensorCorrectionsUpdate(bool force)
{ {
// check if the selected sensor has updated // check if the selected sensor has updated
+4 -4
View File
@@ -53,15 +53,15 @@ public:
static constexpr const char *SensorString() { return "GYRO"; } static constexpr const char *SensorString() { return "GYRO"; }
Gyroscope(); Gyroscope();
explicit Gyroscope(uint32_t device_id); explicit Gyroscope(uint32_t device_id, bool external = false);
~Gyroscope() = default; ~Gyroscope() = default;
void PrintStatus(); void PrintStatus();
void set_calibration_index(uint8_t calibration_index) { _calibration_index = calibration_index; } void set_calibration_index(uint8_t calibration_index) { _calibration_index = calibration_index; }
void set_device_id(uint32_t device_id); void set_device_id(uint32_t device_id, bool external = false);
void set_external(bool external = true) { _external = external; } void set_external(bool external = true);
void set_offset(const matrix::Vector3f &offset) { _offset = offset; } void set_offset(const matrix::Vector3f &offset) { _offset = offset; }
uint32_t device_id() const { return _device_id; } uint32_t device_id() const { return _device_id; }
@@ -93,7 +93,7 @@ private:
int8_t _calibration_index{-1}; int8_t _calibration_index{-1};
uint32_t _device_id{0}; uint32_t _device_id{0};
int32_t _priority{DEFAULT_PRIORITY}; int32_t _priority{-1};
bool _external{false}; bool _external{false};
}; };
+5 -5
View File
@@ -50,14 +50,14 @@ Magnetometer::Magnetometer()
Magnetometer::Magnetometer(uint32_t device_id, bool external) Magnetometer::Magnetometer(uint32_t device_id, bool external)
{ {
set_external(external);
Reset(); Reset();
set_device_id(device_id); set_device_id(device_id, external);
} }
void Magnetometer::set_device_id(uint32_t device_id) void Magnetometer::set_device_id(uint32_t device_id, bool external)
{ {
if (_device_id != device_id) { if (_device_id != device_id || _external != external) {
set_external(external);
_device_id = device_id; _device_id = device_id;
ParametersUpdate(); ParametersUpdate();
} }
@@ -66,7 +66,7 @@ void Magnetometer::set_device_id(uint32_t device_id)
void Magnetometer::set_external(bool external) void Magnetometer::set_external(bool external)
{ {
// update priority default appropriately if not set // update priority default appropriately if not set
if (_calibration_index < 0) { if (_calibration_index < 0 || _priority < 0) {
if ((_priority < 0) || (_priority > 100)) { if ((_priority < 0) || (_priority > 100)) {
_priority = external ? DEFAULT_EXTERNAL_PRIORITY : DEFAULT_PRIORITY; _priority = external ? DEFAULT_EXTERNAL_PRIORITY : DEFAULT_PRIORITY;
+1 -1
View File
@@ -61,7 +61,7 @@ public:
void PrintStatus(); void PrintStatus();
void set_calibration_index(uint8_t calibration_index) { _calibration_index = calibration_index; } void set_calibration_index(uint8_t calibration_index) { _calibration_index = calibration_index; }
void set_device_id(uint32_t device_id); void set_device_id(uint32_t device_id, bool external = false);
void set_external(bool external = true); void set_external(bool external = true);
void set_offset(const matrix::Vector3f &offset) { _offset = offset; } void set_offset(const matrix::Vector3f &offset) { _offset = offset; }
void set_scale(const matrix::Vector3f &scale); void set_scale(const matrix::Vector3f &scale);
+1 -2
View File
@@ -451,8 +451,7 @@ calibrate_return mag_calibrate_all(orb_advert_t *mavlink_log_pub, int32_t cal_ma
uORB::SubscriptionData<sensor_mag_s> mag_sub{ORB_ID(sensor_mag), cur_mag}; uORB::SubscriptionData<sensor_mag_s> mag_sub{ORB_ID(sensor_mag), cur_mag};
if (mag_sub.advertised() && (mag_sub.get().device_id != 0) && (mag_sub.get().timestamp > 0)) { if (mag_sub.advertised() && (mag_sub.get().device_id != 0) && (mag_sub.get().timestamp > 0)) {
worker_data.calibration[cur_mag].set_device_id(mag_sub.get().device_id); worker_data.calibration[cur_mag].set_device_id(mag_sub.get().device_id, mag_sub.get().is_external);
worker_data.calibration[cur_mag].set_external(mag_sub.get().is_external);
} }
// reset calibration index to match uORB numbering // reset calibration index to match uORB numbering
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_ACC0_ID, 0);
/** /**
* Accelerometer 0 priority. * Accelerometer 0 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_ACC0_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_ACC0_PRIO, 50); PARAM_DEFINE_INT32(CAL_ACC0_PRIO, -1);
/** /**
* Accelerometer X-axis offset * Accelerometer X-axis offset
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_ACC1_ID, 0);
/** /**
* Accelerometer 1 priority. * Accelerometer 1 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_ACC1_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_ACC1_PRIO, 50); PARAM_DEFINE_INT32(CAL_ACC1_PRIO, -1);
/** /**
* Accelerometer X-axis offset * Accelerometer X-axis offset
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_ACC2_ID, 0);
/** /**
* Accelerometer 2 priority. * Accelerometer 2 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_ACC2_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_ACC2_PRIO, 50); PARAM_DEFINE_INT32(CAL_ACC2_PRIO, -1);
/** /**
* Accelerometer X-axis offset * Accelerometer X-axis offset
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_GYRO0_ID, 0);
/** /**
* Gyro 0 priority. * Gyro 0 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_GYRO0_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_GYRO0_PRIO, 50); PARAM_DEFINE_INT32(CAL_GYRO0_PRIO, -1);
/** /**
* Gyro X-axis offset * Gyro X-axis offset
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_GYRO1_ID, 0);
/** /**
* Gyro 1 priority. * Gyro 1 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_GYRO1_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_GYRO1_PRIO, 50); PARAM_DEFINE_INT32(CAL_GYRO1_PRIO, -1);
/** /**
* Gyro X-axis offset * Gyro X-axis offset
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_GYRO2_ID, 0);
/** /**
* Gyro 2 priority. * Gyro 2 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_GYRO2_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_GYRO2_PRIO, 50); PARAM_DEFINE_INT32(CAL_GYRO2_PRIO, -1);
/** /**
* Gyro X-axis offset * Gyro X-axis offset
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_MAG0_ID, 0);
/** /**
* Mag 0 priority. * Mag 0 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_MAG0_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_MAG0_PRIO, 50); PARAM_DEFINE_INT32(CAL_MAG0_PRIO, -1);
/** /**
* Rotation of magnetometer 0 relative to airframe. * Rotation of magnetometer 0 relative to airframe.
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_MAG1_ID, 0);
/** /**
* Mag 1 priority. * Mag 1 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_MAG1_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_MAG1_PRIO, 50); PARAM_DEFINE_INT32(CAL_MAG1_PRIO, -1);
/** /**
* Rotation of magnetometer 1 relative to airframe. * Rotation of magnetometer 1 relative to airframe.
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_MAG2_ID, 0);
/** /**
* Mag 2 priority. * Mag 2 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_MAG2_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_MAG2_PRIO, 50); PARAM_DEFINE_INT32(CAL_MAG2_PRIO, -1);
/** /**
* Rotation of magnetometer 2 relative to airframe. * Rotation of magnetometer 2 relative to airframe.
+2 -1
View File
@@ -42,6 +42,7 @@ PARAM_DEFINE_INT32(CAL_MAG3_ID, 0);
/** /**
* Mag 3 priority. * Mag 3 priority.
* *
* @value -1 Uninitialized
* @value 0 Disabled * @value 0 Disabled
* @value 1 Min * @value 1 Min
* @value 25 Low * @value 25 Low
@@ -52,7 +53,7 @@ PARAM_DEFINE_INT32(CAL_MAG3_ID, 0);
* @category system * @category system
* @group Sensor Calibration * @group Sensor Calibration
*/ */
PARAM_DEFINE_INT32(CAL_MAG3_PRIO, 50); PARAM_DEFINE_INT32(CAL_MAG3_PRIO, -1);
/** /**
* Rotation of magnetometer 3 relative to airframe. * Rotation of magnetometer 3 relative to airframe.
@@ -224,8 +224,7 @@ void VehicleMagnetometer::Run()
updated[uorb_index] = true; updated[uorb_index] = true;
if (_calibration[uorb_index].device_id() != report.device_id) { if (_calibration[uorb_index].device_id() != report.device_id) {
_calibration[uorb_index].set_external(report.is_external); _calibration[uorb_index].set_device_id(report.device_id, report.is_external);
_calibration[uorb_index].set_device_id(report.device_id);
_priority[uorb_index] = _calibration[uorb_index].priority(); _priority[uorb_index] = _calibration[uorb_index].priority();
} }