Skip to content

Latest commit

 

History

History
executable file
·
88 lines (64 loc) · 3.17 KB

README.md

File metadata and controls

executable file
·
88 lines (64 loc) · 3.17 KB

RRT_star

This repository contains a C++ port of RRT_Star from Python Robotics, modified to meet our requirements. With the major differences being.

  • Use of cv:Mat to store MAP and display path

  • Ability to load any MAP image and use it for path planning

  • Usage of LineDrawing algorithm to check for obstacles. This helps us detect even obstacles which are a single grid cell thick, as opposed to the more common sampling based approaches. Also the line drawing algorithm uses ineteger arithmetic which beats the runtime when using floating point sampling with half grid resolution. The code uses integers wherever possible to reduce runtime.

  • Using a more gradual roll of function for the neghbour hood distance

    old_fx -old

    new_fx -new

  • Ability to use lebesgue measure for Neighbour hood fall off with USE_LEBESGUE MEASURE option. It uses the following equations

    • gamma_rrt_star

    • search_radius

where

 - d : dimension of space
 - u(xfree) : lebesgue measure 
 - eta : expand distance 
 - n : number of nodes formed till now

RRT Star in Action

RRTStar.gif

RRT Star with smoothening on KITTI

Map is obtained by using ORB SLAM 2 RRTStar.gif

Building and running

git clone https://github.com/SLAM-EE/RRT_star.git
mkdir spline/build
cd spline/build
cmake ..
make all
cd ../../
mkdir build 
cd build
cmake ..
make all
./RRT_Star

Alternatively run the build script given as

git clone https://github.com/SLAM-EE/RRT_star.git
build.sh

Requirements

  • OpenCV

    • opencv version 4 is used in this project
    • You might have to probably built it from sources
    • A build script is provided in the scripts folder run the script as root. Verify the source download link if script fails.
    • Check installation using
      sudo apt install pkg-config
      pkg-config --cflags opencv4
    • To use with OpenCV 3, modify CMakeLists.txt file line 29- 35 as below.
      find_package(OpenCV 3 QUIET)
      if(NOT OpenCV_FOUND)
          find_package(OpenCV 2.4.3 QUIET)
          if(NOT OpenCV_FOUND)
              message(FATAL_ERROR "OpenCV > 2.4.3 not found.")
       endif()
      ```

    might have change some code (mainly #defines used cv::IMREAD_COLOR) to make the code working with OpenCv 3

  • cmake