APMrover v2.1.6 - Added Speed Booster between wp and soft start

Signed-off-by: Jean-Louis Naudin <jlnaudin@gmail.com>
This commit is contained in:
Jean-Louis Naudin 2012-05-17 18:42:16 +02:00
parent 9d221b3625
commit 408d3dfa98
8 changed files with 68 additions and 34 deletions

View File

@ -20,8 +20,8 @@
#define TRACE DISABLED #define TRACE DISABLED
//#include "APM_Config_HILmode.h" // for test in HIL mode with AeroSIM Rc 3.83 #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 //#include "APM_Config_Rover.h" // to be used with the real Traxxas model Monster Jam Grinder
// Radio setup: // Radio setup:
// APM INPUT (Rec = receiver) // APM INPUT (Rec = receiver)

View File

@ -53,6 +53,11 @@
#define MAX_DIST 50 //300 // max distance (in m) for the HEADALT mode #define MAX_DIST 50 //300 // max distance (in m) for the HEADALT mode
#define SARSEC_BRANCH 50 // Long branch of the SARSEC pattern #define SARSEC_BRANCH 50 // Long branch of the SARSEC pattern
#define BOOSTER 2 // booster factor x2
#define AUTO_WP_RADIUS DISABLED
#define AIRSPEED_CRUISE 3 // 4m/s
#define THROTTLE_SLEW_LIMIT 2 // set to 2 for a smooth acceleration by 0.2 step
////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////
// FLIGHT AND NAVIGATION CONTROL // FLIGHT AND NAVIGATION CONTROL
@ -65,7 +70,6 @@
// is 10m/s, which is a conservative value suitable for relatively small, // is 10m/s, which is a conservative value suitable for relatively small,
// light aircraft. // light aircraft.
// //
#define AIRSPEED_CRUISE 3
#define GSBOOST 0 // 60 // boost the throttle if ground speed is too low in case of windy conditions // 100 #define GSBOOST 0 // 60 // boost the throttle if ground speed is too low in case of windy conditions // 100
#define NUDGE_OFFSET 0 //1603 // nudge_offset to get a good sustained speed in autonomous flight #define NUDGE_OFFSET 0 //1603 // nudge_offset to get a good sustained speed in autonomous flight
#define MIN_GNDSPEED 3 #define MIN_GNDSPEED 3
@ -373,7 +377,6 @@
#define THROTTLE_TE_I 0.0 #define THROTTLE_TE_I 0.0
#define THROTTLE_TE_D 0.0 #define THROTTLE_TE_D 0.0
#define THROTTLE_TE_INT_MAX 20 #define THROTTLE_TE_INT_MAX 20
#define THROTTLE_SLEW_LIMIT 0
#define P_TO_T 0.0 #define P_TO_T 0.0
#define T_TO_P 0 #define T_TO_P 0

View File

@ -33,7 +33,6 @@
#define GPS_PROTOCOL GPS_PROTOCOL_AUTO #define GPS_PROTOCOL GPS_PROTOCOL_AUTO
#define CH7_OPTION CH7_SAVE_WP #define CH7_OPTION CH7_SAVE_WP
#define TUNING_OPTION TUN_NONE
#define FLIGHT_MODE_1 AUTO // pos 0 --- #define FLIGHT_MODE_1 AUTO // pos 0 ---
#define FLIGHT_MODE_2 AUTO // pos 1 #define FLIGHT_MODE_2 AUTO // pos 1
@ -49,10 +48,21 @@
#define TURN_GAIN 5 #define TURN_GAIN 5
#define CLOSED_LOOP_NAV ENABLED // set to ENABLED if closed loop navigation else set to DISABLED (Return To Lauch) #define CLOSED_LOOP_NAV ENABLED // set to ENABLED if closed loop navigation else set to DISABLED (Return To Lauch)
#define AUTO_WP_RADIUS DISABLED
#define MAX_DIST 50 //300 // max distance (in m) for the HEADALT mode #define MAX_DIST 50 //300 // max distance (in m) for the HEADALT mode
#define SARSEC_BRANCH 50 // Long branch of the SARSEC pattern #define SARSEC_BRANCH 50 // Long branch of the SARSEC pattern
/*
During straight lines if the speed booster is enabled, after passing the Wp,
the speed is multplied by a speed factor ROV_BOOSTER = 2
(i.e. this is my tested value... so the required speed will be 2 x 4 = 8 m/s in straight lines),
the when the rover approach the wp, it slow down to 4 m/s (TRIM_ARSPD_CM)...
This feature works only if the ROV_AWPR_NAV is set to 0
*/
#define BOOSTER 2 // booster factor x2
#define AUTO_WP_RADIUS DISABLED
#define AIRSPEED_CRUISE 4 // 4m/s
#define THROTTLE_SLEW_LIMIT 2 // set to 2 for a smooth acceleration by 0.2 step
////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////
@ -66,7 +76,6 @@
// is 10m/s, which is a conservative value suitable for relatively small, // is 10m/s, which is a conservative value suitable for relatively small,
// light aircraft. // light aircraft.
// //
#define AIRSPEED_CRUISE 3
#define GSBOOST 0 #define GSBOOST 0
#define NUDGE_OFFSET 0 #define NUDGE_OFFSET 0
#define MIN_GNDSPEED 3 #define MIN_GNDSPEED 3

View File

@ -1,6 +1,6 @@
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- /// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
#define THISFIRMWARE "APMrover v2.14 JL NAUDIN" //New version of the APMrover for the APM v1 or APM v2 and magnetometer + SONAR #define THISFIRMWARE "APMrover v2.16 JL NAUDIN" //New version of the APMrover for the APM v1 or APM v2 and magnetometer + SONAR
// This is a full version of Arduplane v2.32 specially adapted for a Rover by Jean-Louis Naudin (JLN) // This is a full version of Arduplane v2.32 specially adapted for a Rover by Jean-Louis Naudin (JLN)
@ -18,7 +18,7 @@ License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version. version 2.1 of the License, or (at your option) any later version.
// //
// JLN updates: last update 2012-05-15 // JLN updates: last update 2012-05-17
// //
// DOLIST: // DOLIST:
// //
@ -26,6 +26,9 @@ version 2.1 of the License, or (at your option) any later version.
//------------------------------------------------------------------------------------------------------------------------- //-------------------------------------------------------------------------------------------------------------------------
// Dev Startup : 2012-04-21 // Dev Startup : 2012-04-21
// //
// 2012-05-17: added speed_boost during straight line
// 2012-05-17: New update about the throttle rate control based on the field test done by Franco Borasio (Thanks Franco..)
// 2012-05-15: The Throttle rate can be controlled by the THROTTLE_SLEW_LIMIT (the value give the step increase, 1 = 0.1)
// 2012-05-14: Update about mavlink library (now compatible with the latest version of mavlink) // 2012-05-14: Update about mavlink library (now compatible with the latest version of mavlink)
// 2012-05-14: Added option (hold roll to full right + SW7 ON/OFF) to init_home during the wp_list reset // 2012-05-14: Added option (hold roll to full right + SW7 ON/OFF) to init_home during the wp_list reset
// 2012-05-13: Add ROV_SONAR_TRIG (default = 200 cm) // 2012-05-13: Add ROV_SONAR_TRIG (default = 200 cm)
@ -505,6 +508,7 @@ static int16_t sonar_dist;
// The amount current ground speed is below min ground speed. Centimeters per second // The amount current ground speed is below min ground speed. Centimeters per second
static long groundspeed_undershoot = 0; static long groundspeed_undershoot = 0;
static long ground_speed = 0; static long ground_speed = 0;
static int throttle_last = 0, throttle = 500;
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// Location Errors // Location Errors
@ -583,6 +587,7 @@ static bool final = false;
// JLN Update // JLN Update
unsigned long timesw = 0; unsigned long timesw = 0;
static long ground_course = 0; // deg * 100 dir of plane static long ground_course = 0; // deg * 100 dir of plane
static bool speed_boost = false;
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// Loiter management // Loiter management
@ -1023,9 +1028,7 @@ static void slow_loop()
#if TRACE == ENABLED #if TRACE == ENABLED
Serial.printf_P(PSTR("NAV->gnd_crs=%3.0f, nav_brg=%3.0f, tgt_brg=%3.0f, brg_err=%3.0f, nav_rll=%3.1f rsvo=%3.1f\n"), Serial.printf_P(PSTR("NAV->gnd_crs=%3.0f, nav_brg=%3.0f, tgt_brg=%3.0f, brg_err=%3.0f, nav_rll=%3.1f rsvo=%3.1f\n"),
(float)ground_course/100, (float)nav_bearing/100, (float)target_bearing/100, (float)bearing_error/100, (float)nav_roll/100, (float)g.channel_roll.servo_out/100); (float)ground_course/100, (float)nav_bearing/100, (float)target_bearing/100, (float)bearing_error/100, (float)nav_roll/100, (float)g.channel_roll.servo_out/100);
// Serial.printf_P(PSTR("WPL->g.command_total=%d, g.command_index=%d, nav_command_index=%d\n"),
// g.command_total, g.command_index, nav_command_index);
#endif #endif
break; break;
} }
@ -1165,7 +1168,6 @@ static void update_current_flight_mode(void)
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();
break; break;
//roll: -13788.000, pitch: -13698.000, thr: 0.000, rud: -13742.000
} }
} }

View File

@ -25,14 +25,33 @@ static void crash_checker()
} }
static void calc_throttle() static void calc_throttle()
{ { int rov_speed;
int throttle_target = g.throttle_cruise + throttle_nudge + 50;
int throttle_target = g.throttle_cruise + throttle_nudge + 50;
// Normal airspeed target
target_airspeed = g.airspeed_cruise; target_airspeed = g.airspeed_cruise;
groundspeed_error = target_airspeed - (float)ground_speed;
g.channel_throttle.servo_out = throttle_target + g.pidTeThrottle.get_pid(groundspeed_error, dTnav); if(speed_boost)
g.channel_throttle.servo_out = constrain(g.channel_throttle.servo_out, g.throttle_min.get(), g.throttle_max.get()); rov_speed = g.booster * target_airspeed;
else
rov_speed = target_airspeed;
groundspeed_error = rov_speed - (float)ground_speed;
int throttle_req = (throttle_target + g.pidTeThrottle.get_pid(groundspeed_error, dTnav)) * 10;
if(g.throttle_slewrate > 0)
{ if (throttle_req > throttle_last)
throttle = throttle + g.throttle_slewrate;
else if (throttle_req < throttle_last) {
throttle = throttle - g.throttle_slewrate;
}
throttle = constrain(throttle, 500, throttle_req);
throttle_last = throttle;
} else {
throttle = throttle_req;
}
g.channel_throttle.servo_out = constrain(((float)throttle / 10.0f), 0, g.throttle_max.get());
} }
/***************************************** /*****************************************
@ -74,6 +93,7 @@ float roll_slew_limit(float servo)
*****************************************/ *****************************************/
static void throttle_slew_limit() static void throttle_slew_limit()
{ {
/*
static int last = 1000; static int last = 1000;
if(g.throttle_slewrate) { // if slew limit rate is set to zero then do not slew limit if(g.throttle_slewrate) { // if slew limit rate is set to zero then do not slew limit
@ -81,9 +101,9 @@ static void throttle_slew_limit()
g.channel_throttle.radio_out = constrain(g.channel_throttle.radio_out, last - (int)temp, last + (int)temp); g.channel_throttle.radio_out = constrain(g.channel_throttle.radio_out, last - (int)temp, last + (int)temp);
last = g.channel_throttle.radio_out; last = g.channel_throttle.radio_out;
} }
*/
} }
// 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.
// Keeps outdated data out of our calculations // Keeps outdated data out of our calculations
static void reset_I(void) static void reset_I(void)
@ -125,19 +145,12 @@ static void set_servos(void)
g.channel_rudder.calc_pwm(); g.channel_rudder.calc_pwm();
g.channel_throttle.radio_out = g.channel_throttle.radio_in; g.channel_throttle.radio_out = g.channel_throttle.radio_in;
// convert 0 to 100% into PWM
g.channel_throttle.servo_out = constrain(g.channel_throttle.servo_out, g.throttle_min.get(), g.throttle_max.get()); g.channel_throttle.servo_out = constrain(g.channel_throttle.servo_out, g.throttle_min.get(), g.throttle_max.get());
// g.channel_throttle.calc_pwm();
/* TO DO - fix this for RC_Channel library
#if THROTTLE_REVERSE == 1
radio_out[CH_THROTTLE] = radio_max(CH_THROTTLE) + radio_min(CH_THROTTLE) - radio_out[CH_THROTTLE];
#endif
*/
} }
if (control_mode >= FLY_BY_WIRE_B) { if (control_mode >= FLY_BY_WIRE_B) {
// convert 0 to 100% into PWM
g.channel_throttle.calc_pwm(); g.channel_throttle.calc_pwm();
/* only do throttle slew limiting in modes where throttle /* only do throttle slew limiting in modes where throttle
control is automatic */ control is automatic */

View File

@ -133,6 +133,7 @@ public:
k_param_auto_wp_radius, k_param_auto_wp_radius,
k_param_sonar_trigger, k_param_sonar_trigger,
k_param_turn_gain, k_param_turn_gain,
k_param_booster,
// ************************************************************ // ************************************************************
// //
@ -351,7 +352,8 @@ public:
AP_Int8 auto_wp_radius; AP_Int8 auto_wp_radius;
AP_Int16 sonar_trigger; AP_Int16 sonar_trigger;
AP_Int16 turn_gain; AP_Int16 turn_gain;
AP_Int8 booster;
// ************************************************************ // ************************************************************
// RC channels // RC channels
@ -482,7 +484,8 @@ public:
closed_loop_nav (CLOSED_LOOP_NAV), closed_loop_nav (CLOSED_LOOP_NAV),
auto_wp_radius (AUTO_WP_RADIUS), auto_wp_radius (AUTO_WP_RADIUS),
sonar_trigger (SONAR_TRIGGER), sonar_trigger (SONAR_TRIGGER),
turn_gain (TURN_GAIN), turn_gain (TURN_GAIN),
booster (BOOSTER),
// ************************************************************ // ************************************************************

View File

@ -124,6 +124,8 @@ static const AP_Param::Info var_info[] PROGMEM = {
GSCALAR(auto_wp_radius, "ROV_AWPR_NAV"), GSCALAR(auto_wp_radius, "ROV_AWPR_NAV"),
GSCALAR(sonar_trigger, "ROV_SONAR_TRIG"), GSCALAR(sonar_trigger, "ROV_SONAR_TRIG"),
GSCALAR(turn_gain, "ROV_GAIN"), GSCALAR(turn_gain, "ROV_GAIN"),
GSCALAR(booster, "ROV_BOOSTER"),
// ************************************************************ // ************************************************************
GGROUP(channel_roll, "RC1_", RC_Channel), GGROUP(channel_roll, "RC1_", RC_Channel),

View File

@ -351,7 +351,9 @@ static void set_mode(byte mode)
control_mode = mode; control_mode = mode;
crash_timer = 0; crash_timer = 0;
throttle_last = 0;
throttle = 500;
switch(control_mode) switch(control_mode)
{ {
case MANUAL: case MANUAL: