Rover: add Auto_Stop state and use for Nav_Delay

This commit is contained in:
Randy Mackay 2019-08-14 11:26:11 +09:00 committed by Tom Pittenger
parent 1bb332382c
commit 6c3ce521c7
2 changed files with 25 additions and 9 deletions

View File

@ -283,7 +283,8 @@ protected:
Auto_HeadingAndSpeed, // turn to a given heading Auto_HeadingAndSpeed, // turn to a given heading
Auto_RTL, // perform RTL within auto mode Auto_RTL, // perform RTL within auto mode
Auto_Loiter, // perform Loiter within auto mode Auto_Loiter, // perform Loiter within auto mode
Auto_Guided // handover control to external navigation system from within auto mode Auto_Guided, // handover control to external navigation system from within auto mode
Auto_Stop // stop the vehicle as quickly as possible
} _submode; } _submode;
private: private:
@ -291,6 +292,7 @@ private:
bool check_trigger(void); bool check_trigger(void);
bool start_loiter(); bool start_loiter();
void start_guided(const Location& target_loc); void start_guided(const Location& target_loc);
void start_stop();
void send_guided_position_target(); void send_guided_position_target();
bool start_command(const AP_Mission::Mission_Command& cmd); bool start_command(const AP_Mission::Mission_Command& cmd);
@ -351,7 +353,6 @@ private:
// Delay the next navigation command // Delay the next navigation command
uint32_t nav_delay_time_max_ms; // used for delaying the navigation commands uint32_t nav_delay_time_max_ms; // used for delaying the navigation commands
uint32_t nav_delay_time_start_ms; uint32_t nav_delay_time_start_ms;
AutoSubMode nav_delay_submode_backup; // back up sub_mode
}; };

View File

@ -97,6 +97,10 @@ void ModeAuto::update()
rover.mode_guided.update(); rover.mode_guided.update();
break; break;
} }
case Auto_Stop:
stop_vehicle();
break;
} }
} }
@ -117,6 +121,7 @@ float ModeAuto::get_distance_to_destination() const
case Auto_WP: case Auto_WP:
return _distance_to_destination; return _distance_to_destination;
case Auto_HeadingAndSpeed: case Auto_HeadingAndSpeed:
case Auto_Stop:
// no valid distance so return zero // no valid distance so return zero
return 0.0f; return 0.0f;
case Auto_RTL: case Auto_RTL:
@ -142,6 +147,7 @@ bool ModeAuto::get_desired_location(Location& destination) const
} }
return false; return false;
case Auto_HeadingAndSpeed: case Auto_HeadingAndSpeed:
case Auto_Stop:
// no desired location for this submode // no desired location for this submode
return false; return false;
case Auto_RTL: case Auto_RTL:
@ -177,6 +183,7 @@ bool ModeAuto::reached_destination() const
return g2.wp_nav.reached_destination(); return g2.wp_nav.reached_destination();
break; break;
case Auto_HeadingAndSpeed: case Auto_HeadingAndSpeed:
case Auto_Stop:
// always return true because this is the safer option to allow missions to continue // always return true because this is the safer option to allow missions to continue
return true; return true;
break; break;
@ -295,6 +302,12 @@ void ModeAuto::start_guided(const Location& loc)
} }
} }
// start stopping vehicle as quickly as possible
void ModeAuto::start_stop()
{
_submode = Auto_Stop;
}
// send latest position target to offboard navigation system // send latest position target to offboard navigation system
void ModeAuto::send_guided_position_target() void ModeAuto::send_guided_position_target()
{ {
@ -550,11 +563,14 @@ void ModeAuto::do_nav_delay(const AP_Mission::Mission_Command& cmd)
{ {
nav_delay_time_start_ms = millis(); nav_delay_time_start_ms = millis();
// act like we're just doing a heading hold that we instantly achieve. // boats loiter, cars and balancebots stop
// the behavior of this will put a boat into loiter, else stop if (rover.is_boat()) {
nav_delay_submode_backup = _submode; if (!start_loiter()) {
_submode = Auto_HeadingAndSpeed; start_stop();
_reached_heading = true; }
} else {
start_stop();
}
if (cmd.content.nav_delay.seconds > 0) { if (cmd.content.nav_delay.seconds > 0) {
// relative delay // relative delay
@ -563,7 +579,7 @@ void ModeAuto::do_nav_delay(const AP_Mission::Mission_Command& cmd)
// absolute delay to utc time // absolute delay to utc time
nav_delay_time_max_ms = AP::rtc().get_time_utc(cmd.content.nav_delay.hour_utc, cmd.content.nav_delay.min_utc, cmd.content.nav_delay.sec_utc, 0); nav_delay_time_max_ms = AP::rtc().get_time_utc(cmd.content.nav_delay.hour_utc, cmd.content.nav_delay.min_utc, cmd.content.nav_delay.sec_utc, 0);
} }
gcs().send_text(MAV_SEVERITY_INFO, "Delaying %u sec",nav_delay_time_max_ms/1000); gcs().send_text(MAV_SEVERITY_INFO, "Delaying %u sec", nav_delay_time_max_ms/1000);
} }
// start guided within auto to allow external navigation system to control vehicle // start guided within auto to allow external navigation system to control vehicle
@ -634,7 +650,6 @@ bool ModeAuto::verify_nav_delay(const AP_Mission::Mission_Command& cmd)
{ {
if (millis() - nav_delay_time_start_ms > nav_delay_time_max_ms) { if (millis() - nav_delay_time_start_ms > nav_delay_time_max_ms) {
nav_delay_time_max_ms = 0; nav_delay_time_max_ms = 0;
_submode = nav_delay_submode_backup;
return true; return true;
} }