From efdd3946fc441712a4e72c3752f9c3b1fe114d38 Mon Sep 17 00:00:00 2001 From: Randy Mackay Date: Mon, 10 Sep 2018 13:45:06 +0900 Subject: [PATCH] Rover: simple mode fixes --- APMrover2/Rover.h | 1 - APMrover2/mode.cpp | 12 ++++------ APMrover2/mode.h | 9 ++++---- APMrover2/mode_simple.cpp | 46 ++++++++++++++++----------------------- APMrover2/system.cpp | 2 +- 5 files changed, 29 insertions(+), 41 deletions(-) diff --git a/APMrover2/Rover.h b/APMrover2/Rover.h index 719a15b365..bc18e1a82e 100644 --- a/APMrover2/Rover.h +++ b/APMrover2/Rover.h @@ -399,7 +399,6 @@ private: void one_second_loop(void); void update_GPS(void); void update_current_mode(void); - void init_simple_mode(void); // balance_bot.cpp void balancebot_pitch_control(float &throttle); diff --git a/APMrover2/mode.cpp b/APMrover2/mode.cpp index beb9828303..bde56e6e2e 100644 --- a/APMrover2/mode.cpp +++ b/APMrover2/mode.cpp @@ -148,16 +148,12 @@ void Mode::get_pilot_desired_lateral(float &lateral_out) // decode pilot's input and return heading_out (in cd) and speed_out (in m/s) void Mode::get_pilot_desired_heading_and_speed(float &heading_out, float &speed_out) { - float desired_steering; - float desired_throttle; - get_pilot_input(desired_steering, desired_throttle); - - // scale down and limit throttle and steering to a -1 to +1 range - desired_throttle = constrain_float(desired_throttle / 100.0f, -1.0f, 1.0f); - desired_steering = constrain_float(desired_steering / 4500.0f, -1.0, 1.0f); + // get steering and throttle in the -1 to +1 range + float desired_steering = constrain_float(rover.channel_steer->get_control_in() / 4500.0f, -1.0, 1.0f); + float desired_throttle = constrain_float(rover.channel_throttle->get_control_in() / 100.0f, -1.0f, 1.0f); // calculate angle of input stick vector - heading_out = wrap_360_cd(atan2f(desired_steering,desired_throttle) * DEGX100); + heading_out = wrap_360_cd(atan2f(desired_steering, desired_throttle) * DEGX100); // calculate magnitude of input stick vector float magnitude_max = 1.0f; diff --git a/APMrover2/mode.h b/APMrover2/mode.h index c6d3117614..24f1ebb689 100644 --- a/APMrover2/mode.h +++ b/APMrover2/mode.h @@ -496,16 +496,17 @@ public: // methods that affect movement of the vehicle in this mode void update() override; - void init_simple_heading(); + void init_heading(); -protected: - - float simple_initial_heading; +private: // simple type enum used for SIMPLE_TYPE parameter enum simple_type { Simple_InitialHeading = 0, Simple_CardinalDirections = 1, }; + + float _initial_heading_cd; // vehicle heading (in centi-degrees) at moment vehicle was armed + float _desired_heading_cd; // latest desired heading (in centi-degrees) from pilot }; diff --git a/APMrover2/mode_simple.cpp b/APMrover2/mode_simple.cpp index e8c33bda2d..482d9290b9 100644 --- a/APMrover2/mode_simple.cpp +++ b/APMrover2/mode_simple.cpp @@ -1,41 +1,33 @@ #include "mode.h" #include "Rover.h" -void ModeSimple::init_simple_heading() +void ModeSimple::init_heading() { - simple_initial_heading = ahrs.yaw; + _initial_heading_cd = ahrs.yaw_sensor; + _desired_heading_cd = ahrs.yaw_sensor; } void ModeSimple::update() { - float desired_heading, desired_steering, desired_speed; + float desired_heading_cd, desired_speed; - // initial heading simple mode + // get pilot input + get_pilot_desired_heading_and_speed(desired_heading_cd, desired_speed); + + // rotate heading around based on initial heading if (g2.simple_type == Simple_InitialHeading) { - - // get piot input - get_pilot_desired_steering_and_speed(desired_steering, desired_speed); - - float simple_heading; - if (is_zero(desired_steering)) { - simple_heading = ((simple_initial_heading - ahrs.yaw) * 4500.0f); - } else { - simple_heading = desired_steering; - } - - // run throttle and steering controllers - calc_steering_to_heading(simple_heading, false); - calc_throttle(desired_speed, true, false); + desired_heading_cd = wrap_360_cd(_initial_heading_cd + desired_heading_cd); } - // cardinal directions simple mode - if (g2.simple_type == Simple_CardinalDirections) { - - // get pilot input - get_pilot_desired_heading_and_speed(desired_heading, desired_speed); - - // run throttle and steering controllers - calc_steering_to_heading(desired_heading, false); - calc_throttle(desired_speed, false, true); + // if sticks in middle, use previous desired heading (important when vehicle is slowing down) + if (!is_positive(desired_speed)) { + desired_heading_cd = _desired_heading_cd; + } else { + // record desired heading for next iteration + _desired_heading_cd = desired_heading_cd; } + + // run throttle and steering controllers + calc_steering_to_heading(desired_heading_cd, 0.0f, false); + calc_throttle(desired_speed, false, true); } diff --git a/APMrover2/system.cpp b/APMrover2/system.cpp index 8fd37fa249..2140158cd0 100644 --- a/APMrover2/system.cpp +++ b/APMrover2/system.cpp @@ -333,7 +333,7 @@ bool Rover::arm_motors(AP_Arming::ArmingMethod method) g2.smart_rtl.set_home(true); // initialize simple mode heading - rover.mode_simple.init_simple_heading(); + rover.mode_simple.init_heading(); change_arm_state(); return true;