File Exchange

image thumbnail

Colorspace Transformations

version 1.4 (66.2 KB) by

Transform colors between sRGB, YCbCr, YPbPr, YUV, YIQ, HSV, HSL, HSI, XYZ, Lab, Luv, LCH, CAT02 LMS

13 Ratings



View License

Editor's Note: This file was selected as MATLAB Central Pick of the Week

This package converts colors between sRGB, Y'PbPr, Y'CbCr, JPEG-Y'CbCr, Y'UV, Y'IQ, Y'DbDr, HSV, HSL, HSI, CIE XYZ, CIE L*a*b* (CIELAB), CIE L*u*v* (CIELUV), and CIE L*ch (CIELCH), and CIE CAT02 LMS. It can be used either as part of a C/C++ program or compiled as a MATLAB MEX function.

For use in Matlab, colorspace is compiled as a MEX function by entering

mex colorspace.c

on the Matlab command console. As an alternative to MEX, a pure M-code version colorspace.m is also included.

For use in C programs, an example command line program colorcalc is included.

B = colorspace(S,A) converts the color representation of image A where S is a string specifying the conversion. S tells the source and destination color spaces, S = 'dest<-src', or alternatively, S = 'src->dest'. Supported color spaces are
'RGB' = sRGB IEC 61966-2-1
'YPbPr' = Luma (ITU-R BT.601) + Chroma
'YCbCr' = Luma + Chroma
'JPEG-YCbCr' = space used in JPEG
'YUV' = NTSC PAL Y'UV Luma + Chroma
'YIQ' = NTSC Y'IQ Luma + Chroma
'YDbDr' = SECAM Luma + Chroma
'HSV' or 'HSB' = Hue Saturation Value/Brightness
'HSL' or 'HLS' = Hue Saturation Luminance
'HSI' = Hue Saturation Intensity
'Lab' = CIE L*a*b* (CIELAB)
'Luv' = CIE L*u*v* (CIELUV)

All transforms assume 2 degree observer and D65 illuminant. Color space names are case insensitive. When sRGB is the source or destination, it can be omitted. For example 'yuv<-' is short for 'yuv<-rgb'.

Comments and Ratings (23)


afs_7 (view profile)

The Colorspace Transformations by Pascal Getreuer assume D65/2°, which is a two degree observer angle and a D65 illuminant. However, D65/10° with a ten degree observer is the common standard beside C/2° and D50/2°. The use of D65/2° may conflict with international standards.


KAE (view profile)

colorspace_ciedemo is a nice plot of the CIE1931 diagram with pure colors labeled, which is useful.



Thomas (view profile)

First of all thanks for this excellent contribution.

Checking up the Luv computation i found, that you use the (pre-2004 CIE standard) decimal approximation 0.008856 for some conversions instead of the exact rational 216/24389.
( See here: )

Not a big deal, but changing line 484 to
   i = (Y <= 216/24389)
should be exact. Similarly line 491, i suppose.

(sorry for the accidental double post)


Thomas (view profile)

First of all thanks for this excellent contribution.

Checking up the Luv computation i found, that you use the (pre-2004 CIE standard) decimal approximation 0.008856 for some conversions instead of the exact rational 216/24389.
( See here: )

Not a big deal, but changing line 484 to


Cem (view profile)

Thanks for the contribution. Awesome!

Chad Greene

Chad Greene (view profile)

Excellent. Thanks for sharing.

Royi Avital

Great submission.

Any chance to add CMYK (One of the profiles, SWOP for instance)?

Thank You.


zz (view profile)



DGM (view profile)

Maybe I'm just missing something that would be obvious to someone that knows more about this, but there does not appear to be any implementation of HSI conversion in the M-code. The colorspace string 'hsi' is mapped directly to 'hsl', and certainly both HSL and HSI conversions appear to return the exact same results.
There does appear to be an implementation in the c code, however.
I thought about just writing a function myself, but I rather like the convenience of using colorspace().


John (view profile)

Jan Neggers

awesome tool, I luv colorspaces!


Jurgen (view profile)

eric and x.d, I remember reading something like "the Image Processing Toolbox conversion is based on ICC profiles, and it uses a D65 to D50 Bradford adaptation transformation to the D50 white point." That may explain the differences?


x.d (view profile)

Thanks for your great work!
I have used the function “colorspace( )” which can be found in the page of "" as follows:

rgb = imread('peppers.png');
C = makecform('srgb2lab');
lab = applycform(rgb,C);

lab_2 = colorspace('lab<-rgb', rgb);
lab_3 = lab2uint8(lab_2);

I was surprised that the values in lab and lab_3 were quite different. I want to know the mistake in my code or my logical.

Thanks a lot.


Eric (view profile)

Could you comment on the differences between your function and what comes with the image processing toolbox? Specifically, for the same XYZ values, why do I get different results using colorspace as compared to makecform and applycform? Are there arguments to makecform that would yield results consistent with colorspace? As an example, I have been using Spectral and XYZ Color Functions ( and in the function spectrumRGB I have replaced the makecform and applycform calls with a call to colorspace and comparing the results.


Nathan Orloff

For the same images, this is about 2 times as fast as:

cform = makecform('srgb2lab');
lab_Ia = applycform(Ia,cform);

Which is fantastic.


Yajun (view profile)

thanks very much for your good job,it has been an obstacle for me for a long time

Rob Chambers

Works great, appreciate the MEX code. Far more useful and well-done than matlab's conversions. I've been very impressed with all your stuff, Pascal :)

Matteo Niccoli

I used Colorspace in conjunction with cline
( ) for an example in my Perceptually improved colormaps submission.
I used them this way:

% J=jet(256);
% LJ=colorspace('RGB->Lab',J);
% figure; cline([1:1:256],LJ(:,1),LJ(:,1),[1:1:256],J);
% title ('L* plot for jet colormap','Color','k','FontSize',12);

Also, as I was reading Steve's post on Lab based colormaps (thank you Steve!), I used colorspace to do the transformations as I do not have the Image Processign Toolbox ). This helped me visualize things (notice again I used it togeter with cline):

% radius = 50;
% theta = linspace(0, pi/2, 256).';
% a = radius * cos(theta);
% b = radius * sin(theta);
% L = linspace(0, 100, 256).';
% Lab = [L, a, b];
% RGBhlx=colorspace('RGB<-Lab',(Lab));
% figure; cline(a, b, L, L,RGBhlx); view(3);
% VIEW(-165,-15);

Matteo Niccoli

Thanks for your comments Pascal. I used your 2006 implementation many many times, and I recently used this version for the Perceptually improved colormaps. It worked well for me.

Pascal Getreuer

Pascal Getreuer (view profile)

Thanks, Matteo!

The difference between this package and my previous 2006-2008 Color Space Converter is that colorspace is now implemented in C code. There are two advantages to this. First, colorspace now runs in MATLAB as a MEX function, which is noticeably more efficient than the previous M-code version. Second, colorspace can also be used from normal C and C++ programs---MATLAB is not required to use colorspace.

In case MEX is not an option, a pure M-code version of colorspace is also included (effectively an updated version of the previous colorspace).

Additionally, the sRGB definition of gamma-corrected RGB is now used, and two spaces have been added (HSI and CIE CAT02 LMS).

Matteo Niccoli

Hi Pascal
Great work!

Could you add in here comments/details on the differences between this and the earlier version (2006 Color Space Converter -updated 2008)?

Thank you



added tags, minor update in documentation


* Added missing colorspace.h file---thanks to William Cook
* Added M-code version colorspace.m
* Added JPEG-Y'CbCr
* ITU-R BT.709 gamma correction replaced with more standard sRGB definition
* Fix in Xyz2Luv
* Fix in CIE tongue demo

MATLAB Release
MATLAB 7.5 (R2007b)

Download apps, toolboxes, and other File Exchange content using Add-On Explorer in MATLAB.

» Watch video