Skip to content

Latest commit

 

History

History
272 lines (186 loc) · 7.29 KB

README.md

File metadata and controls

272 lines (186 loc) · 7.29 KB

UAV motion-planning

Quick start

git clone https://github.com/peiyu-cui/motion-planning.git
cd motion-planning
catkin_make -DCMAKE_CXX_STANDARD=14

1. Search-Based Methods

(1) A*:

  • quick start:

    • one terminator
    source devel/setup.bash
    roslaunch plan_manage single_run_in_sim.launch
    • another terminator
    source devel/setup.bash
    roslaunch test test_astar_searching.launch
  • parameters:

    <!-- astar parameters -->
    <param name="astar/resolution" value="0.1"/>
    <param name="astar/lambda_heu" value="1.5"/>
    <param name="astar/allocated_node_num" value="1000000"/>

    "astar/resolution": astar search resolution, control the search resolution

    "astar/lambda_heu": $f = g(n) + \lambda * h(n)$

    "astar/allocated_node_num": pre-allocated search node num, avoid too many nodes

  • methods:

    • tie_breaker:enhance the speed of searching

    • weighted A*:

      Image

  • simulation:

Image

(2) Kinodynamic A*

  • quick start

    • one terminator
    source devel/setup.bash
    roslaunch plan_manage single_run_in_sim.launch
    • another terminator
    source devel/setup.bash
    roslaunch test test_kino_astar_searching.launch
  • parameters:(need some parameters to change!!!)

    • kino_astar/collision_check_type = 1 : kino_astar planning
    • kino_astar/collision_check_type = 2 : kino_se(3) planning
    • (map_type change) simulator.xml : "map/fix_map_type" = 0 : generate random map
    • **(map_type change)**simulator.xml : "map/fix_map_type" = 1 : generate fix wall map
     <!-- kino_astar parameters -->
    <param name="kino_astar/rou_time" value="20.0"/>
    <param name="kino_astar/lambda_heu" value="3.0"/>
    <param name="kino_astar/allocated_node_num" value="100000"/>
    <param name="kino_astar/goal_tolerance" value="2.0"/>
    <param name="kino_astar/time_step_size" value="0.075"/>
    <param name="kino_astar/max_velocity" value="7.0"/>
    <param name="kino_astar/max_accelration" value="10.0"/>
    <param name="kino_astar/acc_resolution" value="4.0"/>
    <param name="kino_astar/sample_tau" value="0.3"/>
    <!-- collision check type 1: kino_astar, 2: kino_se3 -->
    <param name="kino_astar/collision_check_type" value="2"/>
    <!-- robot ellipsoid parameters -->
    <param name="kino_se3/robot_r" value="0.4"/>
    <param name="kino_se3/robot_h" value="0.1"/>
  • methods:

  • simulation:

    Image

(3) SE(3) Planning

  • quick start

    • one terminator
    source devel/setup.bash
    roslaunch plan_manage single_run_in_sim.launch
    • another terminator
    source devel/setup.bash
    roslaunch test test_kino_astar_searching.launch
  • parameters(need some parameters to change!!!!):

    • "kino_astar/collision_check_type" = 1 : kino_astar planning
    • "kino_astar/collision_check_type" = 2 : kino_se(3) planning
    • (map_type change) simulator.xml : "map/fix_map_type" = 0 : generate random map
    • **(map_type change)**simulator.xml : "map/fix_map_type" = 1 : generate fix wall map
    <!-- kino_astar parameters -->
    <param name="kino_astar/rou_time" value="20.0"/>
    <param name="kino_astar/lambda_heu" value="3.0"/>
    <param name="kino_astar/allocated_node_num" value="100000"/>
    <param name="kino_astar/goal_tolerance" value="2.0"/>
    <param name="kino_astar/time_step_size" value="0.075"/>
    <param name="kino_astar/max_velocity" value="7.0"/>
    <param name="kino_astar/max_accelration" value="10.0"/>
    <param name="kino_astar/acc_resolution" value="4.0"/>
    <param name="kino_astar/sample_tau" value="0.3"/>
    <!-- collision check type 1: kino_astar, 2: kino_se3 -->
    <param name="kino_astar/collision_check_type" value="2"/>
    <!-- robot ellipsoid parameters -->
    <param name="kino_se3/robot_r" value="0.4"/>
    <param name="kino_se3/robot_h" value="0.1"/>
  • methods:

  • simulation:

    Image

2. Sampling-Based Methods

(1) RRT:

  • quick start:

    • one terminator

      source devel/setup.bash
      roslaunch plan_manage single_run_in_sim.launch
    • another terminator

      source devel/setup.bash
      roslaunch test test_rrt_searching.launch
  • parameters:

<!-- rrt parameters -->
<param name="rrt/max_tree_node_num" value="100000"/>
<param name="rrt/step_length" value="0.5"/>
<param name="rrt/max_allowed_time" value="5"/>
<param name="rrt/search_radius" value="1.0"/>

"rrt/max_tree_node_num": rrt max tree node num, avoid too many tree nodes

"rrt/step_length": rrt step(x1, x2, length), control the step length

"rrt/max_allowed_time": rrt max allowed time, avoid too long search time

"rrt/search_radius": rrt goal tolerance, control the error between search end and real_end

  • method:

    • kdtree-acceleration: find nearest tree node
  • simulation:

Image

(2) RRT*:

  • quick start:

    • one terminator
    source devel/setup.bash
    roslaunch plan_manage single_run_in_sim.launch
    • another terminator
    source devel/setup.bash
    roslaunch test test_rrt_star_searching.launch
  • parameters:

<param name="rrt_star/max_tree_node_num" value="100000"/>
<param name="rrt_star/step_length" value="0.5"/>
<param name="rrt_star/search_radius" value="1.0"/>
  • method:
    • kdtree-acceleration: find nearest tree node
  • simulation:

Image

3. Trajectory Optimization

(1) RRT* + Minimum Snap :

  • quick start:

    • install osqp and osqp-eigen(important!!)

    • one terminator

      source devel/setup.bash
      roslaunch plan_manage single_run_in_sim.launch
    • another terminator

      source devel/setup.bash
      roslaunch test test_minimum_jerk.launch
  • method:

  • simulation:

    • red Line: RRT* Path
    • red Sphere: RRT* Waypoints
    • purple Line: minimum jerk trajectory

Image