Skip to content

Implementation for "Saliency-guided Adaptive Seeding for Supervoxel Segmentation" @IROS2017

License

Notifications You must be signed in to change notification settings

GeeeG/SalientSupervoxel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SalientSupervoxel

This is the C++ implementation of Saliency-guided adaptive seeding for supervoxel segmentation (SSV).

Here's an example output of SSV comparing with baseline approach Voxel Cloud Connectivity Segmentation (VCCS) in pcl library.

The basic idea is to grow smaller supervoxels in more salient regions and bigger supervoxels in less salient regions, by using visual saliency as prior knowledge.

Left is the input point cloud, middle is oversegmentation result with uniformed seeding with VCCS, right is oversegmentation result with saliency-guided adaptive seeding with our approach (SSV).

ssv example

Usage

Required dependency:

  1. opencv2
  2. pcl1.8

Build and run

mkdir build & cd build
cmake ..
make

Please note that you need a saliency map (salmap.png) and the corresponding point cloud (cloud.pcd) to run this algorithm. Here is an example of setting minimum and maximum seeding resolution to 0.05 and 0.5 respectively, with 3 clusters for kmeans.

A set of .pcd and .png file example of a table scenario can be found under example.

./ssv_test table.pcd table.png -k 3 -i 0.05 -a 0.5

To test it on your own example, a saliency map can be generated using "VOCUS2" (Frintrop et al., CVPR 2015), you can find the instructions here VOCUS2.

git clone https://github.com/GeeeG/VOCUS2.git
cd vocus2-version1.1
cmake . 
make
./vocus2 test_img.png

For more information on VOCUS2 please refer to Computer Vision Group @ Uni Hamburg

Results

SSV is evaluated using superpixel-benchmark by Stutz et al with NYUV2 by Silberman et al and SUNRGBD by Song et al datasets.

Here are some results regarding boundary recall (REC) and undersegmentation error (UE) on SUNRGBD dataset. ssv result

Performance

The implementation is tested on a 3.5 GHz Intel i7 CPU.

Average processing time for baseline approach VCCS is 0.45 second/frame

Average processing time is for SSV varies w.r.t number of k-means clusters, e.g. with K=3,4,5 processing times are 0.71, 0.58 and 0.48 second/frame respectively.

Publication

Further details are available in our paper on the subject. If you use this code in an academic context, please cite the paper: Ge Gao, Mikko Lauri, Jianwei Zhang and Simone Frintrop. "Saliency-guided adaptive seeding for supervoxel segmentation", IROS 2017. arxiv version

BiBTeX:

@inproceedings{gaoetal2017ssv,
  title={Saliency-guided Adaptive Seeding for Supervoxel Segmentation},
  author={G. Gao, M. Lauri, J. Zhang and S. Frintrop},
  booktitle={International Conference on Intelligent Robots and Systems},
  year={2017}
}

About

Implementation for "Saliency-guided Adaptive Seeding for Supervoxel Segmentation" @IROS2017

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published