Skip to content

Latest commit

 

History

History
94 lines (68 loc) · 6.7 KB

README.md

File metadata and controls

94 lines (68 loc) · 6.7 KB

Maneuver based navigation

1. Overview

The maneuver-based navigation aims to provide a simple yet efficient of motion planning for differential drive robots with rectangular footprints. The motion planner targets structured indoor environments like those of office building, hospitals, etc., where the robot have to navigate mainly through corridors and intersections.

To navigate to a desired goal in the vicinity of the robot, it is desirable to perform a limited set of movements or maneuvers that eventually can help people in the proximity of the robot to predict its behavior. The maneuvers should also take into account over-sized dimensions of robots carrying a load. To meet those requirements, we propose first a basic set of three maneuvers, move straight, turn left in an intersection and turn right in an intersection. An illustration of the turn left-right maneuvers is shown in the Figure below.

Maneuver Concept

We start by defining a trajectory composed by straight-lines and circles, other choices like clothoids or bezier-curves are also possible. Next, such trajectory is assigned to a reference point on the robot footprint. For instance for the left-turn maneuver, such point is placed at the top-right corner of the footprint. The motivation is that we are interested in keeping such point parallel to the wall of the corridor we will enter. For the right-turn maneuver, we placed the point on the right hand side of the vehicle, as to keep that side away from the corner. This strategy allows the robot to find a wall-collision-free trajectory for turning in intersections.

We have parametrized the trajectories in order to explore several possibilities, for instance by parameterizing the radius of the reference point trajectory and even having multiple reference points. In the current strategy we explore an ordered set of reference points and then a set of circle radii until the first collision-free trajectory is found.

We can the compose several of these basic maneuvers to for instance create change of lane, or overtake maneuvers to avoid obstacles. Once again, the maneuvers can be parametrized in order to explore the free space. An example of an overtake maneuver is shown in the Figure below.

Overtake Maneuver

2. Node API

2.1 Topics

2.1.1 Published topics

2.1.1.1 Maneuver navigation
  • ∼<name>/cmd_vel(geometry_msgs/Twist)
    Velocity commands to be executed by the robot

  • ∼<name>/maneuver_navigation/feedback(geometry_msgs/PoseStamped)
    Current position of the robot

  • ∼<name>/maneuver_navigation/goal_rviz(geometry_msgs/PoseStamped)
    Last goal received. Used for visualization purposes

2.1.2 Subscribed topics

  • ∼<name>/route_navigation/simple_goal(geometry_msgs/PoseStamped)
    Simple goal containing only a pose

  • ∼<name>/route_navigation/goal(/route_navigation/goal)
    Goal containing pose and additional configuration of the planner for adaptibility. See message types section.

  • ∼<name>/route_navigation/cancel(std_msgs/Bool)
    Set to true to cancel the current navigation. A zero velocity command is sent as well.

  • ∼<name>/route_navigation/set_load_attached(std_msgs/Bool)
    When set to true, the navigation is reset and the parameters specified in the file indicated by ∼<name>/default_ropod_load_param_file are loaded. When is set to false, the parameters in the file indicated by ∼<name>/default_ropod_navigation_param_file are loaded. By default it is assumed the ropod is not attached to a load.

  • ∼<name>/odom (nav_msgs/Odometry)
    The local planner make use of the robot's odometry for local path planning.

2.1.3 Extra topics

2.1.3.1 Local costmap

We make use of the Costmap 2D as local costmap. . Please refer to their website for additional published and subscribed topics.

2.1.3.2 TEB local planner

We make use of the TEB Local planner to execute the maneuvers. Please refer to their website for additional published and subscribed topics.

2.2 Message types

/route_navigation/goal
geometry_msgs/PoseStamped start : start pose of plan.
geometry_msgs/PoseStamped goal : goal pose of plan.
Configuration conf
    bool use_line_planner : whether or not plan straight line trajectories, useful for holonomic robots.
    bool precise_goal : use tight tolerances to reach a goal. If after a maneuver the goal is not reached, the goal is resent.

2.3 Parameters

2.3.1 Manuever navigation

  • ∼<name>/maneuver_navigation/default_ropod_navigation_param_file(string, default: "config/footprint_local_planer_params_ropod.yaml")
    Contains the default parameters of the robot's footprint and local planner that are used when the ropod does not have a load attached.

  • ∼<name>/maneuver_navigation/default_ropod_load_param_file(string, default: "config/footprint_local_planer_params_ropod_load.yaml")
    Contains the default parameters of the robot's footprint and local planner that are used when the ropod have a load attached.

  • ∼<name>/maneuver_navigation/local_navigation_rate (double, default: 10.0)
    Rate at which the local planner is run.

  • ∼<name>/maneuver_navigation/prediction_feasibility_check_rate (double, default: 3.0)
    Rate at which the maneuver planner checks feasibility of the rest of the plan. When there are obstacles ahead, a new maneuver is planned.

2.3.2 Manuever planner

  • ∼<name>/maneuver_planner/step_size (double, default: 0.05 (localcostmap default))
    Step size used to generate the reference point trajectories.

  • ∼<name>/maneuver_planner/use_last_goal_as_start (bool, default: false)
    When true, the last received goal is stored and used as starting pose for maneuver planning. To be used only with with a simple_goal (see subscribed topics).

2.3.3 Footprint

The robot footprint is defined in two places and it must be taken care of that they are identical. One is at the Costmap 2D parameters and the other is at the TEB Local planner parameters.

2.3.4 Local costmap

We make use of the Costmap 2D as local costmap. . Please refer to their website for the corresponding parameters.

2.3.5 TEB local planner parameters

We make use of the TEB Local planner to execute the maneuver. Please refer to their website for the parameters.