Skip to content

Commit

Permalink
Use the limits only if both of them is set
Browse files Browse the repository at this point in the history
  • Loading branch information
RBT22 committed Jan 2, 2025
1 parent 1981e95 commit f8f5bd8
Showing 1 changed file with 7 additions and 13 deletions.
20 changes: 7 additions & 13 deletions nav2_behaviors/include/nav2_behaviors/plugins/drive_on_heading.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -134,29 +134,23 @@ class DriveOnHeading : public TimedBehavior<ActionT>
cmd_vel->header.frame_id = this->robot_base_frame_;
cmd_vel->twist.linear.y = 0.0;
cmd_vel->twist.angular.z = 0.0;
if (acceleration_limit_ <= 0.0 && deceleration_limit_ <= 0.0) {
if (acceleration_limit_ <= 0.0 || deceleration_limit_ <= 0.0) {
cmd_vel->twist.linear.x = command_speed_;
} else {
double current_speed = last_vel_ == std::numeric_limits<double>::max() ? 0.0 : last_vel_;
auto remaining_distance = std::fabs(command_x_) - distance;
double min_feasible_speed = -std::numeric_limits<double>::infinity();
double max_feasible_speed = std::numeric_limits<double>::infinity();
if (deceleration_limit_ > 0.0) {
min_feasible_speed = current_speed - deceleration_limit_ / this->cycle_frequency_;
}
if (acceleration_limit_ > 0.0) {
max_feasible_speed = current_speed + acceleration_limit_ / this->cycle_frequency_;
}

double min_feasible_speed = current_speed - deceleration_limit_ / this->cycle_frequency_;
double max_feasible_speed = current_speed + acceleration_limit_ / this->cycle_frequency_;
cmd_vel->twist.linear.x = std::clamp(command_speed_, min_feasible_speed, max_feasible_speed);

// Check if we need to slow down to avoid overshooting
bool forward = command_speed_ > 0.0;
if (forward && deceleration_limit_ > 0.0) {
auto remaining_distance = std::fabs(command_x_) - distance;
if (command_speed_ > 0.0) {
double max_vel_to_stop = std::sqrt(2.0 * deceleration_limit_ * remaining_distance);
if (max_vel_to_stop < cmd_vel->twist.linear.x) {
cmd_vel->twist.linear.x = max_vel_to_stop;
}
} else if (!forward && acceleration_limit_ > 0.0) {
} else {
double max_vel_to_stop = -std::sqrt(2.0 * acceleration_limit_ * remaining_distance);
if (max_vel_to_stop > cmd_vel->twist.linear.x) {
cmd_vel->twist.linear.x = max_vel_to_stop;
Expand Down

0 comments on commit f8f5bd8

Please sign in to comment.