Superpixel Sampling Networks
This is the code accompanying the ECCV 2018 publication on Superpixel Sampling Networks. Please visit the project website for more details about the paper and overall methodology.
License
Copyright (C) 2018 NVIDIA Corporation. All rights reserved. Licensed under the CC BY-NC-SA 4.0 license (https://creativecommons.org/licenses/by-nc-sa/4.0/legalcode).
Installation
Caffe Installation
- Go to 'lib' folder if you are not already there:
cd ssn_superpixels/lib/
- We make use of layers in 'Video Propagation Networks' caffe repository and add additional layers for SSN superpixels:
git clone https://github.com/varunjampani/video_prop_networks.git
- Manually copy all the source files (files in
lib/include
andlib/src
folders) to the corresponding locations in thecaffe
repository. In thessn_superpixels/lib
directory:
cp src/caffe/layers/* video_prop_networks/lib/caffe/src/caffe/layers/.
cp src/caffe/test/* video_prop_networks/lib/caffe/src/caffe/test/.
cp src/caffe/proto/caffe.proto video_prop_networks/lib/caffe/src/caffe/proto/caffe.proto
cp include/caffe/layers/* video_prop_networks/lib/caffe/include/caffe/layers/.
- Install Caffe following the installation instructions.
In the
ssn_superpixels/lib
directory:
cd video_prop_networks/lib/caffe/
mkdir build
cd build
cmake ..
make -j
cd ../../../..
Note: If you install Caffe in some other folder, update CAFFEDIR
in config.py
accordingly.
Install a cython file
We use a cython script taken from 'scikit-image' for enforcing connectivity in superpixels. To compile this:
cd lib/cython/
python setup.py install --user
cd ../..
Usage: BSDS segmentation
Data download
Download the BSDS dataset into data
folder:
cd data
sh get_bsds.sh
cd ..
Superpixel computation
- First download the trained segmentation models using the
get_models.sh
script in themodels
folder:
cd models
sh get_models.sh
cd ..
- Use
compute_ssn_spixels.py
to compute superpixels on BSDS dataset:
python compute_ssn_spixels.py --datatype TEST --n_spixels 100 --num_steps 10 --caffemodel ./models/ssn_bsds_model.caffemodel --result_dir ./bsds_100/
You can change the number of superpixels by changing the n_spixels
argument above, and you can update the datatype
to TRAIN
or VAL
to
compute superpixels on the corresponding data splits.
If you want to compute superpixels on other datasets, update config.py
accordingly.
Evaluation
For superpixel evaluation, we use scripts from here for computing ASA score and scripts from here for computing Precision-Recall and other evaluation metrics.
Training
Use train_ssn.py
to train on BSDS training dataset:
python train_ssn.py --l_rate=0.0001 --num_steps=10
Citation
Please consider citing the below paper if you make use of this work and/or the corresponding code:
@inproceedings{jampani18ssn,
title = {Superpixel Samping Networks},
author={Jampani, Varun and Sun, Deqing and Liu, Ming-Yu and Yang, Ming-Hsuan and Kautz, Jan},
booktitle = {European Conference on Computer Vision (ECCV)},
month = September,
year = {2018}
}