Histogram and normalization

The histogram is of essential importance in terms of characterizing the global appearance of a given image, such as the brightness and contrast of the image. Specifically, the histogram $h[i]$ ( $i=0,\cdots,255)$ is the probability of an arbitrary pixel taking the gray level $i$, which can be approximated as:

$\displaystyle h[i]=\frac{\mbox{Number of pixels of gray level $i$}}{\mbox{Total number of pixels}}$ (15)

The cumulative density function is defined as:

$\displaystyle H[j]=\sum_{i=0}^j h[i],\;\;\;\;\;(j=0,1,\cdots,255)$ (16)

Obviously $H[255]=1$.

Here is the code for finding the histogram of a given image img of $glevel=256$ gray levels (an 8-bit image)and of size $M\times N$:

for (k=0; k < glevel; k++)
    H[k]=h[k]=0;
for (i=0; i<M; i++)
    for (j=0; j<N; j++) {
        k=img[i][j];
        h[k]=h[k]+1;
    }
H[0]=h[0]=h[0]/M/N;
for (k=1; k < glevel; k++) {
    h[k]=h[k]/M/N;
    H[k]=H[k-1]+h[k];
}

Note that as the density function, the histogram satisfies:

$\displaystyle \sum_{i=0}^{glevel-1} h[i] = H[glevel-1]=1$ (17)

Lenna_256_g.gif Lenna_256_g1.hist

Lenna_256_c.gif Lenna_256_c1.hist

For a gray level image to be properly displayed on screen, its pixel values have to be within a proper range. For an 8-bit digital image there are $2^8=256$ (from 0 to 255) gray levels. However, after applying certain processing operations to the input image, the gray levels of the resulting image are no longer necessarily within the proper range for display. In this case the image needs to be normalized or rescaled:

$\displaystyle y=f(x)=255\;\frac{x-x_{min}}{x_{max}-x_{min}}$ (18)

where $x_{min}$ and $x_{max}$ are, respectively, the minimum and maximum pixel values in the image. The rescaling can be implemented by the following code:

min=LARGE; max=-min;
for (i=0; i<M; i++)
    for (j=0; j<N; j++) {
        if (img[i][j] < min) min=img[i][j];
        if (img[i][j] > max) max=img[i][j];
    }
scale=255.0/(max-min);
for (i=0; i<M; i++)
    for (j=0; j<N; j++) {
        img[i][j]=scale*(img[i][j]-min);
    }
where $LARGE$ is some large number (e.g., the largest floating point number representable in the computer) known to be greater than the highest pixel value.