Histogram#

Definition#

The histogram (French: histogramme) may be the simplest tool for image processing; it can be seen on cameras and even some smartphones, when shooting. It depicts how the intensities of the pixels are distributed. It is the discrete function h such that

h(i)=ni

where ni is the number of pixels with intensity i.

The code below shows an image and two associated histograms. The histograms are displayed as a bar plot, constituted as a set of bins. The number (hence the width) of the bins are chosen by the user; in the example below, we choose 128 bins and 16 bins. Both histograms lie on [0,255] which are the intensity range of the image.

import numpy as np
import skimage.io as io
import matplotlib.pyplot as plt

# Load the image
img = io.imread("../_static/figs/daisy.png", as_gray=True) * 255

# Display the image
fig, ax = plt.subplots(1, 1, figsize=(5,5))
ax.imshow(img, cmap="gray")
plt.show()

# Prepare the figure for the histograms
fig, axs = plt.subplots(1, 2, figsize=(12,4))

# Plot the first histogram
axs[0].hist(
    img.ravel(),           # The image must be flattened to use function hist
    bins=range(0,256,2)    # Define 128 bins (of width 2) between 0 and 255
)
axs[0].set_xlabel("Intensities")
axs[0].set_ylabel("Number")

# Plot the second histogram
axs[1].hist(
    img.ravel(),           # The image must be flattened to use function hist
    bins=range(0,256,16)   # Define 16 bins (of width 16) between 0 and 255
)
axs[1].set_xlabel("Intensities")
axs[1].set_ylabel("Number")

# Show the figure
plt.show()
../_images/a71faec081a5b3a66e262a992606be798ec057860fc85b0bfed0f9b40f250686.png ../_images/addd3f0cb0d1aadda11010f06ab9e65da26b06cfc033655da05ca7bb728318ec.png

We distinguish two “modes” on the histogram. The one on the left (intensities around 75) corresponds to the dark tones in the image (mainly the background). The one on the right (intensities around 180) corresponds to the light tones (the petals and the center).

Some remarks#

  • If the histogram h is normalized (i.e. the bins are divided by the pixel number M×N), then it can be seen as a discrete probability density function p:

    p(i)=niM×N
  • The histogram gives a global information about the pixel intensities of an image but loses the spatial information in the image. In consequence, two different images can have the same histogram (cf. Fig. 23).

    ../_images/daisy-sorted.svg

    Fig. 23 These two images have the same histogram. The image on the right actually corresponds to the pixels of the image on the left sorted with respect to their gray level.#

Histogram transformations#

A histogram transformation consists of applying a mathematical function to the intensity distribution. Generally, the transformations are useful to improve the visual quality of an image, but are rarely needed inside an automatic processing.

The transform, denoted T, is applied to the pixel intensities to change their values:

j=T(i)

where j and i are respectively the intensities of the new and the original image. As a consequence, the histogram of the new image differs from the histogram of the original image.

Below are some common transformations (we assume the pixel intensities to lie in [0,1]).

Negative image#

T(i)=1i
../_images/negative.svg

Fig. 24 Negative image: the gray levels are reversed.#

Gamma correction#

T(i)=iγ
../_images/gamma.svg

Fig. 25 Gamma correction modifies the coulors of an image acquired by an electronic system, it is used to take into account the non-linear sensibility of human eyes to the light. Here, γ=0.4#

Histogram spreading#

(French: étalement d’histogramme)

T(i)=iiminimaximin

where imin and imax are respectively the minimum and maximum intensities in the image.

../_images/spreading.svg

Fig. 26 Histogram spreading enhances the contrast by “dilating” the histogram to the whole intensity interval.#

Histogram equalization#

(French: égalisation d’histogramme)

T(i)=1MNk=0ink

where M and N are the image size and nk is the number of pixels with intensity k. This transformation aims to spread the histogram over the entire intensity range, and to make the histogram as flat as possible. A consequence is an increase of the image contrast. It is a fully automatic method that does not require any parameters to be set. The demonstration of this equation is available in [Gonzalez 2010, section 3.3.1].

../_images/equalization.svg

Fig. 27 Histogram equalization is another contrast enhancing and tends to make the details more visible.#

Thresholding#

The histogram is sometimes very useful to segment the image in two classes, that is to distinguish the objects in the image with respect to their gray level. Indeed, if the histogram shows clearly two modes (i.e. two “bumps”), a threshold T can be defined between these two modes, then apply a thresholding on the pixels, such that:

  • if the pixel level is lower that T, then the pixel is in class 0 (displayed in black in Fig. 28),

  • otherwise, the pixel is in class 1 (displayed in white in Fig. 28).

../_images/thresholding.svg

Fig. 28 Threshold with a threshold set to 0.45.#

Such a thresholding yields a binary image whose pixels have only two values. Several methods exist that compute the threshold automatically, such as Otsu’s method.