AP_TECS: Add non airspeed sensor pitch to throttle mode lost during integration
This commit is contained in:
parent
1355b6d89d
commit
a694b781c7
@ -424,6 +424,28 @@ void AP_TECS::_update_throttle(void)
|
||||
_throttle_dem = constrain_float(_throttle_dem, _THRminf, _THRmaxf);
|
||||
}
|
||||
|
||||
void AP_TECS::_update_throttle_option(void)
|
||||
{
|
||||
// Calculate throttle demand by interpolating between pitch and throttle limits
|
||||
float nomThr = aparm.throttle_cruise * 0.01f;
|
||||
if (_climbOutDem)
|
||||
{
|
||||
_throttle_dem = _THRmaxf;
|
||||
}
|
||||
else if (_pitch_dem > 0.0 && _PITCHmaxf > 0.0)
|
||||
{
|
||||
_throttle_dem = nomThr + (_THRmaxf - nomThr) * _pitch_dem / _PITCHmaxf;
|
||||
}
|
||||
else if (_pitch_dem < 0.0 && _PITCHminf < 0.0)
|
||||
{
|
||||
_throttle_dem = nomThr + (_THRminf - nomThr) * _pitch_dem / _PITCHminf;
|
||||
}
|
||||
else
|
||||
{
|
||||
_throttle_dem = nomThr;
|
||||
}
|
||||
}
|
||||
|
||||
void AP_TECS::_detect_bad_descent(void)
|
||||
{
|
||||
// Detect a demanded airspeed too high for the aircraft to achieve. This will be
|
||||
@ -591,8 +613,12 @@ void AP_TECS::update_pitch_throttle(int32_t hgt_dem_cm, int32_t EAS_dem_cm, bool
|
||||
// Calculate specific energy quantitiues
|
||||
_update_energies();
|
||||
|
||||
// Calculate throttle demand
|
||||
// Calculate throttle demand - use simple pitch to throttle if no airspeed sensor
|
||||
if (_ahrs->airspeed_sensor_enabled()) {
|
||||
_update_throttle();
|
||||
} else {
|
||||
_update_throttle_option();
|
||||
}
|
||||
|
||||
// Detect bad descent due to demanded airspeed being too high
|
||||
_detect_bad_descent();
|
||||
|
@ -241,6 +241,9 @@ private:
|
||||
// Update Demanded Throttle
|
||||
void _update_throttle(void);
|
||||
|
||||
// Update Demanded Throttle Non-Airspeed
|
||||
void _update_throttle_option(void);
|
||||
|
||||
// Detect Bad Descent
|
||||
void _detect_bad_descent(void);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user