Rover: removed some more plane specific variables

This commit is contained in:
Andrew Tridgell 2012-11-29 18:09:05 +11:00
parent ebafad7a6b
commit e924460881
7 changed files with 21 additions and 57 deletions

View File

@ -14,24 +14,3 @@
#define TRACE DISABLED #define TRACE DISABLED
//#define LOGGING_ENABLED DISABLED
//#include "APM_Config_HILmode.h" // for test in HIL mode with AeroSIM Rc 3.83
//#include "APM_Config_Rover.h" // to be used with the real Traxxas model Monster Jam Grinder
// Radio setup:
// APM INPUT (Rec = receiver)
// Rec ch1: Roll
// Rec ch2: Throttle
// Rec ch3: Pitch
// Rec ch4: Yaw
// Rec ch5: not used
// Rec ch6:
// Rec ch7: Option channel to 2 positions switch
// Rec ch8: Mode channel to 3 positions switch
// APM OUTPUT
// Ch1: Wheel servo (direction)
// Ch2: not used
// Ch3: to the motor ESC
// Ch4: not used

View File

@ -354,9 +354,7 @@ static int16_t failsafe;
// Used to track if the value on channel 3 (throtttle) has fallen below the failsafe threshold // Used to track if the value on channel 3 (throtttle) has fallen below the failsafe threshold
// RC receiver should be set up to output a low throttle value when signal is lost // RC receiver should be set up to output a low throttle value when signal is lost
static bool ch3_failsafe; static bool ch3_failsafe;
// A timer used to help recovery from unusual attitudes. If we enter an unusual attitude
// while in autonomous flight this variable is used to hold roll at 0 for a recovery period
static byte crash_timer;
// A timer used to track how long since we have received the last GCS heartbeat or rc override message // A timer used to track how long since we have received the last GCS heartbeat or rc override message
static uint32_t rc_override_fs_timer = 0; static uint32_t rc_override_fs_timer = 0;
// A timer used to track how long we have been in a "short failsafe" condition due to loss of RC signal // A timer used to track how long we have been in a "short failsafe" condition due to loss of RC signal
@ -481,8 +479,6 @@ static bool speed_boost = false;
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// The instantaneous desired bank angle. Hundredths of a degree // The instantaneous desired bank angle. Hundredths of a degree
static int32_t nav_roll; static int32_t nav_roll;
// The instantaneous desired pitch angle. Hundredths of a degree
static int32_t nav_pitch;
// Calculated radius for the wp turn based on ground speed and max turn angle // Calculated radius for the wp turn based on ground speed and max turn angle
static int32_t wp_radius; static int32_t wp_radius;
@ -935,7 +931,6 @@ static void update_current_flight_mode(void)
case LEARNING: case LEARNING:
case MANUAL: case MANUAL:
nav_roll = 0; nav_roll = 0;
nav_pitch = 0;
g.channel_roll.servo_out = g.channel_roll.pwm_to_angle(); g.channel_roll.servo_out = g.channel_roll.pwm_to_angle();
g.channel_pitch.servo_out = g.channel_pitch.pwm_to_angle(); g.channel_pitch.servo_out = g.channel_pitch.pwm_to_angle();
g.channel_rudder.servo_out = g.channel_roll.pwm_to_angle(); g.channel_rudder.servo_out = g.channel_roll.pwm_to_angle();
@ -945,25 +940,20 @@ static void update_current_flight_mode(void)
static void update_navigation() static void update_navigation()
{ {
// wp_distance is in ACTUAL meters, not the *100 meters we get from the GPS switch (control_mode) {
// ------------------------------------------------------------------------ case AUTO:
// distance and bearing calcs only
if(control_mode == AUTO){
verify_commands(); verify_commands();
}else{ break;
switch(control_mode){ case RTL:
case RTL: // no loitering around the wp with the rover, goes direct to the wp position case GUIDED:
case GUIDED: // no loitering around the wp with the rover, goes direct to the wp position
calc_nav_roll(); calc_nav_roll();
calc_bearing_error(); calc_bearing_error();
if(verify_RTL()) { if(verify_RTL()) {
g.channel_throttle.servo_out = g.throttle_min.get(); g.channel_throttle.servo_out = g.throttle_min.get();
set_mode(MANUAL); set_mode(MANUAL);
} }
break; break;
}
} }
} }

View File

@ -54,7 +54,6 @@ static void calc_throttle()
static void calc_nav_roll() static void calc_nav_roll()
{ {
// Adjust gain based on ground speed // Adjust gain based on ground speed
nav_gain_scaler = (float)ground_speed / (g.airspeed_cruise * 100.0); nav_gain_scaler = (float)ground_speed / (g.airspeed_cruise * 100.0);
nav_gain_scaler = constrain(nav_gain_scaler, 0.2, 1.4); nav_gain_scaler = constrain(nav_gain_scaler, 0.2, 1.4);
@ -62,17 +61,16 @@ static void calc_nav_roll()
// Calculate the required turn of the wheels rover // Calculate the required turn of the wheels rover
// ---------------------------------------- // ----------------------------------------
// negative error = left turn // negative error = left turn
// positive error = right turn // positive error = right turn
nav_roll = g.pidNavRoll.get_pid(bearing_error, nav_gain_scaler); //returns desired bank angle in degrees*100 nav_roll = g.pidNavRoll.get_pid(bearing_error, nav_gain_scaler); //returns desired bank angle in degrees*100
if(obstacle) { // obstacle avoidance if(obstacle) { // obstacle avoidance
nav_roll += 9000; // if obstacle in front turn 90° right nav_roll += 9000; // if obstacle in front turn 90° right
speed_boost = false; speed_boost = false;
} }
nav_roll = constrain(nav_roll, -g.roll_limit.get(), g.roll_limit.get()); nav_roll = constrain(nav_roll, -g.roll_limit.get(), g.roll_limit.get());
} }
// Zeros out navigation Integrators if we are changing mode, have passed a waypoint, etc. // Zeros out navigation Integrators if we are changing mode, have passed a waypoint, etc.
@ -81,7 +79,6 @@ static void reset_I(void)
{ {
g.pidNavRoll.reset_I(); g.pidNavRoll.reset_I();
g.pidTeThrottle.reset_I(); g.pidTeThrottle.reset_I();
// g.pidAltitudeThrottle.reset_I();
} }
/***************************************** /*****************************************

View File

@ -218,7 +218,7 @@ static void NOINLINE send_nav_controller_output(mavlink_channel_t chan)
mavlink_msg_nav_controller_output_send( mavlink_msg_nav_controller_output_send(
chan, chan,
nav_roll / 1.0e2, nav_roll / 1.0e2,
nav_pitch / 1.0e2, 0,
bearing, bearing,
target_bearing / 100, target_bearing / 100,
wp_distance, wp_distance,

View File

@ -304,7 +304,7 @@ static void Log_Write_Control_Tuning()
DataFlash.WriteInt((int)nav_roll); DataFlash.WriteInt((int)nav_roll);
DataFlash.WriteInt((int)ahrs.roll_sensor); DataFlash.WriteInt((int)ahrs.roll_sensor);
DataFlash.WriteInt((int)(g.channel_pitch.servo_out)); DataFlash.WriteInt((int)(g.channel_pitch.servo_out));
DataFlash.WriteInt((int)nav_pitch); DataFlash.WriteInt(0); // nav_pitch
DataFlash.WriteInt((int)ahrs.pitch_sensor); DataFlash.WriteInt((int)ahrs.pitch_sensor);
DataFlash.WriteInt((int)(g.channel_throttle.servo_out)); DataFlash.WriteInt((int)(g.channel_throttle.servo_out));
DataFlash.WriteInt((int)(g.channel_rudder.servo_out)); DataFlash.WriteInt((int)(g.channel_rudder.servo_out));

View File

@ -172,9 +172,8 @@ static bool verify_condition_command() // Returns true if command complete
static void do_RTL(void) static void do_RTL(void)
{ {
prev_WP = current_loc; prev_WP = current_loc;
control_mode = RTL; control_mode = RTL;
crash_timer = 0;
next_WP = home; next_WP = home;
} }

View File

@ -364,7 +364,6 @@ static void set_mode(byte mode)
trim_control_surfaces(); trim_control_surfaces();
control_mode = mode; control_mode = mode;
crash_timer = 0;
throttle_last = 0; throttle_last = 0;
throttle = 500; throttle = 500;