Dr. Mohannad K. Sabir Biomedical Engineering Department Fifth Class
Dr. Mohannad K. Sabir Biomedical Engineering Department Fifth Class
Dr. Mohannad K. Sabir Biomedical Engineering Department Fifth Class
Sabir
Biomedical Engineering Department
Fifth Class
3- Histogram Processing
• let rk, for k=0, 1, 2, …., L-1, denote the
intensities of an L- level digital image, f(x, y).
• The unnormalized histogram of f is defined as:
h(rk)= nk for k=0, 1, 2, .., L-1 ---- 1
where nk the number of pixels in f with intensity
rk and the subdivisions of the intensity scale
are called histogram bins.
• Similarly, the normalized histogram of f is defined
as:
p(rk)=h(rk)/MN = nk /MN ----- 2
where, as usual, M and N are the number of image
rows and columns, respectively.
• Mostly, we work with normalized histograms,
which we refer to simply as histograms or image
histograms.
• The sum of p(rk) for all values of k is always 1.
• The components of p(rk) are estimates of the
probabilities of intensity levels occurring in an
image.
We note in the dark
image that the most
populated histogram
Pr(rk)=nk/MN ----- 5
• where MN is the total number of pixels in the image, and nk denotes
the number of pixels that have intensity rk. As noted in the
beginning of this section, Pr(rk), with rk ϵ [0, L-1] is commonly
referred to as a normalized image histogram.
• The discrete transformation function of particular importance in
image processing is
k
sk=T(rk) =(L-1) ∑ pr(rj) k=0, 1, 2, … L-1 ----- 6
j=0
where, as before, L is the number of possible
intensity levels in the image (e.g., 256 for an 8-bit
image).
• Thus, a processed (output) image is obtained by
using Eq. 6 to map each pixel in the input image
with intensity rk into a corresponding pixel with
level sk in the output image.
• This is called a histogram equalization or
histogram linearization transformation.
• It is not difficult to show that this transformation
satisfies conditions (a) and (b) stated previously.
Example1: Illustration of the
mechanics of histogram
equalization.
• Suppose that a 3-bit image
(L=8) of size 64x64 pixels
(MN=4096) has the intensity
distribution in Table where
the intensity levels are
integers in the range [0,L-
1]=[0,7]. The histogram of this
image is sketched in Fig.
Values of the histogram
equalization transformation
function are obtained using
Eq.6, For instance
0
s0=T(r0)=7 ∑ pr(rj)= 7pr(r0)=1.33
j=0
Original histogram
• These are the values of the equalized
histogram. Observe that the transformation
yielded only five distinct intensity levels.
Because r0=0, was mapped to s0=1, there are
790 pixels in the histogram equalized image
with this value. Also, there are 1023 pixels
with a value of s1=3 and 850 pixels with a
value of s2=5. However, both r3 and r4 were Transformation function
mapped to the same value, 6, so there are
(656+329)=985 pixels in the equalized image
with this value. Similarly, there are
(245+122+81)=448 pixels with a value of 7 in
the histogram equalized image. Dividing
these numbers by MN=4096 yielded the
equalized histogram Equalized histogram.
• The method just derived produces intensities that
have this tendency, and also has the advantage
that it is fully automatic. In other words, the
process of histogram equalization consists
entirely of implementing Eq. 6, which is based on
information that can be extracted directly from a
given image, without the need for any parameter
specifications. This automatic, “hands-off”
characteristic is important.
• The inverse transformation from s back to r is
denoted by
rk = T−1(sk) ------ 7
• It can be shown that this inverse
transformation satisfies conditions (a′) and (b)
defined earlier only if all are present in the
input image. This implies that none of the
bins of the image histogram are empty.
Although the inverse transformation is not
used in histogram equalization, it plays a
central role in the histogram-matching scheme
developed after the following example.
Example 2 Histogram
equalization.
• The left column in Fig.
shows the four previous
images the center column
shows the result of
performing histogram
equalization on each of
these images. The first
three results from top to
bottom show significant
improvement. As expected,
histogram equalization did
not have much effect on
the fourth image because
its intensities span almost
the full scale already.
Figure below shows the
transformation functions
used to generate the
equalized images in Fig. .
These functions were
generated using Eq. 6.
Observe that
transformation (4) is nearly
linear, indicating that the
inputs were mapped to
nearly equal outputs.
3-2 Histogram Matching (Specification)
• As explained in the last section, histogram equalization produces a
transformation function that seeks to generate an output image
with a uniform histogram.
• When automatic enhancement is desired, this is a good approach
to consider because the results from this technique are predictable
and the method is simple to implement.
• However, there are applications in which histogram equalization is
not suitable. In particular, it is useful sometimes to be able to
specify the shape of the histogram that we wish the processed
image to have.
• The method used to generate images that have a specified
histogram is called histogram matching or histogram specification.
• The discrete formulation is the histogram
equalization transformation, which we repeat
here for convenience:
k
• As in Example 1 ,
these fractional
Specified and actual histograms
values are rounded to
integers in the range
[0, 7]:
• These results are summarized in Table TABLE 4
3.
• The transformation function, G(zq)is
sketched in Fig
• Because its first three values are
equal, G is not strictly monotonic, so
condition (a′) is violated.
• Therefore, we use the approach
outlined in Step 3 of the algorithm to
handle this situation.
• According to this step, we find the
smallest value of zq so that the value
G(zq) is the closest to sq.
• We do this for every value of sq to
create the required mappings from s
to z.
• For example, s0 =1, and we see that
G(z3) =1, which is a perfect match in
this case, so we have the
correspondence s0 z3
• Every pixel whose value is 1 in the Mapping of values sk into corresponding values zq
histogram equalized image would map
to a pixel valued 3 in the histogram-
specified image.
• Continuing in this manner, we arrive
at the mappings in Table 4.
• In the final step of the
procedure, we use the
mappings in Table 4, to
map every pixel in the
histogram equalized image
into a corresponding pixel
in the newly created
histogram-specified image.
• The values of the resulting
histogram are listed in the
third column of Table 2,
and the histogram is
shown in Fig.
• For instance, we see in obtaining the histogram equalized
Table 4, that maps to and image as an intermediate step is
there are 790 pixels in the useful for explaining the
• histogram-equalized image procedure, but this is not
with a value of 1. necessary. Instead, we could list
• Therefore, pz(z3) = the mappings from the r’s to the
790/4096=0.19. s’s and from the s’s to the z’s in a
three-column table.
An image,
• Then, we would use
those mappings to map
the original pixels its histogram
directly into the pixels of
the histogram-specified
image.
• Example 3 Comparison
between histogram
equalization and
histogram specification
Histogram of equalized image
• histogram
specification
• The most Specified histogram
distinguishing
feature of this
histogram is
how its low
end has
histogram specification.
specification image
lighter region
of the gray
scale
4- Local Histogram Processing
• The histogram processing methods discussed thus far
are global, in the sense that pixels are modified by a
transformation function based on the intensity
distribution of an entire image.
• This global approach is suitable for overall
enhancement, but generally fails when the objective is
to enhance details over small areas in an image.
• This is because the number of pixels in small areas
have negligible influence on the computation of global
transformations. The solution is to devise
transformation functions based on the intensity
distribution of pixel neighborhoods.
• The histogram processing techniques previously described can be adapted
to local enhancement.
• The procedure is to define a neighborhood and move its center from pixel
to pixel in a horizontal or vertical direction.
• At each location, the histogram of the points in the neighborhood is
computed, and either a histogram equalization or histogram specification
transformation function is obtained. This function is used to map the
intensity of the pixel centered in the neighborhood.
• The center of the neighborhood is then moved to an adjacent pixel
location and the procedure is repeated. Because only one row or column
of the neighborhood changes in a one-pixel translation of the
neighborhood, updating the histogram obtained in the previous location
with the new data introduced at each motion step is possible.
• Another approach used sometimes to reduce computation is to utilize non
overlapping regions, but this method usually produces an undesirable
“blocky” effect.
Example 4: Local histogram equalization.
• Figure (a) is an 8-bit, 512x512 image
consisting of five black squares on a light gray
background. The image is slightly noisy, but the
noise is imperceptible.
• There are objects embedded in the dark
squares, but they are invisible for all practical
purposes. Original image
• Figure (b) is the result of global
histogram equalization
Result of global
equalization
• As is often the case with histogram equalization
histogram
of smooth, noisy regions, this image shows
significant enhancement of the noise.
• Figure (c) was obtained using local
histogram equalization of Fig. (a) with a
neighborhood of size 3x3.
• Here, we see significant detail within all the
Result of local
dark squares. The intensity values of these
equalization
histogram
objects are too close to the intensity of the dark
squares, and their sizes are too small, to
influence global histogram equalization
significantly enough to show this level of
intensity detail.
4-1 Using Histogram Statistics for Image
Enhancement
• Statistics obtained directly from an image
histogram can be used for image enhancement.
• Let r denote a discrete random variable
representing intensity values in the range [0,L-1],
and let p(ri) denote the normalized histogram
component corresponding to intensity value ri.
• we may view as an estimate of the probability
that intensity ri occurs in the image from which
the histogram was obtained.
• The nth moment of r about its mean, m, which
we write here using image intensity values in
the range [0,L-1]:
L-1
μn=∑ (ri-m)n p(ri) ------ (10)
i=0
• where m is given by
L-1
m= ∑ ri p(ri) ------- (11)
i=0
• The mean is a measure of average intensity and the
variance,
L-1
σ2= μ2 = ∑ (ri-m)2 p(ri) ------ (12)
i =0
• Standard deviation, σ is a measure of image
contrast.
• Let (x, y) denote the coordinates of any pixel in a
given image, and let Sxy denote a neighborhood of
specified size, centered on (x, y). The mean value of
the pixels in this neighborhood is given by the
expression L-1
m Sxy = ∑ p Sxy( ri) ----- (13)
i =0
• Where p Sxy is the histogram of the pixels in region Sxy .
• This histogram has L bins, corresponding to the L
possible intensity values in the input image. However,
many of the bins will have 0 counts, depending on the
size of Sxy .
• For example, if the neighborhood is of size 3x3 and
L=256, only between 1 and 9 of the 256 bins of the
histogram of the neighborhood will be nonzero (the
maximum number of possible different intensities in a
3x3 region is 9, and the minimum is 1). These non-zero
values will correspond to the number of different
intensities in Sxy .
• The variance of the pixels in the neighborhood
is similarly given by:
L-1
σ2 Sxy = ∑ (ri - m Sxy)2 p Sxy( ri) ----- (14)
i=0
• As before, the local mean is a measure of
average intensity in neighborhood Sxy , and
the local variance (or standard deviation) is a
measure of intensity contrast in that
neighborhood.
Example 4: Local enhancement using histogram
statistics.
• The previous image which we enhanced
using local histogram equalization. As noted
before, the dark squares contain embedded
symbols that are almost invisible. As before,
we want to enhance the image to bring out
these hidden features.
• A method used to determine whether an
area is relatively light or dark at a point (x, y)
is to compare the average local intensity
mSxy, to the average image intensity (the
global mean), denoted by mG.
• We obtain mG with the histogram of the
entire image.
• Thus, we have the first element of our
enhancement scheme: We will consider the
pixel at (x, y) as a candidate for processing if
k0 mG ≤ m Sxy ≤ k1 mG , where k0 and k1 are
nonnegative constants and k0 < k1.
• For example, if our focus is on areas that are
darker than one-quarter of the mean
intensity, we would choose k0 =0 and k1
=0.25.
• We summarize the preceding approach as follows. Let
f(x, y) denote the value of an image at any image
coordinates (x, y), and let g(x, y) be the corresponding
value in the enhanced image at those coordinates. Then,
C f(x,y) if k0 mG ≤ m Sxy ≤ k1 mG AND k0 σG ≤ σ Sxy ≤ k1 σG
g(x,y)=
f(x,y) otherwise ------- ( 15)
• for x=0, 1, 2, …., M-1 and y=0, 1, 2, …, N-1, where, as
indicated above, C, k0, k1, k2, and k3 are specified
constants, σG is the global mean of the input image, and
is its standard deviation.
• Parameters m Sxy and σ Sxy are the local mean and
standard deviation, respectively, which change for every
location (x, y). As usual, M and N are the number of rows
and columns in the input image.
• Factors such as the values of the global mean
and variance relative to values in the areas to
be enhanced play a key role in selecting the
parameters in Eq. (15), as does the range of
differences between the intensities of the
areas to be enhanced and their background. In
the case of Fig. ( before ), mG = 161, σG =103
the maximum intensity values of the image
and areas to be enhanced are 228 and 10,
respectively, and the minimum values are 0 in
both cases.