how to enhance a color image ?
Show older comments
For gray image, we use the commands like adapthisteq, imadjust... How to increase the intensity for the color image.
Answers (1)
Image Analyst
on 22 Aug 2012
0 votes
Convert to hsv color space with rgb2hsv(). Then do those same things on the v channel, then transform back to rgb color space with hsv2rgb().
6 Comments
Sivakumaran Chandrasekaran
on 22 Aug 2012
Sivakumaran Chandrasekaran
on 22 Aug 2012
Jürgen
on 22 Aug 2012
Siva,
take a look at http://en.wikipedia.org/wiki/HSL_and_HSV HSV is a colorspace like rgb , you have three channel , insted of R, G and B, you have H, S and V, a possibility is also to transform to gray scale regardsJ
Image Analyst
on 22 Aug 2012
Your v is the full 3D image with all the h, s, and v channels. Do this:
hsvImage = rgb2hsv(rgbImage);
% Extract individual color channels.
hChannel = hsvImage(:, :, 1);
sChannel = hsvImage(:, :, 2);
vChannel = hsvImage(:, :, 3);
% Do stuff to the v channel.
% Then, after that recombine the new v channel
% with the old, original h and s channels.
hsvImage2 = cat(3, hChannel, sChannel, vChannel);
% Convert back to rgb.
rgbImage2 = hsv2rgb(hsvImage2);
Sivakumaran Chandrasekaran
on 22 Aug 2012
FWIW, the synopsis for adapthisteq() has had an example of doing this in LAB. That said, it's written around very old conventions, so it can be simplified in contemporary versions. For comparison:
% inputs
inpict = imread('peppers.png');
cl = 0.005;
% adjust V in HSV
hsvpict = rgb2hsv(inpict);
hsvpict(:,:,3) = adapthisteq(hsvpict(:,:,3),'cliplimit',cl); % adjust
op1 = im2uint8(hsv2rgb(hsvpict));
% adjust L in LAB
labpict = rgb2lab(inpict);
labpict(:,:,1) = adapthisteq(labpict(:,:,1)/100,'cliplimit',cl)*100; % adjust
op2 = im2uint8(lab2rgb(labpict));
% display as a montage
outpict = [inpict; op1; op2];
imshow(outpict,'border','tight')

... either way, it might not look so great.
For what it's worth, MIMT has a convenience tool for applying histeq() and adapthisteq() to color images. It's simple to use, preserves the numeric class, and does not require IPT.
% inputs
inpict = imread('peppers.png');
cl = 0.005;
% CLAHE in RGB
op1 = histeqtool(inpict,'ahisteqrgb','cliplimit',cl);
% CLAHE on L in LCHab
op2 = histeqtool(inpict,'ahisteqlchab','cliplimit',cl);
% display as a montage
outpict = [inpict; op1; op2];
imshow(outpict,'border','tight')

Note the differences between the LCHab result using histeqtool() and that achieved using the prior approach using rgb2lab() (e.g. the yellow pepper and other regions near primary/secondary corners of the RGB cube). By default, histeqtool() does chroma truncation prior to conversion back to RGB. That prevents out-of-gamut colors from having their L and H altered when they move back to the gamut boundary. Consequently, the histogram equalization of L is actually preserved, whereas in the IPT-only approach, the histogram equalization of L is not preseved.
Categories
Find more on Contrast Adjustment in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!