mirror of
https://github.com/wassname/scikit-image.git
synced 2026-06-28 04:07:14 +08:00
55f5103dd8
Modified travis_script.sh to account for the new structure of the gallery Added README.txt files in directories of gallery examples Fixed references to gallery images in user guide pages Fixed broken links
96 lines
4.0 KiB
Python
96 lines
4.0 KiB
Python
"""
|
|
====================================================
|
|
Comparison of segmentation and superpixel algorithms
|
|
====================================================
|
|
|
|
This example compares three popular low-level image segmentation methods. As
|
|
it is difficult to obtain good segmentations, and the definition of "good"
|
|
often depends on the application, these methods are usually used for obtaining
|
|
an oversegmentation, also known as superpixels. These superpixels then serve as
|
|
a basis for more sophisticated algorithms such as conditional random fields
|
|
(CRF).
|
|
|
|
|
|
Felzenszwalb's efficient graph based segmentation
|
|
-------------------------------------------------
|
|
This fast 2D image segmentation algorithm, proposed in [1]_ is popular in the
|
|
computer vision community.
|
|
The algorithm has a single ``scale`` parameter that influences the segment
|
|
size. The actual size and number of segments can vary greatly, depending on
|
|
local contrast.
|
|
|
|
.. [1] Efficient graph-based image segmentation, Felzenszwalb, P.F. and
|
|
Huttenlocher, D.P. International Journal of Computer Vision, 2004
|
|
|
|
|
|
Quickshift image segmentation
|
|
-----------------------------
|
|
|
|
Quickshift is a relatively recent 2D image segmentation algorithm, based on an
|
|
approximation of kernelized mean-shift. Therefore it belongs to the family of
|
|
local mode-seeking algorithms and is applied to the 5D space consisting of
|
|
color information and image location [2]_.
|
|
|
|
One of the benefits of quickshift is that it actually computes a
|
|
hierarchical segmentation on multiple scales simultaneously.
|
|
|
|
Quickshift has two main parameters: ``sigma`` controls the scale of the local
|
|
density approximation, ``max_dist`` selects a level in the hierarchical
|
|
segmentation that is produced. There is also a trade-off between distance in
|
|
color-space and distance in image-space, given by ``ratio``.
|
|
|
|
.. [2] Quick shift and kernel methods for mode seeking,
|
|
Vedaldi, A. and Soatto, S.
|
|
European Conference on Computer Vision, 2008
|
|
|
|
|
|
SLIC - K-Means based image segmentation
|
|
---------------------------------------
|
|
|
|
This algorithm simply performs K-means in the 5d space of color information and
|
|
image location and is therefore closely related to quickshift. As the
|
|
clustering method is simpler, it is very efficient. It is essential for this
|
|
algorithm to work in Lab color space to obtain good results. The algorithm
|
|
quickly gained momentum and is now widely used. See [3] for details. The
|
|
``compactness`` parameter trades off color-similarity and proximity, as in the
|
|
case of Quickshift, while ``n_segments`` chooses the number of centers for
|
|
kmeans.
|
|
|
|
.. [3] Radhakrishna Achanta, Appu Shaji, Kevin Smith, Aurelien Lucchi,
|
|
Pascal Fua, and Sabine Suesstrunk, SLIC Superpixels Compared to
|
|
State-of-the-art Superpixel Methods, TPAMI, May 2012.
|
|
"""
|
|
from __future__ import print_function
|
|
|
|
import matplotlib.pyplot as plt
|
|
import numpy as np
|
|
|
|
from skimage.data import astronaut
|
|
from skimage.segmentation import felzenszwalb, slic, quickshift
|
|
from skimage.segmentation import mark_boundaries
|
|
from skimage.util import img_as_float
|
|
|
|
img = img_as_float(astronaut()[::2, ::2])
|
|
segments_fz = felzenszwalb(img, scale=100, sigma=0.5, min_size=50)
|
|
segments_slic = slic(img, n_segments=250, compactness=10, sigma=1)
|
|
segments_quick = quickshift(img, kernel_size=3, max_dist=6, ratio=0.5)
|
|
|
|
print("Felzenszwalb's number of segments: %d" % len(np.unique(segments_fz)))
|
|
print("Slic number of segments: %d" % len(np.unique(segments_slic)))
|
|
print("Quickshift number of segments: %d" % len(np.unique(segments_quick)))
|
|
|
|
fig, ax = plt.subplots(1, 3, sharex=True, sharey=True, subplot_kw={'adjustable':'box-forced'})
|
|
fig.set_size_inches(8, 3, forward=True)
|
|
fig.subplots_adjust(0.05, 0.05, 0.95, 0.95, 0.05, 0.05)
|
|
|
|
ax[0].imshow(mark_boundaries(img, segments_fz))
|
|
ax[0].set_title("Felzenszwalbs's method")
|
|
ax[1].imshow(mark_boundaries(img, segments_slic))
|
|
ax[1].set_title("SLIC")
|
|
ax[2].imshow(mark_boundaries(img, segments_quick))
|
|
ax[2].set_title("Quickshift")
|
|
for a in ax:
|
|
a.set_xticks(())
|
|
a.set_yticks(())
|
|
plt.show()
|