-
Notifications
You must be signed in to change notification settings - Fork 17.9k
/
Copy pathVariometer.h
87 lines (56 loc) · 2.22 KB
/
Variometer.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/* Variometer class by Samuel Tabor
Manages the estimation of aircraft total energy, drag and vertical air velocity.
*/
#pragma once
#include <AP_Param/AP_Param.h>
#include <Filter/AverageFilter.h>
#include <Filter/LowPassFilter.h>
#include <AP_Vehicle/AP_FixedWing.h>
#include <AP_Common/Location.h>
class Variometer {
const AP_FixedWing &_aparm;
// store time of last update
uint64_t _prev_update_time;
float _raw_climb_rate;
float _aspd_filt_constrained;
float _expected_thermalling_sink;
// declares a 5point average filter using floats
AverageFilterFloat_Size5 _vdot_filter;
AverageFilterFloat_Size5 _sp_filter;
/*
low pass filters for various purposes.
*/
// Climb rate filter for monitoring progress in thermal.
LowPassFilter<float> _climb_filter{1/60.0};
// Fast filter for mavlink/audio vario output.
LowPassFilter<float> _audio_filter{1/0.71};
// Slower filter for deciding to enter THERMAL mode.
LowPassFilter<float> _trigger_filter{1/4.06};
// Longitudinal acceleration bias filter.
LowPassFilter<float> _vdotbias_filter{1/60.0};
// Speed to fly vario filter.
LowPassFilter<float> _stf_filter{1/20.0};
public:
struct PolarParams {
AP_Float K;
AP_Float CD0;
AP_Float B;
};
Variometer(const AP_FixedWing &parms, const PolarParams &polarParams);
float alt;
float reading;
float tau;
void update(const float thermal_bank);
float calculate_aircraft_sinkrate(float phi) const;
void reset_climb_filter(float value) { _climb_filter.reset(value);}
void reset_trigger_filter(float value) { _trigger_filter.reset(value);}
float get_airspeed(void) const {return _aspd_filt_constrained;};
float get_displayed_value(void) const {return _audio_filter.get();};
float get_filtered_climb(void) const {return _climb_filter.get();};
float get_trigger_value(void) const {return _trigger_filter.get();};
float get_stf_value(void) const {return _stf_filter.get();};
float get_exp_thermalling_sink(void) const {return _expected_thermalling_sink;};
float calculate_circling_time_constant(const float thermal_bank) const;
private:
const PolarParams &_polarParams;
};