ardupilot/libraries/AP_TempCalibration/AP_TempCalibration.h
Andrew Tridgell 177284bd6b AP_TempCalibration: temperature calibration library
this adds opportunistic temperature calibration. This is initially only
for barometers, and has been only tested with the ICM-20789, but can be
extended to other sensors and other barometers
2018-02-08 17:36:33 +11:00

80 lines
2.1 KiB
C++

#pragma once
/*
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/*
temperature calibration library. This monitors temperature changes
and opportunistically calibrates sensors when the vehicle is still
*/
#include <AP_HAL/AP_HAL.h>
#include <AP_Param/AP_Param.h>
#include <AP_Baro/AP_Baro.h>
#include <AP_InertialSensor/AP_InertialSensor.h>
class AP_TempCalibration
{
public:
// constructor
AP_TempCalibration(AP_Baro &baro, AP_InertialSensor &ins);
// settable parameters
static const struct AP_Param::GroupInfo var_info[];
void update(void);
enum {
TC_DISABLED = 0,
TC_ENABLE_USE = 1,
TC_ENABLE_LEARN = 2,
};
private:
AP_Baro &baro;
AP_InertialSensor &ins;
AP_Int8 enabled;
AP_Int8 temp_min;
AP_Int8 temp_max;
AP_Float baro_exponent;
Vector3f last_accels;
float learn_temp_start;
float learn_temp_step;
uint16_t learn_count;
uint16_t learn_i;
float *learn_values;
uint32_t last_learn_ms;
// temperature at which baro correction starts
const float Tzero = 25;
const float exp_limit_max = 2;
const float exp_limit_min = 0;
float learn_delta = 0.01;
// require observation of at least 5 degrees of temp range to
// start learning
const float min_learn_temp_range = 7;
void setup_learning(void);
void learn_calibration(void);
void apply_calibration(void);
void calculate_calibration();
float calculate_correction(float temp, float exponent) const;
float calculate_p_range(float baro_factor) const;
};