/* Variometer class by Samuel Tabor Manages the estimation of aircraft total energy, drag and vertical air velocity. */ #pragma once #include <AP_AHRS/AP_AHRS.h> #include <AP_Param/AP_Param.h> #include <DataFlash/DataFlash.h> #include <AP_SpdHgtControl/AP_SpdHgtControl.h> #define ASPD_FILT 0.05 #define TE_FILT 0.03 #define TE_FILT_DISPLAYED 0.15 class Variometer { AP_AHRS &_ahrs; AP_SpdHgtControl &_spdHgt; const AP_Vehicle::FixedWing &_aparm; // store time of last update unsigned long _prev_update_time; float _last_alt; float _aspd_filt; float _last_aspd; float _last_roll; float _last_total_E; public: Variometer(AP_AHRS &ahrs, AP_SpdHgtControl &spdHgt, const AP_Vehicle::FixedWing &parms); float alt; float reading; float filtered_reading; float displayed_reading; bool new_data; void update(const float polar_K, const float polar_CD0, const float polar_B); float correct_netto_rate(float climb_rate, float phi, float aspd, const float polar_K, const float polar_CD0, const float polar_B); };