Commit 6891d778 authored by Alexander Alekhin's avatar Alexander Alekhin Committed by GitHub

Merge pull request #923 from cbalint13:mslic

Add MSLIC (Manifold SLIC)
parents 04ad07c0 ce2fd8e3
...@@ -160,6 +160,14 @@ ...@@ -160,6 +160,14 @@
keywords = {Superpixels, segmentation, clustering, k-means} keywords = {Superpixels, segmentation, clustering, k-means}
} }
@InProceedings{Liu_2016_CVPR,
author = {Liu, Yong-Jin and Yu, Cheng-Chi and Yu, Min-Jing and He, Ying},
title = {Manifold SLIC: A Fast Method to Compute Content-Sensitive Superpixels},
booktitle = {The IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
month = {June},
year = {2016}
}
@InProceedings{LiCVPR2015LSC, @InProceedings{LiCVPR2015LSC,
author = {Li, Zhengqin and Chen, Jiansheng}, author = {Li, Zhengqin and Chen, Jiansheng},
title = {Superpixel Segmentation Using Linear Spectral Clustering}, title = {Superpixel Segmentation Using Linear Spectral Clustering},
......
...@@ -61,6 +61,8 @@ namespace ximgproc ...@@ -61,6 +61,8 @@ namespace ximgproc
//! @addtogroup ximgproc_superpixel //! @addtogroup ximgproc_superpixel
//! @{ //! @{
enum SLIC { SLIC = 100, SLICO = 101, MSLIC = 102 };
/** @brief Class implementing the SLIC (Simple Linear Iterative Clustering) superpixels /** @brief Class implementing the SLIC (Simple Linear Iterative Clustering) superpixels
algorithm described in @cite Achanta2012. algorithm described in @cite Achanta2012.
...@@ -68,7 +70,9 @@ SLIC (Simple Linear Iterative Clustering) clusters pixels using pixel channels a ...@@ -68,7 +70,9 @@ SLIC (Simple Linear Iterative Clustering) clusters pixels using pixel channels a
to efficiently generate compact, nearly uniform superpixels. The simplicity of approach makes it to efficiently generate compact, nearly uniform superpixels. The simplicity of approach makes it
extremely easy to use a lone parameter specifies the number of superpixels and the efficiency of extremely easy to use a lone parameter specifies the number of superpixels and the efficiency of
the algorithm makes it very practical. the algorithm makes it very practical.
Several optimizations are available for SLIC class:
SLICO stands for "Zero parameter SLIC" and it is an optimization of baseline SLIC descibed in @cite Achanta2012.
MSLIC stands for "Manifold SLIC" and it is an optimization of baseline SLIC described in @cite Liu_2016_CVPR.
*/ */
class CV_EXPORTS_W SuperpixelSLIC : public Algorithm class CV_EXPORTS_W SuperpixelSLIC : public Algorithm
...@@ -134,26 +138,25 @@ public: ...@@ -134,26 +138,25 @@ public:
}; };
/** @brief Class implementing the SLIC (Simple Linear Iterative Clustering) superpixels /** @brief Initialize a SuperpixelSLIC object
@param image Image to segment @param image Image to segment
@param algorithm Chooses the algorithm variant to use: @param algorithm Chooses the algorithm variant to use:
SLIC segments image using a desired region_size, and in addition SLIC segments image using a desired region_size, and in addition SLICO will optimize using adaptive compactness factor,
SLICO will choose an adaptive compactness factor. while MSLIC will optimize using manifold methods resulting in more content-sensitive superpixels.
@param region_size Chooses an average superpixel size measured in pixels @param region_size Chooses an average superpixel size measured in pixels
@param ruler Chooses the enforcement of superpixel smoothness factor of superpixel @param ruler Chooses the enforcement of superpixel smoothness factor of superpixel
The function initializes a SuperpixelSLIC object for the input image. It sets the parameters of choosed The function initializes a SuperpixelSLIC object for the input image. It sets the parameters of choosed
superpixel algorithm, which are: region_size and ruler. It preallocate some buffers for future superpixel algorithm, which are: region_size and ruler. It preallocate some buffers for future
computing iterations over the given image. An example of SLIC versus SLICO is ilustrated in the computing iterations over the given image. For enanched results it is recommended for color images to
following picture. preprocess image with little gaussian blur using a small 3 x 3 kernel and additional conversion into
CieLAB color space. An example of SLIC versus SLICO and MSLIC is ilustrated in the following picture.
![image](pics/superpixels_slic.png) ![image](pics/superpixels_slic.png)
*/ */
enum SLIC { SLIC = 100, SLICO = 101 };
CV_EXPORTS_W Ptr<SuperpixelSLIC> createSuperpixelSLIC( InputArray image, int algorithm = SLICO, CV_EXPORTS_W Ptr<SuperpixelSLIC> createSuperpixelSLIC( InputArray image, int algorithm = SLICO,
int region_size = 10, float ruler = 10.0f ); int region_size = 10, float ruler = 10.0f );
......
...@@ -19,7 +19,7 @@ static const char* keys = ...@@ -19,7 +19,7 @@ static const char* keys =
"{h help | | help menu}" "{h help | | help menu}"
"{c camera |0| camera id}" "{c camera |0| camera id}"
"{i image | | image file}" "{i image | | image file}"
"{a algorithm |1| SLIC(0),SLICO(1)}" "{a algorithm |1| SLIC(0),SLICO(1),MSLIC(2)}"
; ;
int main(int argc, char** argv) int main(int argc, char** argv)
...@@ -63,7 +63,7 @@ int main(int argc, char** argv) ...@@ -63,7 +63,7 @@ int main(int argc, char** argv)
} }
namedWindow(window_name, 0); namedWindow(window_name, 0);
createTrackbar("Algorithm", window_name, &algorithm, 1, 0); createTrackbar("Algorithm", window_name, &algorithm, 2, 0);
createTrackbar("Region size", window_name, &region_size, 200, 0); createTrackbar("Region size", window_name, &region_size, 200, 0);
createTrackbar("Ruler", window_name, &ruler, 100, 0); createTrackbar("Ruler", window_name, &ruler, 100, 0);
createTrackbar("Connectivity", window_name, &min_element_size, 100, 0); createTrackbar("Connectivity", window_name, &min_element_size, 100, 0);
......
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment