Image Processing
Image Processing
Image Processing
Image Processing
2.1
Introduction
Computer vision operates on images that come in the form of arrays of pixel values. When these
images are transformed to obtain another image (as opposed to some other data structure), we say
that image processing (as opposed to computer vision) is performed. This Section discusses some
essential image processing operations.
The pixel values in the input image are invariably affected by noise, and it is often useful to
clean the images somewhat with what is called a filter before they are further processed. Depending on the type of noise, a linear or nonlinear filter may be more appropriate. These filters may
merely suppress fine detail so as to remove as much noise and as little useful signal as possible.
Alternatively, image enhancement filters may attempt to undo part of an undesired image transformation, such as the blur resulting from poor lens focusing or from relative motion between the
camera and the scene.
Applications of filtering to computer vision are not limited to image cleanup or enhancement.
Other uses include taking derivatives of image intensity (a concept that strictly speaking is defined
only for the continuous distribution of intensities on the imaging sensor) and detecting image
structure (edges, periodic patterns, regions).
This Section discusses these concepts at a level that is sufficient for a good amount of work
in computer vision. A more formal and thorough treatment can be found in classic books on
image processing [2]. In addition, many topics of image processing are not treated at all in this
Section. These include point processing (for instance, gamma correction, histogram equalization,
or contrast enhancement); color processing (which requires substantial amount of material from
psychophysics for a proper treatment); image morphology, compression, and compositing. These
are all fascinating topics, but we need to choose.
2.2
Images
2.2
(d) Gray
k = 1 ; R = {L : 0 L 255}
2.3
scheme requires storing only mn + 3c numbers, where c is the number of triples in the color map.2
Additional compression can be obtained if groups of similar colors are approximated by single
colors. For instance, the image in Figure 2.1(a) has 28952 colors, but a reasonable approximation
of this image can be obtained with only 100 distinct colors, as shown in the color-mapped image in
Figure 2.1(b). The 100 colors were obtained by a clustering algorithm, which finds the 100 groups
of colors in the original image that can best be approximated by one color per group. Different
definitions of best approximation yield different clustering algorithms. Figure 2.1(c) shows a
more aggressive color map compression with only ten colors.
A color image, color mapped or not, can be converted into a gray image by recording only the
luminance
L = 0.30R + 0.59G + 0.11B
of each pixel. The three coefficients in this formula approximate the average response of the human
eye to the three colors. Figure 2.1(d) shows the gray version of the color image in Figure 2.1(a).
Extreme compression can be achieved by storing a single bit (0 for black and 1 for white)
for each pixel, as done in Figure 2.1(e). Half-toned images of this type are obtained by a class
of techniques called halftoning or dithering, which produce the impression of gray by properly
placed clusters of black dots in white areas. This compression method used to be useful for twotone printing devices or displays, and can still be found in some newspapers that are printed with
devices that can only either paint or not paint a black dot at any position on a white page.
More generally, a binary image is any image with only two levels of brightness. For instance,
the image in Figure 2.1(f) was obtained by thresholding the gray image in Figure 2.1(d) with the
value 100: pixels that are at least as bright as this value are transformed to white, and the others to
black.
Regardless of range, we denote the pixel value (an integer or a triple) at row r and column c by
I(r, c) (or other symbols instead of I) when we want to emphasize the array nature of an image.
When graphics-style conventions are more useful, we use I(xi , yi ) and express image position
in the image reference system introduced in the Section on image formation. In discussions of
reconstruction methods, writing coordinates in the camera reference system is more natural, so we
use I(x, y) instead. For video, we add a third coordinate, typically t for time or f for frame.
2.3
However, unless the image has at most 256 rows and columns, the indices take more than one byte each.
2.4
where D is the domain of I. This is just like matrix multiplication, but with twice the indices:
every pixel (r, c) of the output is a linear combination of all of the pixels (i, j) of the input, and the
combination for each output pixel can in principle have a different set of coefficients.
Even more explicitly, equation (1) can be written in matrix form if the input and output images
I and J are transformed into vectors i and j that list all the pixels in a fixed order. For instance, if
the image I has m rows and n columns, then the transformation
i(entry(i, j)) = I(i, j) where entry(i, j) = m(j 1) + i for 1 i m and 1 j n
lists the pixels in I in column-major order. Equivalently,
i(k) = I(row(k), col(k)) where row(k) = ((k 1) mod m) + 1 and col(k) = dk/me
where de is the ceil operator.
The block L of coefficients in equation (1) can then be transformed accordingly into a matrix
L where
L(entry(i, j), entry(r, c)) = L(i, j, r, c) .
The matrix L is square, with mn rows and mn columns. Its huge size reflects the great generality
of the definition of a linear transformation.
Practical Aspects: Indices in Matlab and C. In Matlab, transformation into a vector in columnmajor order is conveniently achieved by the instruction
i = I(:);
The reverse operation is
I = reshape(i, m, n);
In a language like C, arrays and vectors are typically indexed starting at 0 rather than 1, and
row-major order is preferred:
i(entryC (i, j)) = I(i, j)
where
In this case,
colC (k) = k
2.3.1
mod n
and
With this definition, only trivial image transformations are linear: since the range of pixel values
is finite, adding two images, or multiplying an image by a constant, often produces values out
of range. This saturation problem must be taken into account for nearly every image processing
algorithm. However, the advantages of linear transformations are so great that we temporarily
redefine the range of images to be subsets of the real numbers. Conceptually, we proceed as
illustrated in Figure 2.2: we first transform each image I into its real-range version R(I): I and
R(I) are the same image, but the values of the latter are thought of as real numbers, rather than
2.5
integers in a finite set. We then do image processing (the transformation P in the Figure), and
finally revert to the original range through a quantization operator Q. Quantization restores the
range to a finite set, and is more substantial than R:
Figure 2.2: For linear processing, images are transformed through a conceptual point operation
R that regards image values as real numbers. After processing P occurs, the values of the resulting
image are quantized through point operator Q.
Practical Aspects: Casts. When programming, the operator R is often implemented as a type
cast operation that converts integers to floating-point numbers. For instance, in Matlab we
would write something like the following:
img = double(img);
Conveniently, the Matlab uint8 operator (for unsigned integer with 8 bits) performs quantization Q:
img = uint8(img);
2.3.2
Convolution
The size of the matrix L for a general, linear image transformation makes it essentially impossible
to use in practice. Fortunately, many transformations of great practical interest correspond to a
matrix L with a great deal of structure.
The most important case is convolution, which adds structure to a general linear transformation
in two ways. First, the value of a pixel at position (r, c) in the output image J is a linear combination of the pixel values in a relatively small neighborhood of position (r, c) in the input image I,
rather than of all the pixel values in I. Second, the coefficients of the linear combination are the
same for all output pixel positions (r, c).
The first property of convolution implies that L(i, j, r, c) and its flattened form L(entry(i, j),
entry(r, c)) have only a small number of nonzero entries. The second property implies that there
2.6
(a)
2
11,2
22
2
1 1,2
1,2
(b)
22
2
2
(c)
It is a useful exercise to work out the structure of L for a small case. The resulting matrix structure is called
block-Toeplitz with Toeplitz blocks.
2.7
If the input (focused) image I has a certain value I(i, j) at the pixel in row i, column j, then
that value is divided by 21, to reflect the fact that the energy of one pixel is spread over 21 pixels,
and then written into the pixels in the neighborhood of pixel (i, j) in the output (blurred) image J.
Consider now the pixel just to the right of (i, j) in the input image, at position (i, j + 1). That will
have a value I(i, j + 1), which in turn needs to be written into the pixels of the neighborhood of
(i, j + 1) in the output image J. However, the two neighborhoods just defined overlap. What value
is written into pixels in the overlap region?
The physics is additive: each pixel in the overlap region is lit by both blurs, and is therefore
painted with the sum of the two values. The region marked 1, 2 in Figure 2.3(b) is the overlap of
two adjacent neighborhoods. Pixels in the areas marked with only 1 or only 2 only get one value.
This process can be repeated for each pixel in the input image I. In programming terms, one
can start with all pixels in the output image J set to zero, loop through each pixel (i, j) in the input
image, and for each pixel add I(i, j) to the pixels that are in the neighborhood of pixel (i, j) in
J. In order to do this, it is convenient to define a point-spread function, that is, a 5 5 matrix H
that contains a value of 1/21 everywhere except at its four corners, where it contains zeros. For
symmetry, it is also convenient to number the rows and columns of H with integers between 2
and 2:
2 1 0 1 2
0 1 1 1 0
2
1
1 1 1 1 1 1
H=
0
21
1 1 1 1 1
1 1 1 1 1
1
0 1 1 1 0
2
Use of the matrix H allows writing the summation at each pixel position (i, j) with the two for
loops in u and v below:
for i = 1:m
for j = 1:n
J(i, j) = 0
end
end
for i = 1:m
for j = 1:n
for u = -2:2
for v = -2:2
J(i+u, j+v) = J(i+u, j+v) + H(u, v) * I(i, j)
end
end
end
end
This first view of the blur operation paid attention to an individual pixel in the input image I,
and followed its values as they were dispersed into the output image J.
2.8
The second view lends itself better to mathematical notation, and does the reverse of the first
view by asking the following question: what is the final value at any given pixel (r, c) in the
output image? This pixel receives a contribution from each of the neighborhoods that overlap it,
as shown in Figure 2.3(c). There are 21 such neighborhoods, because each neighborhood has 21
pixels. Specifically, whenever a pixel (i, j) in the input image is within 2 pixels from pixel (r, c)
horizontally and vertically, pixel (i, j) is in the square bounding box of the neighborhood. The
positions corresponding to the four corner pixels, for which there is no overlap, can be handled, as
before, through the point-spread function H to obtain a similar piece of code as before:
for r = 1:m
for c = 1:n
J(r, c) = 0
for u = -2:2
for v = -2:2
J(r, c) = J(r, c) + H(u, v) * I(r-u, c-v)
end
end
end
end
Note that the two outermost loops now scan the output image, rather than the input image.
This program can be translated into mathematical notation as follows:
J(r, c) =
2
2
X
X
H(u, v)I(r u, c v) .
(2)
u=2 v=2
In contrast, a direct mathematical translation from the earlier piece of code is not obvious. The
operation described by equation (2) is called convolution.
Of course, the point-spread function can contain arbitrary values, not just 0 and 1/21. For instance, a better approximation for the blur point-spread function can be computed by assigning to
each entry of H a value proportional to the area of the blur circle (the gray circle in Figure 2.3(a))
that overlaps the corresponding pixel. Simple but lengthy mathematics, or numerical approximation, yields the following values for a 5 5 approximation H to the pillbox function:
0.0500
0.0511
0.0511
0.0511
0.0500
H=
1,2
1
2.9
r-u, c-v
r,c
Figure 2.4: The contribution of input pixel I(r 2, c 1) (blue) with to output pixel J(r, c) (red)
is determined by entry H(2, 1) of the point-spread function (gray).
have no effect. However, if H is not symmetric, the signs make good sense: with u, v positive,
say, pixel (r u, c v) is to the left of and above pixel (r, c), so the contribution of the input pixel
value I(r u, c v) to output pixel value J(r, c) is mediated through a low-right value of the
point-spread function H. This is illustrated in Figure 2.4.
Mathematical manipulation becomes easier if the domains of both point-spread function and
images are extended to Z2 by the convention that unspecified values are set to zero. In this way,
the summations in the definition of convolution can be extended to the entire plane:4
J(r, c) =
X
X
H(u, v)I(r u, c v) .
(3)
u= v=
The changes of variables u r u and v c v then entail the equivalence of equation (3) with
the following expression:
J(r, c) =
X
X
H(r u, c v)I(u, v)
u= v=
(4)
2.10
X
X
H(u, v)I(r u, c v)
u= v=
X
X
H(r u, c v)I(u, v) .
(5)
u= v=
A delta image centered at a, b is an image that has a pixel value of 1 at (a, b) and zero everywhere else:
1 for u = a and v = b
a,b (u, v) =
.
0 elsewhere
Substitution of a,b (u, v) for I(u, v) in the second form of equation (5) shows immediately that the
convolution of a delta image with a point-spread function H returns H itself, centered at (a, b):
[a,b H](r, c) = H(r a, c b) .
(6)
This equation explains the meaning of the term point-spread function: the point in the delta
image is spread into a blur equal to H. Equation (5) then shows that the output image J is obtained
by the superposition (sum) of one such blur, centered at (u, v) and scaled by the value I(u, v), for
each of the pixels in the input image.
The result in equation (6) is particularly simple when image domains are thought of as infinite,
and when a = b = 0. We then define
(u, v) = 0,0 (u, v)
and obtain
H =H .
The point-spread function H in the definition of convolution (or, sometimes, the convolution
operation itself) is said to be shift-invariant or space-invariant because the entries in H do not
depend on the position (r, c) in the output image. In the case of image blur caused by poor lens
focusing, invariance is only an approximation. As seen in the Section on image formation, a
shallow depth of field leads to different amounts of blur in different parts of the image. In this
case, one needs to consider a point-spread function of the form H(u, v, r, c). This is still simpler
than the general linear transformation in equation (1), because the number of nonzero entries for
each value of r and c in H is equal to the neighborhood size, rather than the image size.
2.11
X
X
H(u, v, r, c)I(r u, c v)
u= v=
X
X
H(r u, c v, r, c)I(u, v) .
(7)
u= v=
i14
i14
i14
i24
i34
i44
i44
i44
i15
i15
i15
i25
i35
i45
i45
i45
i15
i15
i15
i25
i35
i45
i45
i45
i15
i15
i15
i25
i35
i45
i45
i45
This is a relatively simple solution, avoids spurious discontinuities, and preserves image
size.
2.12
The Matlab convolution function conv2 provides options full, valid, and same to
implement the first three alternatives above, in that order.
Figure 2.5 shows an example of shift-variant convolution: for a coarse grid (ri , cj ) of pixel
positions, the diameter d(ri , cj ) of the pillbox function H that best approximates the blur between
the image I in (a) and J in Figure 2.5(b) is found by trying all integer diameters and picking the
one for which
X
D2 (r, c) where D(r, c) = J(r, c) [I H](r, c)
(r,c)W (ri ,cj )
is as small as possible for a fixed-size window W (ri , cj ) centered at (ri , cj ). These diameter values
are shown in Figure 2.5(c).
Each of the three color bands in the image in Figure 2.5(a) is then padded with replicas of its
boundary values, as explained earlier, and filtered with a space-varying pillbox point-spread function, whose diameter d(r, c) at pixel (r, c) is defined by bilinear interpolation of the surrounding
coarse-grid values as follows. Let
u = arg max {ri : ri r} and v = arg max {cj : cj c}
i
be the indices of the coarse-grid point just to the left of and above position (r, c). Then
ru+1 r cv+1 c
d(r, c) = round d(ru , cv )
ru+1 ru cv+1 cv
r
cv+1 c
+ d(ru+1 , cv )
ru+1 ru cv+1 cv
ru+1 r
c
+ d(ru , cv+1 )
ru+1 ru cv+1 cv
r
c
+ d(ru+1 , cv+1 )
.
ru+1 ru cv+1 cv
The space-varying convolution is performed by literal implementation of equation (7), and is therefore very slow.
2.4
Filters
The lens blur model is an example of shift-varying convolution. Shift-invariant convolutions are
also pervasive in image processing, where they are used for different purposes, including the reduction of the effects of image noise and image differentiation. We discuss linear noise filters in
this Section, and differentiation in the next.
The effects of noise on images can be reduced by smoothing, that is, by replacing every pixel
by a weighted average of its neighbors. The reason for this can be understood by thinking of an
image patch that is small enough that the image intensity function I is well approximated by its
2.13
(a)
20
20
20
20
20
20
20
20
20
18
20
20
20
20
20
20
15
14
17
19
20
19
16
14
11 9 7
10 18 8
12 9 9
11 8 9
10 8 8
12 8 9
11 7 9
10 10 10
(c)
(b)
7
6
8
7
6
6
7
8
5
5
7
7
7
5
9
5
5
4
6
5
5
4
6
7
5
4
5
3
4
3
5
8
2
3
7
5
7
7
6
6
4
5
6
7
7
7
7
7
(d)
Figure 2.5: (a) An image taken with a narrow aperture, resulting in a great depth of field. (b) The
same image taken with a wider aperture, resulting in a shallow depth of field and depth-dependent
blur. (c) Values of the diameter of the pillbox point-spread function that best approximates the
transformation from (a) to (b) in windows centered at a coarse grid on the image. The grid points
are 300 rows and columns apart in a 2592 3872 image. (d) The image in (a) filtered with a
space-varying pillbox function, whose diameters are computed by bilinear interpolation from the
surrounding coarse-grid diameter values.
2.14
Figure 2.6: The two dimensional kernel on the left can be obtained by rotating the function (r)
on the right around a vertical axis through the maximum of the curve (r = 0).
tangent plane at the center (r, c) of the patch. Then, the average value of the patch is I(r, c), so that
averaging does not alter image value. On the other hand, noise added to the image can usually be
assumed to be zero mean, so that averaging reduces the noise component. Since both filtering and
averaging are linear, they can be switched: the result of filtering image plus noise is equal to the
result of filtering the image (which does not alter values) plus the result of filtering noise (which
reduces noise). The net outcome is an increase of the signal-to-noise ratio.
For independent noise values, noise reduction is proportional to the square root of the number
of pixels in the smoothing window, so a large window is preferable. However, the assumption that
the image intensity is approximately linear fails more and more as the window size increases, and is
violated particularly badly along edges, where the image intensity function is nearly discontinuous,
as shown in Figure 2.8. Thus, when smoothing, a compromise must be reached between noise
reduction and image blurring.
The pillbox function is an example of a point-spread function that could be used for smoothing.
The kernel (a shorter name for the point-spread function) is usually rotationally symmetric, as there
is no reason to privilege, say, the pixels on the left of a given pixel over those on its right5 :
G(v, u) = ()
where
=
u2 + v 2
is the distance from the center of the kernel to its pixel (u, v). Thus, a rotationally symmetric
kernel can be obtained by rotating a one-dimensional function () defined on the nonnegative
reals around the origin of the plane (figure 2.6).
The plot in figure 2.6 was obtained from the (unnormalized) Gaussian function
1
() = e 2 ( )
5
This only holds for smoothing. Nonsymmetric filters tuned to particular orientations are very important in vision.
Even for smoothing, some authors have proposed to bias filtering along an edge away from the edge itself. An idea
worth pursuing.
2.15
G(v, u) = e 2
(8)
This last sentence will only make sense to you if you have had some exposure to the Fourier transform. If not, it
is OK to ignore this statement.
2.16
Figure 2.8: Intensity graphs (left) and images (right) of a vertical step function (top), and of the
same step function smoothed with a Gaussian (middle), and with a pillbox function (bottom).
Gaussian and pillbox have the same support and the same integral.
2.17
two functions g and g 0 of one variable such that
G(x, y) = g(x)g 0 (y) .
For the Gaussian, this is a consequence of the fact that
ex+y = ex ey
which leads to the equality
G(x, y) = g(x)g(y)
where
g(x) = e 2 ( )
1
(9)
v=n
n
n
X
X
G(v, u)J(r u, c v)
u=n v=n
n
X
g(u) (r u, c)
(11)
g(v)I(r, c v) .
(12)
u=n
where
(r, c) =
n
X
v=n
=
.
4m 2
4m
2
If for instance m = 21, we need only 42 multiplications instead of 441, with an approximately
tenfold increase in speed.
2.18
Exercise. Notice the similarity between () and g(x). Is this a coincidence?
Practical Aspects: Truncation and Normalization. The Gaussian functions in this section were
defined with normalization factors that make the integral of the kernel equal to one, either on
the plane or on the line. This normalization factor must be taken into account when actual
values output by filters are important. For instance, if we want to smooth an image, initially
stored in a file of bytes, one byte per pixel, and write the result to another file with the same
format, the values in the smoothed image should be in the same range as those of the unsmoothed image. Also, when we compute image derivatives, it is sometimes important to
know the actual value of the derivatives, not just a scaled version of them.
However, using the normalization values as given above would not lead to the correct results,
and this is for two reasons. First, we do not want the integral of G(v, u) to be normalized, but
rather its sum, since we define G(v, u) over an integer grid. Second, our grids are invariably
finite, so we want to add up only the values we actually use, as opposed to every value for u, v
between and +.
The solution to this problem is simple. For a smoothing filter we first compute the unscaled
version of, say, the Gaussian in equation (8), and then normalize it by sum of the samples:
1 u2 +v 2
= e 2 2
n
n
X
X
G(j, i)
c =
G(v, u)
(13)
i=n j=n
1
G(v, u) .
c
To verify that this yields the desired normalization, consider an image with constant intensity
u) should yield I0 everywhere as a result. In fact,
I0 . Then its convolution with the new G(v,
we have
n
n
X
X
u)I(r u, c v)
G(v,
J(r, c) =
u)
G(v,
u=n v=n
n
n
X
X
= I0
u)
G(v,
u=n v=n
= I0
as desired.
Of course, normalization can be performed on one-dimensional Gaussian functions separably,
if the two-dimensional Gaussian function is written as the product of two one-dimensional
Gaussian functions. The concept is the same:
g(u)
kg
= e 2 ( )
1
= Pn
1
v=n
g(u)
2.4.1
g(v)
(14)
= kg g(u) .
Image Differentiation
Since images are defined on discrete domains, image differentiation is undefined. To give this
notion some meaning, we think of images as sampled versions of continuous7 distributions of
7
Continuous here refers to the domain: we are talking about functions of real valued variables.
2.19
brightness. This indeed they are: the distribution of intensities on the sensor is continuous, and we
saw in the Section on image formation that the sensor integrates this distribution over the active
area of each pixel and then samples the result at the pixel locations.
Differentiating an image means to compute the samples of the derivative of the continuous distribution of brightness values on the sensor surface.
Thus, differentiation involves, at least conceptually, undoing sampling (that is, computing a
continuous image from a discrete one), differentiating, and sampling again. The process of undoing
sampling is called interpolation. Figure 2.9 shows a conceptual bloc diagram for the computation
of the image derivative in the x (or c) direction.
I(r, c)
C(x, y)
D(x, y)
Ic(r, c)
Figure 2.9: Conceptual bloc diagram for the computation of the derivative of image I(r, c) in the
horizontal (c) direction. The first block interpolates from a discrete to a continuous domain. The
second computes the partial derivative in the horizontal (x) direction. The third block samples
from a continuous domain back to a discrete one.
Interpolation can be expressed as a hybrid-domain convolution, that is a convolution of a discrete image with a continuous kernel. This is formally analogous to a discrete convolution, but has
a very different meaning:8
C(x, y) =
X
X
I(i, j)P (x j, y i)
i= j=
where x, y are real variables and P (x, y) is called the interpolation kernel.
This hybrid convolution seems hard to implement: how can we even represent the output, a
function of two real variables, on a computer? However, the chain of the three operations depicted
in Figure 2.9 goes from discrete-domain to discrete-domain. As we now show, this chain can be
implemented easily and without reference to continuous-domain variables.
Since both interpolation and differentiation are linear, instead of interpolating the image and
then differentiating we can interpolate the image with the derivative of the interpolation function.
8
For simplicity, we assume that the x and y axes have the same origin and direction as the j and i axes: to the right
and down, respectively.
2.20
Formally,
X X
C
(x, y) =
I(i, j)P (x j, y i)
D(x, y) =
x
x i= j=
X
X
I(i, j)Px (x j, y i)
i= j=
where
Px (x, y) =
P
(x, y)
x
X
X
I(i, j)Px (c j, r i) .
i= j=
Note that all continuous variables have disappeared from this expression: this is a standard, discretedomain convolution, so we can implement this on a computer without difficulty.
The correct choice for the interpolation function P (x, y) is outside the scope of this course,
but it turns out that the truncated Gaussian function is adequate, as it smooths the data while
differentiating. We therefore let P be the (unnormalized) Gaussian function of two continuous
variables x and y:
P (x, y) = G(x, y)
and Px , Py its partial derivatives with respect to x and y (Figure 2.10). We then sample Px and Py
over a suitable interval [n, n] of the integers and normalize them by requiring that their response
to a ramp yield the slope of the ramp itself. A unit-slope, discrete ramp in the j direction is
represented by
u(i, j) = j
and we want to find a constant u0 such that
u0
n
n
X
X
u(i, j)Px (c j, r i) = 1 .
i=n j=n
and
Py (x, y) = u0 Py (x, y) .
Again, c and r are assumed to have the same origin and orientations as x and y.
2.21
In particular for r = c = 0 we obtain
u0 = Pn
i=n
Pn
j=n
jGx (j, i)
(15)
Since the partial derivative Gx (x, y) of the Gaussian function with respect to x is negative for
positive x, this constant u0 is positive. By symmetry, the same constant normalizes Gy .
Figure 2.10: The partial derivatives of a Gaussian function with respect to x (left) and y (right)
represented by plots (top) and isocontours (bottom). In the isocontour plots, the x variable points
horizontally to the right, and the y variable points vertically down.
Of course, since the two-dimensional Gaussian function is separable, so are its two partial
derivatives:
Ic (r, c) =
n
n
X
X
I(i, j)Gx (c j, r i) =
i=n j=n
n
X
d(c j)
j=n
n
X
I(i, j)g(r i)
i=n
where
d(x) =
dg
x
= 2 g(x)
dx
is the ordinary derivative of the one-dimensional Gaussian function g(x) defined in equation (9).
A similar expression holds for Ir (r, c) (see below).
Thus, the partial derivative of an image in the x direction is computed by convolving with d(x)
and g(y). The partial derivative in the y direction is obtained by convolving with d(y) and g(x). In
2.22
both cases, the order in which the two one-dimensional convolutions are performed is immaterial:
Ic (r, c) =
Ir (r, c) =
n
X
i=n
n
X
g(r i)
d(r i)
i=n
n
X
j=n
n
X
I(i, j)d(c j) =
I(i, j)g(c j) =
j=n
n
X
j=n
n
X
d(c j)
g(c j)
j=n
n
X
i=n
n
X
I(i, j)g(r i)
I(i, j)d(r i) .
i=n
d(u) = ue 2 ( )
1
kd = Pn
v=n vd(v)
d(u)
= kd d(u) .
We can summarize this discussion as follows.
The derivatives Ic (r, c) and Ir (r, c) of an image I(r, c) in the horizontal (to the right) and
vertical (down) direction, respectively, are approximately the samples of the derivative of
the continuous distribution of brightness values on the sensor surface. The images Ic and
Ir can be computed by the following convolutions:
Ic (r, c) =
Ir (r, c) =
n
X
i=n
n
X
i=n
g(r i)
i)
d(r
n
X
j=n
n
X
j) =
I(i, j)d(c
I(i, j)
g (c j) =
j=n
n
X
j=n
n
X
j=n
j)
d(c
g(c j)
n
X
i=n
n
X
I(i, j)
g (r i)
i) .
I(i, j)d(r
i=n
In these expressions,
1
u 2
and kg = Pn
v=n
g(v)
and
2
and kd = Pn
v=n
vd(v)
The constant determines the amount of smoothing performed during differentiation: the
greater , the more smoothing occurs. The integer n is proportional to , so that the effect
of truncating the Gaussian function is independent of .
2.23
2.5
Nonlinear Filters
Equation (1) shows that linear filters combine input pixels in a way that depends only on where a
pixel is in the image, not on its value. In many situations in image processing, on the other hand,
it is useful to take input pixel values in account as well before deciding how to use them in the
output.
For instance, transmission of a digital image over a noisy channel may corrupt the values of
some pixels while leaving others intact. The new value is often very different from the original
value, because noise affects individual bits during transmission. If a high-order bit is changed,
the corresponding pixel value can change dramatically. The resulting noise is called salt-andpepper noise, because it results into a sprinkle of isolated pixels that are much lighter (salt) or
much darker (pepper) than their neighbors. These anomalous values can be detected, and replaced
by some combination of their neighbors. Such a filter would only process anomalous pixels, and
is therefore nonlinear, because whether a pixel is anomalous or not depends on its value, ont its
position in the image. The median filter does this, and is discussed in Section 2.5.1 below.
Another situation in which nonlinear filtering is useful is when noise (with Gaussian statistics
or otherwise) is to be cleaned up without blurring image edges. The standard smoothing filter
discussed in Section 2.4 cannot do this: since the coefficients of linear filters are blind to input
values, smoothing smooths everything equally, including edges. It turns out that the median filter
does well even in this situation. The bilateral filter discussed in Section 2.5.2 can do even better.
Edge detection, described in Section 2.6, is an example of even more strongly nonlinear image
processing. The decision as to whether a pixel belongs to an edge or not is a binary function of the
image and of pixel position, and is therefore nonlinear.
2.5.1
The principle of operation of the median filter is straightforward: replace the value of each pixel
in the input image with the median of the pixel values in a fixed-size window around the pixel. In
contrast, a smoothing filter replaces the pixel with the mean (weighted by the filter point-spread
function) of the values in the window.
Let (r, c) be the image position for which a filter is computing the current value, and let (i, j)
be the position of a pixel within the given window around (r, c). Then the contribution that pixel
(i, j) gives to the output value at (r, c) for a smoothing filter is proportional to I(i, j), and equals
H(r i, c j)I(i, j), where H is the point-spread function. Thus, the smoothing filter is linear.
In contrast, the contribution that pixel (i, j) gives to the output value at (r, c) for a median filter
depends in a nonlinear way on the values of all the pixels in the window. In principle, the output
value at (r, c) can be computed by sorting all the values in the window, and picking the value in the
middle of the sorted sequence as the output. If the number of elements int he window is even, the
tie between the two values in the middle is usually broken by taking the mean of the two elements.
In image processing, the resulting value is rounded, because the mean is not necessarily an integer
while image pixel values usually are.
2.24
Filters as Statistical Estimators The relative merits of mean and median can be understood by
viewing a filter as a statistical estimator of the value of a pixel. Specifically, the pixel values in an
image window (the support of the point-spread function) are a population sample that is used to
estimate the value in the middle of the window under the assumption that the image intensity is an
approximately linear function within the window.
The (arithmetic, i.e., un-weighted) mean is the most efficient estimator of a population, in the
sense that it is the unbiased estimator that has smallest variance. This makes the mean a good
smoother: if the estimate is repeated multiple times, the error committed is on the average as small
as possible with any unbiased estimator. The weighting introduced by a non-constant point-spread
function typically emphasizes pixels that are closer to the window center. This reduces the effects
of the unwarranted assumption of linear image brightness within the window.
The median is less efficient, as its variance is /2 1.57 greater than that of the mean for a
large population sample (window).10 However, the median has an important advantage in terms of
its breakdown point.
The breakdown point of a statistical estimator is the smallest fraction of population sample
points that must be altered to make the estimate arbitrarily poor. For instance, by altering even just
one value, the mean can be changed by an arbitrary amount: with N members in the sample, a
change of x in the value of the mean can be achieved by changing the value of a single member by
N x. So the mean has a breakdown point of 0.
No statistical estimator can have a breakdown point greater than 0.5: if the sample values are
drawn from a population A, but more than half of them are then replaced by drawing them from
a different population B, no estimator can distinguish between a highly corrupted sample from
population A and a moderately corrupted sample from population B.
Interestingly, the median achieves the maximum attainable breakdown point of 0.5: Although
changing even a single value does in general change the value of the median, it cannot do so by
an arbitrary value. Instead, since the median is the middle value of the sorted list of values from
the sample (window), to change the list so that its middle value, say, increases arbitrarily requires
changing at least half of the values to be no less than the new, desired middle value. A similar
reasoning holds if we want to decrease the median instead.
Removal of Salt and Pepper Noise The high breakdown point of the median quantifies its
relative insensitivity to outliers in a sample. For salt-and-pepper noise, for instance, consider the
case in which a grain of salt (i.e., an anomalously bright pixel) is at position (r, c) in the middle
of the current median-filter window. Unless at least half of the pixels in the window are salt
as well, that value will be very different from the median of the values within the window, and it
will not influence the mean at all. The new, filtered pixel value at (r, c) will therefore replace the
bright pixel value with one that is more representative of the majority of the pixel values within the
window. The grain of salt has been removed.
For the same reason the median filter is also a good edge preserving filter. To illustrate in an
idealized situation, suppose that pixel (r, c) is on the dark side of an edge between a bright and a
10
More precisely, for a window with 2n + 1 pixels, the variance of the median is (2n + 1)/4n times greater than
that of the mean.
2.25
dark region in an image, as illustrated in Figure 2.11. Since the center pixel (r, c) is on the dark
side of the edge, most of the pixels in the window are on the dark side as well. Because of this,
the median of the values in the window is one of the dark pixel values. In particular, if the pixel
at (r, c) were a grain of salt-and-pepper noise, then its value would be replaced by another value
from the dark region. Pixels on the light side of the edge cannot influence the median value by
their values, but only by their number (which is in the minority). Because of this, the median filter
preserves edges while it removes salt-and-pepper noise (and other types of noise as well). This is
in contrast with the smoothing filter, which smooths noise and edges in equal measure.
(r, c)
Figure 2.11: Pixel (r, c) is on the dark side of a dark-light edge in the image. The median-filter
window is 5 5 pixels.
Of course, the edge-preserving property of the median filter relies on the majority of the pixels
in the window being on the same side of the edge as the central pixel. This holds for straight edges,
but not necessarily for curved edges and corners.
Exercise. Convince yourself with a small, 5 5 example similar to that in Figure 2.11 that a
median filter eats away at corners.
Figure 2.12 shows the result of applying a median filter to an image corrupted by salt-andpepper noise.
Algorithms Median filtering with small windows (even 3 3 or so) often yields good results.
With increasing sensor resolutions, however, the amount of light that hits a single pixel decreases.
While the size of the filter window necessary to achieve a certain degree of noise cleanup is likely
to remain more or less constant per unit of solid angle, it is likely to increase, as a function of
image resolution, when it is measured in pixels, and therefore in terms of computational complexity. Because of this, the asymptotic complexity of median filtering, which is irrelevant for small
windows, is of some interest.
2.26
(a)
(b)
(c)
(d)
Figure 2.12: (a) An image corrupted by salt-and-pepper noise. (b) Detail in the red box in (a). (c)
The image in (a) filtered with a median filter with a 5 5 pixel window. (d) Detail in the red box
in (c). Note the more rounded corners than in (b).
2.27
Straightforward computer implementation of the definition of the median filter with an n n
window costs O(n2 log n) for sorting. This cost, which is then multiplied by the number of pixels
in the image, grows quite rapidly. However, the median (or any order statistics) of N numbers can
be computed in O(N ) by a selection algorithm [1], thereby bringing the complexity of the median
down to O(n2 ) per image pixel.
A different route for increased efficiency capitalizes on the fixed number of bits per pixel. A
histogram of pixel values has a fixed number of bins, and can be computed in each window in
O(n2 ) time. The median can then be computed from the histogram in constant time, so median
filtering takes O(n2 ) again. In addition, Huang [6] noted that windows for neighboring pixels overlap over n2 2n pixels, and calculation of the histogram can take advantage of this overlap: When
sliding the filter window one pixel to the right, decrease the proper bin counts for the leftmost,
exiting column of the window, and increase them for the rightmost, entering column. This reduces
the complexity to O(n) per image pixel.
Weiss [12] devised an algorithm that is faster both asymptotically and practically by observing
that (i) the window overlap exploited by Huang also occurs vertically and, perhaps more importantly, that (ii) histograms are additive over disjoint regions: if regions A and B do not share pixels,
then hAB = hA + hB , where hX is the histogram of values in region X. This allows building
a hierarchical structure for the maintenance (in O(log n) time and O(n) space) of multiple histograms over image columns, and to compute the required medians in constant time. This results
in an O(log n) (per image pixel) median filtering algorithm.
2.5.2
The bilateral filter [10, 11] offers a more flexible and explicit way to account for the values of the
pixels in the filter window than the median filter does. In the bilateral filter, a closeness function
H accounts for the spatial distance between the windows central pixel (r, c) and a pixel (i, j)
within the window. This is exactly what the point-spread function H does for a smoothing filter.
In addition, the bilateral filter has a similarity function s that measures how similar the values of
two pixels are. While the domain of H is the set of image position differences (r i, c j), the
domain of s is the set of pixel value differences I(r, c) I(i, j).
The bilateral filter combines closeness and similarity in a multiplicative fashion to determine
the contribution of the pixel at (i, j) to the value resulting at (r, c):
P
(i,j)W (r,c) I(i, j) H(r i, c j) s(I(r, c) I(i, j))
P
(16)
J(r, c) =
(i,j)W (r,c) H(r i, c j) s(I(r, c) I(i, j))
where W (r, c) is the customary fixed-size window centered at (r, c). As usual, the denominator
ensures proper normalization of the output: for a constant image, I(i, j) = I0 for all (i, j), the
output is unaltered: J(r, c) = I0 for all (r, c). In a typical implementation, both closeness H and
similarity s are truncated Gaussian functions with different spread parameters H and s .
The main property of the bilateral filter is that it preserves edges while smoothing away image
noise and smaller variations of image intensity. Edges are preserved because pixels (i, j) that are
across an edge from the output pixel position (r, c) have a dissimilar intensity, and the similarity
2.28
term s(I(r, c) I(i, j)) is correspondingly small. In contrast with the median filter, this effect
depends on the difference in the values of the two pixels, rather than on the number of pixels on
either side of the edge. As a consequence, the bilateral filter does not eat away at corners.
In addition, it can be shown formally [11] that the similarity term of the filter has the effect of
narrowing the modes of the histogram of image intensities, that is, to reduce the number of distinct
pixel values in an image. Informally, this effect is a consequence of the smoothing property of the
bilateral filter for groups of mutually close pixels that have similar values.
However, the bilateral filter does not remove salt and pepper noise: when a grain of noise is
at the output position (r, c), the similarity term s(I(r, c) I(i, j)) is very small for all other pixels,
and the value I(r, c) is copied essentially unaltered in the output J(r, c).
Figure 2.13 illustrates the effects of the bilateral filter on an image with rich texture.
(a)
(b)
Figure 2.13: (a) Image of a kitten. (b) The image in (a) filtered with a bilateral filter with closeness
spread H = 3 pixels and similarity spread s = 30 gray levels. Images are from [11].
All edges around the head of the kitten are faithfully preserved, because intensity differences
across these edges are strong. This also holds for the whiskers, eyes, nose, and mouth, and for the
glint in the kittens eyes. On the other hand, much of the texture of the kittens fur has been wiped
out by the filter, because intensity differences between different points on the fur are smaller.
The similarity function s of the bilateral filter can be defined in different ways depending on
the application. This allows applying the filter to images in which each pixel is a vector of values,
rather than a single value. The main example for this is the filtering of color images. Inherently
scalar filters such as the median filter (which requires a total ordering of the pixel values) are
2.29
sometimes applied to vector images by applying the filter to each vector component separately (for
instance, to the red, green, blue color bands). This has often undesired effects along edges, because
smoothing alters the balance of the color components, and therefore changes the hue of the colors.
In contrast, the bilateral filter can use any desired color similarity s, including functions derived
from a psychophysical study of how humans perceive color differences, thereby making sure that
colors are handled correctly everywhere. [11]
The nonlinear nature of the bilateral filter disrupts separability (discussed earlier in Section
2.4). Direct implementation of the filter after its definition is therefore rather slow. However, the
methods cited earlier to speed up the median filter are applicable to the bilateral filter as well, and
result in fast implementations. [12]
2.6
Edge Detection
The goal of edge detection is to compute (possibly open) curves in the image that are characterized
by a comparatively strong change of image intensity across them. Change of image intensity is
usually measured by the magnitude of the image gradient, defined in Section 2.6.1. Different notions of strength lead to different edge detectors. The most widely used was developed by Canny
in his master thesis[3] together with a general, formal framework for edge detection. Cannys edge
detector is described in Section 2.6.2. Section 2.6.3 discusses the notion of the scale at which an
edge occurs, that is, the width of a band around the edge in which intensity changes from darker to
brighter.
2.6.1
Image Gradient
We saw in Section 2.4.1 how to compute the partial derivatives of image intensity I anywhere in
the image. In that Section, we had identified the x axis with the c (column) axis, and the y axis
with the r (row) axis. To avoid confusion, now that we have settled the image processing aspects,
we can revert to a more standard notation. Specifically, the x and y axes follow the computer
graphics convention: x is horizontal and to the right, while y is vertical and up, with the origin of
the reference frame at the center of the pixel at the bottom left corner of the image, which is now
the point (0, 0). If R is the number of rows in the image, the new image function I in terms of the
old one, I (old) , is given by the following change of variables:
I(x, y) = I (old) (R r, c) .
Note that the first argument x of I is in the horizontal direction, while the first argument of I (old)
used to be in the vertical direction. Similarly, for the partial derivatives we have
I
I
Ix (x, y) =
(x, y) = Ix(old) (R r, c) and Iy (x, y) =
(x, y) = Iy(old) (R r, c) .
x
y
(old)
The minus sign before Iy (Rr, c) is a consequence of the reversal in the direction of the vertical
axis.
A value of Ix and one of Iy can be computed at every image position11 (x, y), and these values
11
2.30
can be collected into two images. Two sample images are shown in Figure 2.14 (c) and (d).
A different view of a detail of these two images is shown in Figure 2.15 in the form of a quiver
diagram. For each pixel (x, y), this diagram shows a vector with components Ix (x, y) and Iy (x, y).
The diagram is shown only for a detail of the eye in Figure 2.14 to make the vectors visible.
The two components Ix (x, y) and Iy (x, y) considered together as a vector at each pixel form
the gradient of the image,
g(x, y) = (Ix (x, y), Iy (x, y))T .
The gradient vector at pixel (x, y) points in the direction of greatest change in I, from darker to
lighter. The magnitude
q
g(x, y) = kg(x, y)k = Ix2 (x, y) + Iy2 (x, y)
of the gradient is the local amount of change in the direction of the gradient, measured in gray
levels per pixel. The (total) derivative of image intensity I along a given direction with unit vector
u is the rate of change of I in the direction of u = (u, v). This can be computed from the gradient
by noticing that the coordinates p = (x, y)T of a point on the line through p0 = (x0 , y0 )T and
along u are
x = x0 + tu
p = p0 + tu that is,
,
y = y0 + tv
so that the chain rule for differentiation yields
I x
I y
dI
=
+
= Ix u + Iy v .
dt
x t
y t
In other words, the derivative of I in the direction of the unit vector u is the projection of the
gradient onto u:
dI
= gT u .
(17)
dt
2.6.2
In a nutshell, Cannys edge detector computes the magnitude of the gradient everywhere in the
image, finds ridges of this function, and preserves ridges that have a high enough value. The
magnitude of the gradient measures local change of image brightness in the direction of maximum
change. Ridges of the magnitude g are points where g achieves a local maximum in the direction
of g, and are therefore inflection points of the image intensity function I. High-valued ridges are
likely to correspond to inflection points of the signal. In contrast, low-valued ridges have some
likelihood of being caused by noise, and are therefore suppressed. This suppresses noise, but also
edges with low contrast.
Ridge detection and thresholding are discussed in more detail next.
2.31
(a)
(b)
(c)
(d)
Figure 2.14: (a) Image of an eye. See Figure 2.15 for a different view of the detail in the box.
(b) The gradient magnitude of the image in (a). Black is zero, white is large. (c), (d) The partial
derivatives in the horizontal (c) and vertical (d) direction. Gray is zero, black is large negative,
white is large positive. Recall that a positive value of y is upwards.
2.32
Figure 2.15: Quiver diagram of the gradient in the detail from the box of Figure 2.14 (a). Note
the long arrows pointing towards the bright glint in the eye, and those pointing from the pupil and
from the eyelid towards the eye white.
2.33
g
(x, y)
(a)
(b)
g
(x, y)
(c)
Figure 2.16: (a) An image of the letter C. (b) Plot of the image intensity function. The curve
of inflection is marked in blue. (c) Magnitude of the gradient of the function in (b). The ridge is
marked in blue, and corresponds to the curve of inflection in (b).
Ridge Detection. The gradient vector g(x, y) encodes both the direction of greatest change and
the rate of change in that direction. Consider a small image patch around the lower tip of the letter
C in Figure 2.16(a).
The image intensity function from this detail is shown in Figure 2.16(b). The blue curve in
this Figure is the curve of inflection of the intensity function, that is, the curve where the function
changes from convex to concave. When walking along the gradient g, the derivative along g at
a point (x, y) on the curve of inflection reaches a maximum, and then starts decreasing. Thus,
the gradient magnitude reaches a maximum at points on the inflection curve when walking in the
direction of the gradient.
Figure 2.16(c) shows a plot of the magnitude g(x, y) of the gradient of the image function
I(x, y) in Figure 2.16(b). The blue curve in (c) is the ridge of the magnitude of the gradient, and
corresponds to the curve of inflection (blue curve) in (b).
Algorithmically, ridge points of the gradient magnitude function g(x, y) can be found as follows. For each pixel position q = (x, y) determine the values of g at the three points
p=qu , q , r=q+u
where
g(x, y)
g(x, y)
is a unit vector along the gradient. Thus, p, q, r are three points just before, at, and just after
the pixel position q when walking through it in the direction of the gradient. The point q is a
ridge point if the gradient magnitude reaches a local maximum at q in that direction, that is, if the
following conditions are satisfied:
u=
(18)
If s(x, y) is the skeleton image, that is, the image of the local maxima thus found, and g(x, y) is
the gradient magnitude image, then edge detection forms the ridge image
r(x, y) = s(x, y) g(x, y)
2.34
which records the value of g at all ridge points, and is zero everywhere else.
Practical Aspects: Issues Related to Image Discretization and Quantization. The direction u
of the gradient magnitude is generally not aligned with the pixel grid. Because of this, the
coordinates of the points p and r are usually not integer. One then determines the values of
g(p) and g(r) by bilinear interpolation. For instance, let p = (xp , yp , and
= bxp c , = byp c
x = xp , y = yp .
Then,
g(p)
=
+
+
+
g(, ) (1 x) (1 y)
g( + 1, ) x (1 y)
g(, + 1) (1 x) y
g( + 1, + 1) x y .
In addition, because of possible quantization in the function values, there may be a plateau
rather than a single ridge point:
g(p) < g(q1 ) = . . . = g(qk ) > g(r) .
In this case the check (18) for a maximum would fail. To address this problem, one can use a
weaker check:
g(p) g(q) and g(q) g(r) .
This check would reveal several ridge point candidates where only one is desired. Rather than
a curve, one then generally finds a ridge region. This region must then be thinned into a curve.
Thinning is a tricky operation if the topology of the original region is to be preserved. A survey
of thinning methods is given in [7]. One of these methods is implemented by the Matlab
function bwmorph called with the thin option.
A simpler thinning method based on the distance transform is presented next. This method
does not necessarily preserve topology, and is described mainly to give the flavor of some of
these methods. The region to be thinned is assumed to be given in the form of a binary image
where a value of 1 denotes pixels in the region, and 0 denotes pixels outside (background).
The distance transform of the image is a new image that for each pixel records the Manhattan
distance12 to the nearest background point. The transform can be computed in two passes in
place over the image [9]. Let I be an image with m rows and n columns. The image contains
binary values initially, as specified above, but is of an unsigned integer type, so that it can
hold the distance transform. Define I(x, y) to be infinity outside the image (or modify the min
operations in the code below so they do not check for values outside the image). A value that
is a sufficiently large proxy for infinity is m + n. The two-pass algorithm is as follows:
for y = 0 to m 1
for x = 0 to n 1
if I(x, y) 6= 0
I(x, y) = min(I(x 1, y) + 1 , I(x, y 1) + 1)
The Manhattan or L1 distance between points (x, y) and (x0 , y 0 ) is |x x0 | + |y y 0 |. Think of streets (x) and
avenues (y) in Manhattan.
12
2.35
end
end
end
for y = m 1 down to 0
for x = n 1 down to 0
I(x, y) = min(I(x, y) , I(x + 1, y) + 1 , I(x, y + 1) + 1)
end
end
Given the result I(x, y) of this algorithm, the skeleton or medial axis of the region defined by
the original binary image is the set of local (four-connected) maxima, that is, the set of points
that satisfy the following predicate:
I(x, y) max(I(x 1, y) , I(x, y 1) , I(x + 1, y) , I(x, y + 1)) .
This region is either one or two pixels thick everywhere.
Figure 2.17 shows the results of this procedure. For edge detection, thinning would have to
preserve the endpoints of the thick edges as well as the topology.
(a)
(b)
(c)
Figure 2.17: (a) A binary image with a thick curve. (b) The distance transform of the image in
(a). (c) The skeleton of the region in (a).
Hysteresis Thresholding Ridges of the gradient magnitude that have a low value are often due
to whatever amount of image noise is left after the smoothing that is implicit in the differentiation
process used to compute the image gradient. Because of this, it is desirable to suppress small ridges
after thinning.
However, use of a single threshold on the ridge values would also shorten strong ridges, since
ridge values tend to taper off at the endpoints of edges. To avoid this, two thresholds can be used
instead, gL and gH , with gL < gH . First, ridge points whose value exceeds the high threshold gH
are declared to be strong edge points:
h(x, y) = r(x, y) gH .
2.36
Second, the binary, weak-edge image
l(x, y) = r(x, y) gL
is formed. The final edge map is the image of all the pixels in l that can be reached from pixels in
e without traversing zero-valued pixels in l.
One way to compute e is to consider the on pixels (pixels with value 1) in l as nodes of a
graph, whose edges are the adjacency relations between pixels (a pixel is adjacent to its north, east,
south, and west neighbors). By construction, the on pixels in h are a subset of those of l. One
can then build a spanning forest for the components of l that contain some pixels of h. The pixels
in this forest form the edge image e. Figure 2.18 shows a simple image, a plot of its intensity,
gradient magnitude, and edge map.
Practical Aspects: Computing the Spanning Forest. As a sample implementation outline, the
following algorithm scans h in raster order. Once it encounters an on pixel at position (x, y),
it uses a stack to traverse pixels in l starting at (x, y) in depth-first order. As it goes, it erases
the pixels it visits in both l (to avoid loops) and h (to avoid revisiting a component), and marks
them in the initially empty image e.
for y = 0 to m 1
for x = 0 to n 1
e(x, y) = 0
end
end
for y = 0 to m 1
for x = 0 to n 1
if h(x, y)
push((x, y))
while the stack is not empty
(x0 , y 0 ) = pop
e(x0 , y 0 ) = 1
h(x0 , y 0 ) = l(x0 , y 0 ) = 0
for all neighbors (x, y) of (x0 , y 0 )
if l(x, y)
push((x, y))
end
end
end
end
end
end
2.6.3
Edge Scale
The gradient measurement step in edge detection computes derivatives by convolving the image
with derivatives of a Gaussian function, as explained in Section 2.4.1. As the parameter of this
2.37
(a)
(b)
(c)
(d)
Figure 2.18: (a) Input image. (b) Plot of the intensity function in (a). (c) The magnitude of the
gradient. (d) Edges found by Cannys edge detector.
(a)
(b)
(c)
Figure 2.19: (a) An image from [4] that exhibits edges at different scales. (b) Edges detected with
= 1 pixel. (c) Edges detected with = 20 pixels.
2.38
Gaussian is increased, the differentiation operator blurs the image more and more. In addition to
smoothing away noise, the useful part of the image is smoothed as well. This has the effect of
making the edge detector sensitive to edges that occur over different spatial extents, or scales. The
image in Figure 2.19(a) illustrates a situation in which consideration of scale is important.
If is small, the sharp edges around the mannequin are detected, but the fuzzier edges of the
shadow are either missed altogether (if the gradient magnitude is too small) or result in multiple
edges, as shown in Figure 2.19(b). If is large, most of the shadow edges are found, but all edges
are rounded, and multiple sharp edges can be mixed together under the wide differentiation kernel,
with unpredictable results. This is shown in Figure 2.19(c).
These considerations suggest detecting edges with differentiation operators at multiple scales
(values of ), and to define the correct edge at position (x, y) to be the edge detected with
the value (x, y) of the scale parameter that yields the strongest edge. The definition of edge
strength relies naturally on the value g(x, y) of the magnitude of the gradient. However, since g
has the dimensions of gray levels per pixel, it has been proposed [8, 5] to measure strength with
the quantity
S(x, y) = (x, y)g(x, y)
which is dimensionless, and therefore more appropriate to compare strengths measured at different scales. Specific definitions, methods, and algorithms that embody this notion of scale space
analysis can be found in the references above.
References
[1] M. Blum, R. W. Floyd, V. Pratt, R. Rivest, and R. Tarjan. Time bounds for selection. Journal
of Computer and System Sciences, 7:448461, 1973.
[2] R. N. Bracewell. Two-Dimensional Imaging. Prentice-Hall, Englewood Cliffs, NJ, 1995.
[3] J. Canny. A computational approach to edge detection. IEEE Transactions on Pattern Analysis and Machine Intelligence, PAMI-8(6):679698, November 1986.
[4] J. H. Elder and S. W. Zucker. Local scale control for edge detection and blur estimation.
IEEE Transactions on Pattern Analysis and Machine Intelligence, 20(7):699716, 1998.
[5] L. M. J. Florack and A. Kuijper. The topological structure of scale-space images. Journal of
Mathematical Imaging and Vision, 12:6579, 2000.
[6] T. S. Huang. Two-Dimensional Signal Processing II: Transforms and Median Filters.
Springer-Verlag, New York, NY, 1981.
[7] L. Lam, S.-W. Lee, and C. Y. Suen. Thinning methodologies a comprehensive survey. IEEE
Transactions on Pattern Analysis and Machine Intelligence, 14(9), September 1992.
[8] T. Lindeberg. Feature detection with automatic scale selection. International Journal on
Computer Vision, 30(2):79116, 1998.
2.39
[9] A. Rosenfeld and J. L. Pfaltz. Sequential operations in digital picture processing. Journal of
the ACM, 13(4):471494, 1966.
[10] S. M. Smith and J. M. Brady. Susana new approach to low level image processing. International Journal of Computer Vision, 23(1):4578, 1997.
[11] C. Tomasi and R. Manduchi. Bilateral filtering for gray and color images. In Proceedings
of the Sixth International Conference on Computer Vision (ICCV), pages 839846, Bombay,
India, January 1998.
[12] B. Weiss. Fast median and bilateral filtering. In SIGGRAPH 06: ACM SIGGRAPH 2006
Papers, pages 519526, New York, NY, 2006. ACM Press.