Images with low contrast may be enhanced by manipulating its histogram. This post on my blog will show you just that.
(Histogram is a graph showing how many pixels have a particular value, from 0-255, in a grayscale image. This is equal to the probability distribution function or PDF.)
Start with an image that you want to enhance:
(Histogram is a graph showing how many pixels have a particular value, from 0-255, in a grayscale image. This is equal to the probability distribution function or PDF.)
Start with an image that you want to enhance:
Convert this image into grayscale:
data:image/s3,"s3://crabby-images/2b3f0/2b3f06fc8dc917e9f865d24dfc4e1489c14beb21" alt=""
From the obtained histogram, get the CDF(cumulative probability function) using the scilab fuction cumsum():
data:image/s3,"s3://crabby-images/c5b90/c5b9038da9dd25ac87340c93f8428abfed9a6f16" alt=""
By pixel-per-pixel backprojection, the undesired pixels may be replaced with the x-values of the desired CDF. The image below shows the modified image. If compared with the original image, this one is clearer and more resolved.
data:image/s3,"s3://crabby-images/536fe/536fe3d07f471867d9eda450d04d60bd4e4a7a44" alt=""
Other softwares such as photoshop and GIMP allows you to "twick" your image's histogram. As a comparison, I also tried manipulating my original image's histogram in imagej. The results are shown below:
Using imagej:
data:image/s3,"s3://crabby-images/ee664/ee6640f83fca3f2379fac805f94be82d44fb868f" alt=""
CODE:
//reading the image
I = gray_imread('C:\Users\cindyleen\Desktop\DSC03137.jpg');
scf();
//imshow(I);
//PLOTTING THE HISTOGRAM OF THE IMAGE
histplot(256,I);
//TABULATION OF FREQUENCY PER GRAYSCALE VALUE(0-256)
tab = tabul(I, 'i');
x = tab(:,1);
y = tab(:,2)/sum(tab(:,2)); //normalization of frequency
//disp(sum(y))
//scf();
//plot(x, y, '.')
//getting the CDF
ycum = cumsum(y);
scf();
plot(x, ycum) //this is the CDF of your image
//desired CDF(linear)
scf();
plot(x,x)
//BACKPROJECTION
[r c] = size(I);
ix = I(:);
yp = interp1(x,ycum,ix);
xd = interp1(x,x,yp,['spline']);
//displaying the processed image
Inew = matrix(xd, [r c]);
scf();
imshow(Inew);
I would to give my self a grade of 9.5 for this activity. Although I did manage to get all output ask, I'm afraid I wasn't able to explain the method clearly in this blog.
Thank you Joseph for all the help in this activity! :D
//reading the image
I = gray_imread('C:\Users\cindyleen\Desktop\DSC03137.jpg');
scf();
//imshow(I);
//PLOTTING THE HISTOGRAM OF THE IMAGE
histplot(256,I);
//TABULATION OF FREQUENCY PER GRAYSCALE VALUE(0-256)
tab = tabul(I, 'i');
x = tab(:,1);
y = tab(:,2)/sum(tab(:,2)); //normalization of frequency
//disp(sum(y))
//scf();
//plot(x, y, '.')
//getting the CDF
ycum = cumsum(y);
scf();
plot(x, ycum) //this is the CDF of your image
//desired CDF(linear)
scf();
plot(x,x)
//BACKPROJECTION
[r c] = size(I);
ix = I(:);
yp = interp1(x,ycum,ix);
xd = interp1(x,x,yp,['spline']);
//displaying the processed image
Inew = matrix(xd, [r c]);
scf();
imshow(Inew);
I would to give my self a grade of 9.5 for this activity. Although I did manage to get all output ask, I'm afraid I wasn't able to explain the method clearly in this blog.
Thank you Joseph for all the help in this activity! :D
No comments:
Post a Comment