Added 5 sec Takeoff Timer to clear i terms when lifting

Moved loiter relocation function to update_nav
moved User hooks to correct place
Added tuning for D term
This commit is contained in:
Jason Short 2011-12-29 10:28:01 -08:00
parent 8a1b9df325
commit aa2e474b80

View File

@ -325,7 +325,6 @@ static int16_t rc_override[8] = {0,0,0,0,0,0,0,0};
static bool rc_override_active = false; static bool rc_override_active = false;
static uint32_t rc_override_fs_timer = 0; static uint32_t rc_override_fs_timer = 0;
// Heli // Heli
// ---- // ----
#if FRAME_CONFIG == HELI_FRAME #if FRAME_CONFIG == HELI_FRAME
@ -450,6 +449,7 @@ static byte roll_pitch_mode;
static byte throttle_mode; static byte throttle_mode;
static boolean takeoff_complete; // Flag for using take-off controls static boolean takeoff_complete; // Flag for using take-off controls
static int32_t takeoff_timer; // time since we throttled up
static boolean land_complete; static boolean land_complete;
static int32_t old_alt; // used for managing altitude rates static int32_t old_alt; // used for managing altitude rates
static int16_t velocity_land; static int16_t velocity_land;
@ -464,7 +464,7 @@ static int32_t old_target_bearing; // used to track difference in angle
static int16_t loiter_total; // deg : how many times to loiter * 360 static int16_t loiter_total; // deg : how many times to loiter * 360
static int16_t loiter_sum; // deg : how far we have turned around a waypoint static int16_t loiter_sum; // deg : how far we have turned around a waypoint
static uint32_t loiter_time; // millis : when we started LOITER mode static uint32_t loiter_time; // millis : when we started LOITER mode
static unsigned loiter_time_max; // millis : how long to stay in LOITER mode static unsigned loiter_time_max; // millis : how long to stay in LOITER mode
@ -518,7 +518,6 @@ static int16_t event_undo_value; // the value used to undo commands
// -------------- // --------------
static int32_t condition_value; // used in condition commands (eg delay, change alt, etc.) static int32_t condition_value; // used in condition commands (eg delay, change alt, etc.)
static int32_t condition_start; static int32_t condition_start;
//static int16_t condition_rate;
// land command // land command
// ------------ // ------------
@ -608,13 +607,19 @@ void loop()
// --------------------- // ---------------------
fast_loop(); fast_loop();
} }
// port manipulation for external timing of main loops
//PORTK &= B11101111; //PORTK &= B11101111;
if ((timer - fiftyhz_loopTimer) >= 20000) { if ((timer - fiftyhz_loopTimer) >= 20000) {
// store the micros for the 50 hz timer
fiftyhz_loopTimer = timer; fiftyhz_loopTimer = timer;
// port manipulation for external timing of main loops
//PORTK |= B01000000; //PORTK |= B01000000;
// reads all of the necessary trig functions for cameras, throttle, etc. // reads all of the necessary trig functions for cameras, throttle, etc.
// --------------------------------------------------------------------
update_trig(); update_trig();
// update our velocity estimate based on IMU at 50hz // update our velocity estimate based on IMU at 50hz
@ -631,7 +636,7 @@ void loop()
counter_one_herz++; counter_one_herz++;
if(counter_one_herz == 50){ if(counter_one_herz >= 50){
super_slow_loop(); super_slow_loop();
counter_one_herz = 0; counter_one_herz = 0;
} }
@ -675,10 +680,10 @@ static void fast_loop()
//if(motor_armed) //if(motor_armed)
//Log_Write_Attitude(); //Log_Write_Attitude();
// agmatthews - USERHOOKS // agmatthews - USERHOOKS
#ifdef USERHOOK_FASTLOOP #ifdef USERHOOK_FASTLOOP
USERHOOK_FASTLOOP USERHOOK_FASTLOOP
#endif #endif
} }
@ -925,21 +930,9 @@ static void slow_loop()
// ------------------------------- // -------------------------------
read_control_switch(); read_control_switch();
// Read main battery voltage if hooked up - does not read the 5v from radio // agmatthews - USERHOOKS
// ------------------------------------------------------------------------ #ifdef USERHOOK_SLOWLOOP
//#if BATTERY_EVENT == 1 USERHOOK_SLOWLOOP
// read_battery();
//#endif
#if AUTO_RESET_LOITER == 1
if(control_mode == LOITER){
if((abs(g.rc_2.control_in) + abs(g.rc_1.control_in)) > 500){
// reset LOITER to current position
next_WP = current_loc;
// clear Loiter Iterms
reset_nav();
}
}
#endif #endif
break; break;
@ -972,11 +965,6 @@ static void slow_loop()
break; break;
} }
// agmatthews - USERHOOKS
#ifdef USERHOOK_SLOWLOOP
USERHOOK_SLOWLOOP
#endif
} }
// 1Hz loop // 1Hz loop
@ -1208,6 +1196,7 @@ void update_roll_pitch_mode(void)
#define THROTTLE_FILTER_SIZE 4 #define THROTTLE_FILTER_SIZE 4
// 50 hz update rate, not 250 // 50 hz update rate, not 250
// controls all throttle behavior
void update_throttle_mode(void) void update_throttle_mode(void)
{ {
int16_t throttle_out; int16_t throttle_out;
@ -1226,11 +1215,43 @@ void update_throttle_mode(void)
//throttle_avg = throttle_avg * .98 + rc_3.control_in * .02; //throttle_avg = throttle_avg * .98 + rc_3.control_in * .02;
//g.throttle_cruise = throttle_avg; //g.throttle_cruise = throttle_avg;
} }
// Code to manage the Copter state
if ((millis() - takeoff_timer) > 5000){
// we must be in the air by now
// stop resetting rate_I()
takeoff_complete = true;
}else{
// reset these I terms to prevent flips on takeoff
g.pi_rate_roll.reset_I();
g.pi_rate_pitch.reset_I();
}
}else{ }else{
// we are on the ground
takeoff_complete = false;
// reset baro data if we are near home
if(home_distance < 4 || GPS_enabled == false){
// causes Baro to do a quick recalibration
// XXX commented until further testing
// reset_baro();
}
// reset out i terms and takeoff timer
// -----------------------------------
g.pi_stabilize_roll.reset_I(); g.pi_stabilize_roll.reset_I();
g.pi_stabilize_pitch.reset_I(); g.pi_stabilize_pitch.reset_I();
g.pi_rate_roll.reset_I(); g.pi_rate_roll.reset_I();
g.pi_rate_pitch.reset_I(); g.pi_rate_pitch.reset_I();
// remember our time since takeoff
// -------------------------------
takeoff_timer = millis();
// make sure we also request 0 throttle out
// so the props stop ... properly
// ----------------------------------------
g.rc_3.servo_out = 0; g.rc_3.servo_out = 0;
} }
break; break;
@ -1238,6 +1259,7 @@ void update_throttle_mode(void)
case THROTTLE_HOLD: case THROTTLE_HOLD:
// allow interactive changing of atitude // allow interactive changing of atitude
adjust_altitude(); adjust_altitude();
// fall through // fall through
case THROTTLE_AUTO: case THROTTLE_AUTO:
@ -1255,6 +1277,14 @@ void update_throttle_mode(void)
// reset next_WP.alt and don't go below 1 meter // reset next_WP.alt and don't go below 1 meter
next_WP.alt = max(current_loc.alt, 100); next_WP.alt = max(current_loc.alt, 100);
/*
Serial.printf("tar_alt: %d, actual_alt: %d \talt_err: %d, \t manb: %d\n",
next_WP.alt,
current_loc.alt,
altitude_error,
manual_boost);
//*/
}else{ }else{
// 10hz, don't run up i term // 10hz, don't run up i term
if(invalid_throttle && motor_auto_armed == true){ if(invalid_throttle && motor_auto_armed == true){
@ -1346,7 +1376,21 @@ static void update_navigation()
// switch passthrough to LOITER // switch passthrough to LOITER
case LOITER: case LOITER:
case POSITION: case POSITION:
wp_control = LOITER_MODE; // This feature allows us to reposition the quad when the user lets
// go of the sticks
if((abs(g.rc_2.control_in) + abs(g.rc_1.control_in)) > 500){
// this sets the copter to not try and nav while we control it
wp_control = NO_NAV_MODE;
// reset LOITER to current position
next_WP = current_loc;
// clear Loiter Iterms
reset_nav();
}else{
// this is also set by GPS in update_nav
wp_control = LOITER_MODE;
}
// calculates the desired Roll and Pitch // calculates the desired Roll and Pitch
update_nav_wp(); update_nav_wp();
@ -1461,7 +1505,7 @@ static void update_altitude()
baro_rate = (temp + baro_rate) >> 1; baro_rate = (temp + baro_rate) >> 1;
old_baro_alt = baro_alt; old_baro_alt = baro_alt;
// sonar_alt is calculaed in a faster loop and filtered with a mode filter // sonar_alt is calculated in a faster loop and filtered with a mode filter
#endif #endif
@ -1563,6 +1607,12 @@ static void tuning(){
thrust = tuning_value * .2; thrust = tuning_value * .2;
break;*/ break;*/
case CH6_DAMP:
g.rc_6.set_range(0,1500); // 0 to 1
//thrust = tuning_value * .2;
g.stablize_d.set(tuning_value);
break;
case CH6_STABILIZE_KP: case CH6_STABILIZE_KP:
g.rc_6.set_range(0,8000); // 0 to 8 g.rc_6.set_range(0,8000); // 0 to 8
g.pi_stabilize_roll.kP(tuning_value); g.pi_stabilize_roll.kP(tuning_value);