APM: use ahrs.airspeed_estimate() in two more places

this applies the wind constraint
This commit is contained in:
Andrew Tridgell 2012-09-08 11:31:55 +10:00
parent de28cc8b28
commit dec12c7370
2 changed files with 9 additions and 8 deletions

View File

@ -1091,12 +1091,15 @@ static void update_current_flight_mode(void)
nav_pitch_cd = constrain(nav_pitch_cd, 500, takeoff_pitch_cd);
}
// don't use a pitch/roll integrators during takeoff if we are
// below minimum speed
#if APM_CONTROL == DISABLED
if (airspeed.use() && airspeed.get_airspeed() < g.flybywire_airspeed_min) {
g.pidServoPitch.reset_I();
g.pidServoRoll.reset_I();
float aspeed;
if (ahrs.airspeed_estimate(&aspeed)) {
// don't use a pitch/roll integrators during takeoff if we are
// below minimum speed
if (aspeed < g.flybywire_airspeed_min) {
g.pidServoPitch.reset_I();
g.pidServoRoll.reset_I();
}
}
#endif

View File

@ -220,9 +220,7 @@ static void calc_nav_roll()
// Use airspeed_cruise as an analogue for airspeed if we don't have airspeed.
float speed;
if(airspeed.use()) {
speed = airspeed.get_airspeed();
} else {
if (!ahrs.airspeed_estimate(&speed)) {
speed = g.airspeed_cruise_cm*0.01;
// Floor the speed so that the user can't enter a bad value