mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
3c66cb8af1
this keeps the true airspeed ratio in the airspeed driver, which seems the most logical place
141 lines
3.5 KiB
C++
141 lines
3.5 KiB
C++
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
#ifndef __AP_AIRSPEED_H__
|
|
#define __AP_AIRSPEED_H__
|
|
|
|
#include <AP_Common.h>
|
|
#include <AP_HAL.h>
|
|
#include <AP_Param.h>
|
|
|
|
class Airspeed_Calibration {
|
|
public:
|
|
// constructor
|
|
Airspeed_Calibration(void);
|
|
|
|
// initialise the calibration
|
|
void init(float initial_ratio);
|
|
|
|
// take current airspeed in m/s and ground speed vector and return
|
|
// new scaling factor
|
|
float update(float airspeed, const Vector3f &vg);
|
|
|
|
private:
|
|
// state of kalman filter for airspeed ratio estimation
|
|
Matrix3f P; // covarience matrix
|
|
const float Q0; // process noise matrix top left and middle element
|
|
const float Q1; // process noise matrix bottom right element
|
|
Vector3f state; // state vector
|
|
const float DT; // time delta
|
|
};
|
|
|
|
class AP_Airspeed
|
|
{
|
|
public:
|
|
// constructor
|
|
AP_Airspeed() :
|
|
_ets_fd(-1),
|
|
_EAS2TAS(1.0f)
|
|
{
|
|
AP_Param::setup_object_defaults(this, var_info);
|
|
};
|
|
|
|
void init(void);
|
|
|
|
// read the analog source and update _airspeed
|
|
void read(void);
|
|
|
|
// calibrate the airspeed. This must be called on startup if the
|
|
// altitude/climb_rate/acceleration interfaces are ever used
|
|
void calibrate();
|
|
|
|
// return the current airspeed in m/s
|
|
float get_airspeed(void) const {
|
|
return _airspeed;
|
|
}
|
|
|
|
// return the unfiltered airspeed in m/s
|
|
float get_raw_airspeed(void) const {
|
|
return _raw_airspeed;
|
|
}
|
|
|
|
// return the current airspeed in cm/s
|
|
float get_airspeed_cm(void) const {
|
|
return _airspeed*100;
|
|
}
|
|
|
|
// return the current airspeed ratio (dimensionless)
|
|
float get_airspeed_ratio(void) const {
|
|
return _ratio;
|
|
}
|
|
|
|
// set the airspeed ratio (dimensionless)
|
|
void set_airspeed_ratio(float ratio) {
|
|
_ratio.set(ratio);
|
|
}
|
|
|
|
// return true if airspeed is enabled, and airspeed use is set
|
|
bool use(void) const {
|
|
return _enable && _use && _offset != 0;
|
|
}
|
|
|
|
// return true if airspeed is enabled
|
|
bool enabled(void) const {
|
|
return _enable;
|
|
}
|
|
|
|
// force disable the airspeed sensor
|
|
void disable(void) {
|
|
_enable.set(0);
|
|
}
|
|
|
|
// used by HIL to set the airspeed
|
|
void set_HIL(float airspeed) {
|
|
_airspeed = airspeed;
|
|
}
|
|
|
|
// return the differential pressure in Pascal for the last
|
|
// airspeed reading. Used by the calibration code
|
|
float get_differential_pressure(void) const {
|
|
return max(_last_pressure - _offset, 0);
|
|
}
|
|
|
|
// set the apparent to true airspeed ratio
|
|
void set_EAS2TAS(float v) {
|
|
_EAS2TAS = v;
|
|
}
|
|
|
|
// get the apparent to true airspeed ratio
|
|
float get_EAS2TAS(void) const {
|
|
return _EAS2TAS;
|
|
}
|
|
|
|
// update airspeed ratio calibration
|
|
void update_calibration(Vector3f vground);
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
private:
|
|
AP_HAL::AnalogSource *_source;
|
|
AP_Float _offset;
|
|
AP_Float _ratio;
|
|
AP_Int8 _use;
|
|
AP_Int8 _enable;
|
|
AP_Int8 _pin;
|
|
AP_Int8 _autocal;
|
|
float _raw_airspeed;
|
|
float _airspeed;
|
|
int _ets_fd;
|
|
float _last_pressure;
|
|
float _EAS2TAS;
|
|
|
|
Airspeed_Calibration _calibration;
|
|
float _last_saved_ratio;
|
|
uint8_t _counter;
|
|
|
|
// return raw differential pressure in Pascal
|
|
float get_pressure(void);
|
|
};
|
|
|
|
#endif // __AP_AIRSPEED_H__
|
|
|