Plane: added AUTOTUNE flight mode

this is just like FBWA, but with automatic roll/pitch tuning
This commit is contained in:
Andrew Tridgell 2014-04-12 14:12:14 +10:00
parent 50fc75917e
commit 1bce4239a3
9 changed files with 63 additions and 21 deletions

View File

@ -1230,6 +1230,7 @@ static void update_flight_mode(void)
break; break;
} }
case AUTOTUNE:
case FLY_BY_WIRE_A: { case FLY_BY_WIRE_A: {
// set nav_roll and nav_pitch using sticks // set nav_roll and nav_pitch using sticks
nav_roll_cd = channel_roll->norm_input() * roll_limit_cd; nav_roll_cd = channel_roll->norm_input() * roll_limit_cd;
@ -1342,6 +1343,7 @@ static void update_navigation()
case INITIALISING: case INITIALISING:
case ACRO: case ACRO:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
case AUTOTUNE:
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
case CIRCLE: case CIRCLE:
// nothing to do // nothing to do

View File

@ -130,6 +130,7 @@ static void stabilize_stick_mixing_direct()
if (!stick_mixing_enabled() || if (!stick_mixing_enabled() ||
control_mode == ACRO || control_mode == ACRO ||
control_mode == FLY_BY_WIRE_A || control_mode == FLY_BY_WIRE_A ||
control_mode == AUTOTUNE ||
control_mode == FLY_BY_WIRE_B || control_mode == FLY_BY_WIRE_B ||
control_mode == CRUISE || control_mode == CRUISE ||
control_mode == TRAINING) { control_mode == TRAINING) {
@ -148,6 +149,7 @@ static void stabilize_stick_mixing_fbw()
if (!stick_mixing_enabled() || if (!stick_mixing_enabled() ||
control_mode == ACRO || control_mode == ACRO ||
control_mode == FLY_BY_WIRE_A || control_mode == FLY_BY_WIRE_A ||
control_mode == AUTOTUNE ||
control_mode == FLY_BY_WIRE_B || control_mode == FLY_BY_WIRE_B ||
control_mode == CRUISE || control_mode == CRUISE ||
control_mode == TRAINING || control_mode == TRAINING ||
@ -842,7 +844,8 @@ static void set_servos(void)
(control_mode == STABILIZE || (control_mode == STABILIZE ||
control_mode == TRAINING || control_mode == TRAINING ||
control_mode == ACRO || control_mode == ACRO ||
control_mode == FLY_BY_WIRE_A)) { control_mode == FLY_BY_WIRE_A ||
control_mode == AUTOTUNE)) {
// manual pass through of throttle while in FBWA or // manual pass through of throttle while in FBWA or
// STABILIZE mode with THR_PASS_STAB set // STABILIZE mode with THR_PASS_STAB set
channel_throttle->radio_out = channel_throttle->radio_in; channel_throttle->radio_out = channel_throttle->radio_in;

View File

@ -51,6 +51,7 @@ static NOINLINE void send_heartbeat(mavlink_channel_t chan)
break; break;
case STABILIZE: case STABILIZE:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
case AUTOTUNE:
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
case CRUISE: case CRUISE:
base_mode = MAV_MODE_FLAG_STABILIZE_ENABLED; base_mode = MAV_MODE_FLAG_STABILIZE_ENABLED;
@ -174,6 +175,7 @@ static NOINLINE void send_extended_status1(mavlink_channel_t chan)
case STABILIZE: case STABILIZE:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
case AUTOTUNE:
control_sensors_enabled |= MAV_SYS_STATUS_SENSOR_ANGULAR_RATE_CONTROL; // 3D angular rate control control_sensors_enabled |= MAV_SYS_STATUS_SENSOR_ANGULAR_RATE_CONTROL; // 3D angular rate control
control_sensors_enabled |= MAV_SYS_STATUS_SENSOR_ATTITUDE_STABILIZATION; // attitude stabilisation control_sensors_enabled |= MAV_SYS_STATUS_SENSOR_ATTITUDE_STABILIZATION; // attitude stabilisation
break; break;
@ -1339,6 +1341,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
case TRAINING: case TRAINING:
case ACRO: case ACRO:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
case AUTOTUNE:
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
case CRUISE: case CRUISE:
case AUTO: case AUTO:

View File

@ -471,7 +471,7 @@ const AP_Param::Info var_info[] PROGMEM = {
// @Param: FLTMODE1 // @Param: FLTMODE1
// @DisplayName: FlightMode1 // @DisplayName: FlightMode1
// @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,10:Auto,11:RTL,12:Loiter,15:Guided // @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,8:AUTOTUNE,10:Auto,11:RTL,12:Loiter,15:Guided
// @User: Standard // @User: Standard
// @Description: Flight mode for switch position 1 (910 to 1230 and above 2049) // @Description: Flight mode for switch position 1 (910 to 1230 and above 2049)
GSCALAR(flight_mode1, "FLTMODE1", FLIGHT_MODE_1), GSCALAR(flight_mode1, "FLTMODE1", FLIGHT_MODE_1),
@ -479,35 +479,35 @@ const AP_Param::Info var_info[] PROGMEM = {
// @Param: FLTMODE2 // @Param: FLTMODE2
// @DisplayName: FlightMode2 // @DisplayName: FlightMode2
// @Description: Flight mode for switch position 2 (1231 to 1360) // @Description: Flight mode for switch position 2 (1231 to 1360)
// @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,10:Auto,11:RTL,12:Loiter,15:Guided // @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,8:AUTOTUNE,10:Auto,11:RTL,12:Loiter,15:Guided
// @User: Standard // @User: Standard
GSCALAR(flight_mode2, "FLTMODE2", FLIGHT_MODE_2), GSCALAR(flight_mode2, "FLTMODE2", FLIGHT_MODE_2),
// @Param: FLTMODE3 // @Param: FLTMODE3
// @DisplayName: FlightMode3 // @DisplayName: FlightMode3
// @Description: Flight mode for switch position 3 (1361 to 1490) // @Description: Flight mode for switch position 3 (1361 to 1490)
// @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,10:Auto,11:RTL,12:Loiter,15:Guided // @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,8:AUTOTUNE,10:Auto,11:RTL,12:Loiter,15:Guided
// @User: Standard // @User: Standard
GSCALAR(flight_mode3, "FLTMODE3", FLIGHT_MODE_3), GSCALAR(flight_mode3, "FLTMODE3", FLIGHT_MODE_3),
// @Param: FLTMODE4 // @Param: FLTMODE4
// @DisplayName: FlightMode4 // @DisplayName: FlightMode4
// @Description: Flight mode for switch position 4 (1491 to 1620) // @Description: Flight mode for switch position 4 (1491 to 1620)
// @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,10:Auto,11:RTL,12:Loiter,15:Guided // @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,8:AUTOTUNE,10:Auto,11:RTL,12:Loiter,15:Guided
// @User: Standard // @User: Standard
GSCALAR(flight_mode4, "FLTMODE4", FLIGHT_MODE_4), GSCALAR(flight_mode4, "FLTMODE4", FLIGHT_MODE_4),
// @Param: FLTMODE5 // @Param: FLTMODE5
// @DisplayName: FlightMode5 // @DisplayName: FlightMode5
// @Description: Flight mode for switch position 5 (1621 to 1749) // @Description: Flight mode for switch position 5 (1621 to 1749)
// @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,10:Auto,11:RTL,12:Loiter,15:Guided // @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,8:AUTOTUNE,10:Auto,11:RTL,12:Loiter,15:Guided
// @User: Standard // @User: Standard
GSCALAR(flight_mode5, "FLTMODE5", FLIGHT_MODE_5), GSCALAR(flight_mode5, "FLTMODE5", FLIGHT_MODE_5),
// @Param: FLTMODE6 // @Param: FLTMODE6
// @DisplayName: FlightMode6 // @DisplayName: FlightMode6
// @Description: Flight mode for switch position 6 (1750 to 2049) // @Description: Flight mode for switch position 6 (1750 to 2049)
// @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,10:Auto,11:RTL,12:Loiter,15:Guided // @Values: 0:Manual,1:CIRCLE,2:STABILIZE,3:TRAINING,4:ACRO,5:FBWA,6:FBWB,7:CRUISE,8:AUTOTUNE,10:Auto,11:RTL,12:Loiter,15:Guided
// @User: Standard // @User: Standard
GSCALAR(flight_mode6, "FLTMODE6", FLIGHT_MODE_6), GSCALAR(flight_mode6, "FLTMODE6", FLIGHT_MODE_6),

View File

@ -79,3 +79,20 @@ static void reset_control_switch()
read_control_switch(); read_control_switch();
} }
/*
called when entering autotune
*/
static void autotune_start(void)
{
rollController.autotune_start();
pitchController.autotune_start();
}
/*
called when exiting autotune
*/
static void autotune_restore(void)
{
rollController.autotune_restore();
pitchController.autotune_restore();
}

View File

@ -62,6 +62,7 @@ enum FlightMode {
FLY_BY_WIRE_A = 5, FLY_BY_WIRE_A = 5,
FLY_BY_WIRE_B = 6, FLY_BY_WIRE_B = 6,
CRUISE = 7, CRUISE = 7,
AUTOTUNE = 8,
AUTO = 10, AUTO = 10,
RTL = 11, RTL = 11,
LOITER = 12, LOITER = 12,

View File

@ -13,6 +13,7 @@ static void failsafe_short_on_event(enum failsafe_state fstype)
case STABILIZE: case STABILIZE:
case ACRO: case ACRO:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
case AUTOTUNE:
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
case CRUISE: case CRUISE:
case TRAINING: case TRAINING:
@ -60,6 +61,7 @@ static void failsafe_long_on_event(enum failsafe_state fstype)
case STABILIZE: case STABILIZE:
case ACRO: case ACRO:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
case AUTOTUNE:
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
case CRUISE: case CRUISE:
case TRAINING: case TRAINING:

View File

@ -310,6 +310,7 @@ setup_flightmodes(uint8_t argc, const Menu::arg *argv)
mode != TRAINING && mode != TRAINING &&
mode != ACRO && mode != ACRO &&
mode != FLY_BY_WIRE_A && mode != FLY_BY_WIRE_A &&
mode != AUTOTUNE &&
mode != FLY_BY_WIRE_B && mode != FLY_BY_WIRE_B &&
mode != CRUISE && mode != CRUISE &&
mode != AUTO && mode != AUTO &&

View File

@ -292,36 +292,55 @@ static void set_mode(enum FlightMode mode)
previous_mode = control_mode; previous_mode = control_mode;
control_mode = mode; control_mode = mode;
if (previous_mode == AUTOTUNE && control_mode != AUTOTUNE) {
// restore last gains
autotune_restore();
}
switch(control_mode) switch(control_mode)
{ {
case INITIALISING: case INITIALISING:
auto_throttle_mode = true;
break;
case MANUAL: case MANUAL:
case STABILIZE: case STABILIZE:
case TRAINING: case TRAINING:
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
auto_throttle_mode = false;
break;
case AUTOTUNE:
auto_throttle_mode = false;
autotune_start();
break; break;
case ACRO: case ACRO:
auto_throttle_mode = false;
acro_state.locked_roll = false; acro_state.locked_roll = false;
acro_state.locked_pitch = false; acro_state.locked_pitch = false;
break; break;
case CRUISE: case CRUISE:
auto_throttle_mode = true;
cruise_state.locked_heading = false; cruise_state.locked_heading = false;
cruise_state.lock_timer_ms = 0; cruise_state.lock_timer_ms = 0;
target_altitude_cm = current_loc.alt; target_altitude_cm = current_loc.alt;
break; break;
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
auto_throttle_mode = true;
target_altitude_cm = current_loc.alt; target_altitude_cm = current_loc.alt;
break; break;
case CIRCLE: case CIRCLE:
// the altitude to circle at is taken from the current altitude // the altitude to circle at is taken from the current altitude
auto_throttle_mode = true;
next_WP_loc.alt = current_loc.alt; next_WP_loc.alt = current_loc.alt;
break; break;
case AUTO: case AUTO:
auto_throttle_mode = true;
prev_WP_loc = current_loc; prev_WP_loc = current_loc;
// start the mission. Note that we use resume(), not start(), // start the mission. Note that we use resume(), not start(),
// as the correct behaviour for plane when entering auto is to // as the correct behaviour for plane when entering auto is to
@ -332,34 +351,25 @@ static void set_mode(enum FlightMode mode)
break; break;
case RTL: case RTL:
auto_throttle_mode = true;
prev_WP_loc = current_loc; prev_WP_loc = current_loc;
do_RTL(); do_RTL();
break; break;
case LOITER: case LOITER:
auto_throttle_mode = true;
do_loiter_at_location(); do_loiter_at_location();
break; break;
case GUIDED: case GUIDED:
auto_throttle_mode = true;
guided_throttle_passthru = false; guided_throttle_passthru = false;
set_guided_WP(); set_guided_WP();
break; break;
default:
prev_WP_loc = current_loc;
do_RTL();
break;
} }
// if in an auto-throttle mode, start with throttle suppressed for // start with throttle suppressed in auto_throttle modes
// safety. suppress_throttle() will unsupress it when appropriate throttle_suppressed = auto_throttle_mode;
if (control_mode == CIRCLE || control_mode >= FLY_BY_WIRE_B) {
auto_throttle_mode = true;
throttle_suppressed = true;
} else {
auto_throttle_mode = false;
throttle_suppressed = false;
}
if (should_log(MASK_LOG_MODE)) if (should_log(MASK_LOG_MODE))
Log_Write_Mode(control_mode); Log_Write_Mode(control_mode);
@ -565,6 +575,9 @@ print_flight_mode(AP_HAL::BetterStream *port, uint8_t mode)
case FLY_BY_WIRE_A: case FLY_BY_WIRE_A:
port->print_P(PSTR("FBW_A")); port->print_P(PSTR("FBW_A"));
break; break;
case AUTOTUNE:
port->print_P(PSTR("AUTOTUNE"));
break;
case FLY_BY_WIRE_B: case FLY_BY_WIRE_B:
port->print_P(PSTR("FBW_B")); port->print_P(PSTR("FBW_B"));
break; break;