From cc36401b7cbd9da4589b98edb7cb41ca9bd1beb0 Mon Sep 17 00:00:00 2001 From: Jonathan Challinger Date: Wed, 18 Mar 2015 16:42:30 -0700 Subject: [PATCH] AP_Compass: add calibration interface --- .../AP_Compass/AP_Compass_Calibration.cpp | 232 ++++++++++++++++++ libraries/AP_Compass/Compass.cpp | 12 + libraries/AP_Compass/Compass.h | 38 ++- 3 files changed, 275 insertions(+), 7 deletions(-) create mode 100644 libraries/AP_Compass/AP_Compass_Calibration.cpp diff --git a/libraries/AP_Compass/AP_Compass_Calibration.cpp b/libraries/AP_Compass/AP_Compass_Calibration.cpp new file mode 100644 index 0000000000..4768ad183b --- /dev/null +++ b/libraries/AP_Compass/AP_Compass_Calibration.cpp @@ -0,0 +1,232 @@ +/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- +#include +#include "Compass.h" +#include + +void +Compass::compass_cal_update() +{ + AP_Notify::flags.compass_cal_running = 0; + + for(uint8_t i=0; i 0.5f) { + AP_Notify::events.initiated_compass_cal = 1; + } + if(i == get_primary()) { + _calibrator[i].set_tolerance(5); + } else { + _calibrator[i].set_tolerance(10); + } + _calibrator[i].start(retry, autosave, delay); + return true; + } else { + return false; + } +} + +bool +Compass::start_calibration_mask(uint8_t mask, bool retry, bool autosave, float delay) +{ + for(uint8_t i=0; i -#include -#include -#include -#include // ArduPilot Mega Declination Helper Library -#include +#include +#include +#include +#include // ArduPilot Mega Declination Helper Library +#include +#include +#include "CompassCalibrator.h" #include "AP_Compass_Backend.h" // compass product id @@ -109,8 +111,6 @@ public: const Vector3f &get_field(void) const { return get_field(get_primary()); } // raw/unfiltered measurement interface - - uint32_t raw_meas_time_us(uint8_t i) const { return _state[i].raw_meas_time_us; } uint32_t raw_meas_time_us() const { return _state[get_primary()].raw_meas_time_us; } uint32_t unfiltered_meas_time_us(uint8_t i) const { return _state[i].raw_meas_time_us; } @@ -128,9 +128,31 @@ public: const Vector3f &get_unfiltered_field(uint8_t i) const { return _state[i].unfiltered_field; } const Vector3f &get_unfiltered_field(void) const { return get_unfiltered_field(get_primary()); } + // compass calibrator interface + void compass_cal_update(); + + bool start_calibration(uint8_t i, bool retry=false, bool autosave=false, float delay_sec=0.0f); + bool start_calibration_all(bool retry=false, bool autosave=false, float delay_sec=0.0f); + bool start_calibration_mask(uint8_t mask, bool retry=false, bool autosave=false, float delay_sec=0.0f); + + void cancel_calibration(uint8_t i); + void cancel_calibration_all(); + void cancel_calibration_mask(uint8_t mask); + + bool accept_calibration(uint8_t i); + bool accept_calibration_all(); + bool accept_calibration_mask(uint8_t mask); + + uint8_t get_cal_mask() const; + bool is_calibrating() const; + + void send_mag_cal_progress(mavlink_channel_t chan); + void send_mag_cal_report(mavlink_channel_t chan); + /// Return the health of a compass bool healthy(uint8_t i) const { return _state[i].healthy; } bool healthy(void) const { return healthy(get_primary()); } + uint8_t get_healthy_mask() const; /// Returns the current offset values /// @@ -353,6 +375,8 @@ private: Vector3f unfiltered_field; } _state[COMPASS_MAX_INSTANCES]; + CompassCalibrator _calibrator[COMPASS_MAX_INSTANCES]; + // if we want HIL only bool _hil_mode:1; };