• Stars
    star
    155
  • Rank 239,421 (Top 5 %)
  • Language
    C++
  • License
    BSD 3-Clause "New...
  • Created almost 5 years ago
  • Updated almost 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Plane Segmentation Utilites

Plane Seg CI

ANYmal climbing a real staircase

Plane Seg is a library for fitting planes to LIDAR, depth camera data or elevation maps. It uses robust estimation to fit planes by clustering planar points with similar normals.

We assume the ROS build system (e.g. Melodic). The core library (plane-seg) is only dependent on PCL. The ROS application (plane-seg-ros) can process PointCloud2 and GridMap data types.

The edge detection package depends on Rviz Visual Tools and on the Locomotion Viewer library.

Using It

Run-Time Application: A sample application (for ANYmal) can be run and visualized (in Rviz) as follows:

roslaunch plane_seg_ros anymal.launch
roslaunch plane_seg_ros view_plane_seg.launch

Test program: reads example point clouds (PCDs), processes them and executes the fitting algorithm:

roslaunch plane_seg_ros test.launch
roslaunch plane_seg_ros view_plane_seg.launch

Run edge detection:

rosrun edge_detection_ros edge_detection_ros

Input

Input should be a point cloud or elevation map in the robot's odometry frame as well as the pose of the robot in the odometry frame. The elevation map is assumed to be at a 1-2 Hz.

Output

  1. A series of planar convex hulls published to ROS at 1-2 Hz
  • Nov 2019: Existing limitation is that the code searches for plane regions (which works fine), but that these regions are then assumed to be convex. However, they could be concave. We need to instead break concave regions into convex ones - a basic task.
  1. A series of line segments (edges) of published to ROS at 1-2 Hz. The minimum lenght of the edges can be adjusted, as much as the minimum height required to detect a new step.

Performance

  • The ANYmal RGB-D (RealSense D435) elevation map is 2cm resolution with 18000 points. It takes 0.3 seconds to process.
  • The DRC LIDAR terrain scan below is very dense with 76000 points. It takes 2.5 seconds to process.

Authors

Originally Developed as part of the DARPA Robotics Challenge project at MIT. Subsequent improvements and conversion to ROS was carried out at the DRS Group in Oxford during the MEMMO EU H2020 Project.

Maintainers: DRS Group at Oxford Robotics Institute
Original Author: Matt Antone (then at MIT)

The source code is released under a BSD 3-Clause license.

Citing this work

If you use this work in an academic context, please use the following:

  • M. Fallon, M. Antone, "Plane Seg – Robustly and Efficiently Extracting Contact Regions from Depth Data".

      @misc{Fallon2019PlaneSeg,
          author = {Fallon, Maurice and Antone, Matt},
          url = {https://github.com/ori-drs/plane_seg},
          title = {{Plane Seg – Robustly and Efficiently Extracting Contact Regions from Depth Data}},
          year = {2019},
      }
    

Other Images

Segmenting the DARPA Robotics Challenge terrain:

drc terrain segmentation

Actual DRC Finals terrain (not quite the same scene):

drc terrain photo

Video of ANYmal climbing a simulated staircase in Gazebo:

ANYmal climbing a simulated staircase in Gazebo

More Repositories

1

allan_variance_ros

ROS compatible tool to generate Allan Deviation plots
C++
466
star
2

pronto

Pronto - Legged Robot State Estimator - libraries, ROS wrapper and messages
C++
200
star
3

isam

iSAM is an optimization library for sparse nonlinear problems as encountered in simultaneous localization and mapping (SLAM).
C++
90
star
4

pronto-distro

Pronto is now built in ROS and developed at https://github.com/ori-drs/pronto_core
C++
78
star
5

director

An intuitive user interface for operating field mobile robots
Python
27
star
6

pronto_anymal_example

Example binary running the Pronto state estimator on the ANYmal B robot
C++
24
star
7

recast_ros

C++
14
star
8

integrated-dynamic-motion-planning-framework

14
star
9

quadruped_robcogen

RobCoGen code generator for any quadruped robot from the xacro description
CMake
13
star
10

gaitmesh

C++
12
star
11

director_anymal_b_simple

Python
11
star
12

slam_tutorial

ORIentate tutorial: SLAM and factor graphs
Jupyter Notebook
9
star
13

hesai_description

URDF Model of hesai lidar products
CMake
8
star
14

frontier_description

URDF of the Frontier Handheld Device
CMake
6
star
15

lfmc_gym

Training repository for learning Low-Frequency Motion Control (LFMC) policies using RL
C++
6
star
16

rloc_manuscript_supplementary_code

Supplementary code to the RLOC manuscript.
Python
5
star
17

trajectory_prediction_ros

C++
5
star
18

fovis_ros

ROS node for FOVIS
C++
3
star
19

aicp_mapping

Auto-tuned Iterative Closest Point -- AICP -- Public
C++
3
star
20

vo_estimate

DEPRECIATED. DO NOT USE. LCM node for FOVIS. Uses pods.
C++
2
star
21

gpu_voxels_ros

C++
2
star
22

halo_description

Robot Model definition of the HALO (Handheld Alphasense Lidar Ouster)
CMake
2
star
23

apriltags_archived

C
1
star
24

hierarchical-planning-sequences

Learning Sequences of Approximations for Hierarchical Motion Planning (ICAPS 2020)
C++
1
star
25

drs-externals

(was called legacy_pods)
CMake
1
star
26

cdt_challenge_2021

CDT Challenge 2021: Autonomous exploration with wheeled robots
Python
1
star
27

surfel_map

C++
1
star
28

centermask_ros

A package for launching centermask and detectron nodes in a dockerised catkin workspace
1
star
29

sdf_mp_integration

C++
1
star
30

manipulation_playground

A set of manipulation models used in the lab. Static and actuated models for visualisation and simulation
Python
1
star