The
image segmentation
In digital image processing and computer vision, image segmentation is the process of partitioning a digital image into multiple image segments, also known as image regions or image objects (Set (mathematics), sets of pixels). The goal of segmen ...
problem is concerned with partitioning an image into multiple regions according to some homogeneity criterion. This article is primarily concerned with graph theoretic approaches to image segmentation applying
graph partitioning
In mathematics, a graph partition is the reduction of a graph to a smaller graph by partitioning its set of nodes into mutually exclusive groups. Edges of the original graph that cross between the groups will produce edges in the partitioned graph ...
via
minimum cut
In graph theory, a minimum cut or min-cut of a graph is a cut (a partition of the vertices of a graph into two disjoint subsets) that is minimal in some metric.
Variations of the minimum cut problem consider weighted graphs, directed graphs, ter ...
or
maximum cut
In a graph, a maximum cut is a cut whose size is at least the size of any other cut. That is, it is a partition of the graph's vertices into two complementary sets and , such that the number of edges between and is as large as possible. ...
. Segmentation-based object categorization can be viewed as a specific case of
spectral clustering
In multivariate statistics, spectral clustering techniques make use of the spectrum (eigenvalues) of the similarity matrix of the data to perform dimensionality reduction before clustering in fewer dimensions. The similarity matrix is provided ...
applied to image segmentation.
Applications of image segmentation
* Image compression
** Segment the image into homogeneous components, and use the most suitable compression algorithm for each component to improve compression.
* Medical diagnosis
** Automatic segmentation of MRI images for identification of cancerous regions.
* Mapping and measurement
** Automatic analysis of
remote sensing
Remote sensing is the acquisition of information about an physical object, object or phenomenon without making physical contact with the object, in contrast to in situ or on-site observation. The term is applied especially to acquiring inform ...
data from satellites to identify and measure regions of interest.
* Transportation
** Partition a transportation network makes it possible to identify regions characterized by homogeneous traffic states.
Segmentation using normalized cuts
Graph theoretic formulation
The set of points in an arbitrary feature space can be represented as a weighted undirected complete graph G = (V, E), where the nodes of the graph are the points in the feature space. The weight
of an edge
is a function of the similarity between the nodes
and
. In this context, we can formulate the image segmentation problem as a graph partitioning problem that asks for a partition
of the vertex set
, where, according to some measure, the vertices in any set
have high similarity, and the vertices in two different sets
have low similarity.
Normalized cuts
Let ''G'' = (''V'', ''E'', ''w'') be a weighted graph. Let
and
be two subsets of vertices.
Let:
:
:
:
In the normalized cuts approach, for any cut
in
,
measures the similarity between different parts, and
measures the total similarity of vertices in the same part.
Since
, a cut
that minimizes
also maximizes
.
Computing a cut
that minimizes
is an
NP-hard
In computational complexity theory, a computational problem ''H'' is called NP-hard if, for every problem ''L'' which can be solved in non-deterministic polynomial-time, there is a polynomial-time reduction from ''L'' to ''H''. That is, assumi ...
problem. However, we can find in polynomial time a cut
of small normalized weight
using
spectral techniques.
The ncut algorithm
Let:
:
Also, let ''D'' be an
diagonal matrix with
on the diagonal, and let
be an
symmetric matrix with
.
After some algebraic manipulations, we get:
:
subject to the constraints:
*
, for some constant
*
Minimizing
subject to the constraints above is
NP-hard
In computational complexity theory, a computational problem ''H'' is called NP-hard if, for every problem ''L'' which can be solved in non-deterministic polynomial-time, there is a polynomial-time reduction from ''L'' to ''H''. That is, assumi ...
. To make the problem tractable, we relax the constraints on
, and allow it to take real values. The relaxed problem can be solved by solving the generalized eigenvalue problem
for the second smallest generalized eigenvalue.
The partitioning algorithm:
# Given a set of features, set up a weighted graph
, compute the weight of each edge, and summarize the information in
and
.
# Solve
for eigenvectors with the second smallest eigenvalues.
# Use the eigenvector with the second smallest eigenvalue to bipartition the graph (e.g. grouping according to sign).
# Decide if the current partition should be subdivided.
# Recursively partition the segmented parts, if necessary.
Computational Complexity
Solving a standard eigenvalue problem for all eigenvectors (using the
QR algorithm
In numerical linear algebra, the QR algorithm or QR iteration is an eigenvalue algorithm: that is, a procedure to calculate the eigenvalues and eigenvectors of a Matrix (mathematics), matrix. The QR algorithm was developed in the late 1950s by John ...
, for instance) takes
time. This is impractical for image segmentation applications where
is the number of pixels in the image.
Since only one eigenvector, corresponding to the second smallest generalized eigenvalue, is used by the uncut algorithm, efficiency can be dramatically improved if the solve of the corresponding eigenvalue problem is performed in a
matrix-free fashion, i.e., without explicitly manipulating with or even computing the matrix W, as, e.g., in the
Lanczos algorithm
The Lanczos algorithm is an iterative method devised by Cornelius Lanczos that is an adaptation of power iteration, power methods to find the m "most useful" (tending towards extreme highest/lowest) eigenvalues and eigenvectors of an n \times n ...
.
Matrix-free methods In computational mathematics, a matrix-free method is an algorithm for solving a linear system of equations or an eigenvalue problem that does not store the coefficient matrix explicitly, but accesses the matrix by evaluating matrix-vector products ...
require only a function that performs a matrix-vector product for a given vector, on every iteration. For image segmentation, the matrix W is typically sparse, with a number of nonzero entries
, so such a matrix-vector product takes
time.
For high-resolution images, the second eigenvalue is often
ill-conditioned
In numerical analysis, the condition number of a function measures how much the output value of the function can change for a small change in the input argument. This is used to measure how sensitive a function is to changes or errors in the inpu ...
, leading to slow convergence of iterative eigenvalue solvers, such as the
Lanczos algorithm
The Lanczos algorithm is an iterative method devised by Cornelius Lanczos that is an adaptation of power iteration, power methods to find the m "most useful" (tending towards extreme highest/lowest) eigenvalues and eigenvectors of an n \times n ...
.
Preconditioning
In mathematics, preconditioning is the application of a transformation, called the preconditioner, that conditions a given problem into a form that is more suitable for numerical solving methods. Preconditioning is typically related to reducing ...
is a key technology accelerating the convergence, e.g., in the matrix-free
LOBPCG Locally Optimal Block Preconditioned Conjugate Gradient (LOBPCG) is a matrix-free method for finding the largest (or smallest) eigenvalues and the corresponding eigenvectors of a symmetric generalized eigenvalue problem
:A x= \lambda B x,
for a g ...
method. Computing the eigenvector using an optimally preconditioned matrix-free method takes
time, which is the optimal complexity, since the eigenvector has
components.
Software Implementations
scikit-learn
scikit-learn (formerly scikits.learn and also known as sklearn) is a free and open-source machine learning library for the Python programming language.
It features various classification, regression and clustering algorithms including support ...
uses
LOBPCG Locally Optimal Block Preconditioned Conjugate Gradient (LOBPCG) is a matrix-free method for finding the largest (or smallest) eigenvalues and the corresponding eigenvectors of a symmetric generalized eigenvalue problem
:A x= \lambda B x,
for a g ...
from
SciPy
SciPy (pronounced "sigh pie") is a free and open-source Python library used for scientific computing and technical computing.
SciPy contains modules for optimization, linear algebra, integration, interpolation, special functions, fast Fourier ...
with
algebraic multigrid preconditioning for solving the
eigenvalue
In linear algebra, an eigenvector ( ) or characteristic vector is a vector that has its direction unchanged (or reversed) by a given linear transformation. More precisely, an eigenvector \mathbf v of a linear transformation T is scaled by a ...
problem for the
graph Laplacian
In the mathematical field of graph theory, the Laplacian matrix, also called the graph Laplacian, admittance matrix, Kirchhoff matrix, or discrete Laplacian, is a matrix representation of a graph. Named after Pierre-Simon Laplace, the graph Lap ...
to perform
image segmentation
In digital image processing and computer vision, image segmentation is the process of partitioning a digital image into multiple image segments, also known as image regions or image objects (Set (mathematics), sets of pixels). The goal of segmen ...
via spectral
graph partitioning
In mathematics, a graph partition is the reduction of a graph to a smaller graph by partitioning its set of nodes into mutually exclusive groups. Edges of the original graph that cross between the groups will produce edges in the partitioned graph ...
as first proposed in and actually tested in and.
OBJ CUT
OBJ CUT is an efficient method that automatically segments an object. The OBJ CUT method is a generic method, and therefore it is applicable to any object category model.
Given an image D containing an instance of a known object category, e.g. cows, the OBJ CUT algorithm computes a segmentation of the object, that is, it infers a set of labels ''m''.
Let m be a set of binary labels, and let
be a shape parameter(
is a shape prior on the labels from a
layered pictorial structure (LPS) model). An energy function
is defined as follows.
:
(1)
The term
is called a unary term, and the term
is called a pairwise term.
A unary term consists of the likelihood
based on color, and the unary potential
based on the distance from
. A pairwise term consists of a prior
and a contrast term
.
The best labeling
minimizes
, where
is the weight of the parameter
.
:
(2)
Algorithm
# Given an image D, an object category is chosen, e.g. cows or horses.
# The corresponding LPS model is matched to D to obtain the samples
# The objective function given by equation (2) is determined by computing
and using
# The objective function is minimized using a single
MINCUT operation to obtain the segmentation m.
Other approaches
* Jigsaw approach
* Image parsing
* Interleaved segmentation
* LOCUS
* LayoutCRF
[J. M. Winn, J. Shotton]
The Layout Consistent Random Field for Recognizing and Segmenting Partially Occluded Objects
CVPR (1) 2006: 37–44
*
Minimum spanning tree-based segmentation Segmentation (image processing), Image segmentation strives to partition a digital image into regions of pixels with similar properties, e.g. homogeneity. The higher-level region representation simplifies image analysis tasks such as counting object ...
References
{{reflist, 32em
Object recognition and categorization
Image segmentation