colour

colour — colour operators

Stability Level

Stable, unless otherwise indicated

Synopsis

#include <vips/vips.h>

#define             VIPS_D93_X0
#define             VIPS_D93_Y0
#define             VIPS_D93_Z0
#define             VIPS_D75_X0
#define             VIPS_D75_Y0
#define             VIPS_D75_Z0
#define             VIPS_D65_X0
#define             VIPS_D65_Y0
#define             VIPS_D65_Z0
#define             VIPS_D55_X0
#define             VIPS_D55_Y0
#define             VIPS_D55_Z0
#define             VIPS_D50_X0
#define             VIPS_D50_Y0
#define             VIPS_D50_Z0
#define             VIPS_A_X0
#define             VIPS_A_Y0
#define             VIPS_A_Z0
#define             VIPS_B_X0
#define             VIPS_B_Y0
#define             VIPS_B_Z0
#define             VIPS_C_X0
#define             VIPS_C_Y0
#define             VIPS_C_Z0
#define             VIPS_E_X0
#define             VIPS_E_Y0
#define             VIPS_E_Z0
#define             VIPS_D3250_X0
#define             VIPS_D3250_Y0
#define             VIPS_D3250_Z0
enum                VipsIntent;
gboolean            vips_colourspace_issupported        (const VipsImage *image);
int                 vips_colourspace                    (VipsImage *in,
                                                         VipsImage **out,
                                                         VipsInterpretation space,
                                                         ...);
int                 vips_LabQ2sRGB                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_rad2float                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_float2rad                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_LabS2LabQ                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_LabQ2LabS                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_LabQ2Lab                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_Lab2LabQ                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_LCh2Lab                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_Lab2LCh                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_Yxy2Lab                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_CMC2XYZ                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_Lab2XYZ                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_XYZ2Lab                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_XYZ2scRGB                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_scRGB2sRGB                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_sRGB2scRGB                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_scRGB2XYZ                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_LCh2CMC                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_CMC2LCh                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_XYZ2Yxy                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_Yxy2XYZ                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_LabS2Lab                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_Lab2LabS                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_icc_present                    (void);
int                 vips_icc_transform                  (VipsImage *in,
                                                         VipsImage **out,
                                                         const char *output_profile,
                                                         ...);
int                 vips_icc_import                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_icc_export                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);
int                 vips_icc_ac2rc                      (VipsImage *in,
                                                         VipsImage **out,
                                                         const char *profile_filename);
int                 vips_dE76                           (VipsImage *left,
                                                         VipsImage *right,
                                                         VipsImage **out,
                                                         ...);
int                 vips_dE00                           (VipsImage *left,
                                                         VipsImage *right,
                                                         VipsImage **out,
                                                         ...);
int                 vips_dECMC                          (VipsImage *left,
                                                         VipsImage *right,
                                                         VipsImage **out,
                                                         ...);
void                vips_col_Lab2XYZ                    (float L,
                                                         float a,
                                                         float b,
                                                         float *X,
                                                         float *Y,
                                                         float *Z);
void                vips_col_XYZ2Lab                    (float X,
                                                         float Y,
                                                         float Z,
                                                         float *L,
                                                         float *a,
                                                         float *b);
double              vips_col_ab2h                       (double a,
                                                         double b);
void                vips_col_ab2Ch                      (float a,
                                                         float b,
                                                         float *C,
                                                         float *h);
void                vips_col_Ch2ab                      (float C,
                                                         float h,
                                                         float *a,
                                                         float *b);
float               vips_col_L2Lcmc                     (float L);
float               vips_col_C2Ccmc                     (float C);
float               vips_col_Ch2hcmc                    (float C,
                                                         float h);
void                vips_col_make_tables_CMC            (void);
float               vips_col_Lcmc2L                     (float Lcmc);
float               vips_col_Ccmc2C                     (float Ccmc);
float               vips_col_Chcmc2h                    (float C,
                                                         float hcmc);
int                 vips_col_sRGB2scRGB_8               (int r,
                                                         int g,
                                                         int b,
                                                         float *R,
                                                         float *G,
                                                         float *B);
int                 vips_col_sRGB2scRGB_16              (int r,
                                                         int g,
                                                         int b,
                                                         float *R,
                                                         float *G,
                                                         float *B);
int                 vips_col_scRGB2XYZ                  (float R,
                                                         float G,
                                                         float B,
                                                         float *X,
                                                         float *Y,
                                                         float *Z);
int                 vips_col_XYZ2scRGB                  (float X,
                                                         float Y,
                                                         float Z,
                                                         float *R,
                                                         float *G,
                                                         float *B);
int                 vips_col_scRGB2sRGB_8               (float R,
                                                         float G,
                                                         float B,
                                                         int *r,
                                                         int *g,
                                                         int *b,
                                                         int *or_ret);
int                 vips_col_scRGB2sRGB_16              (float R,
                                                         float G,
                                                         float B,
                                                         int *r,
                                                         int *g,
                                                         int *b,
                                                         int *or_ret);
float               vips_pythagoras                     (float L1,
                                                         float a1,
                                                         float b1,
                                                         float L2,
                                                         float a2,
                                                         float b2);
float               vips_col_dE00                       (float L1,
                                                         float a1,
                                                         float b1,
                                                         float L2,
                                                         float a2,
                                                         float b2);

Description

These operators let you transform coordinates and images between colour spaces, calculate colour differences, and move to and from device spaces.

Radiance images have four 8-bits bands and store 8 bits of R, G and B and another 8 bits of exponent, common to all channels. They are widely used in the HDR imaging community.

The colour functions can be divided into three main groups. First, functions to transform images between the different colour spaces supported by VIPS: RGB, sRGB, XYZ, Yxy, Lab, LabQ, LabS, LCh and CMC). Use vips_colourspace() to move an image to a target colourspace using the best sequence of colour transform operations. Secondly, there are a set of operations for calculating colour difference metrics. Finally, VIPS wraps LittleCMS and uses it to provide a set of operations for reading and writing images with ICC profiles.

This figure shows how the VIPS colour spaces interconvert:

The colour spaces supported by VIPS are:

  • LabQ

    This is the principal VIPS colorimetric storage format. LabQ images have four 8-bit bands and store 10 bits of L and 11 bits of a and b.

    You cannot perform calculations on LabQ images (they are tagged with VIPS_CODING_LABQ), though a few operations such as vips_extract_area() will work directly with them.

  • LabS

    This format represents coordinates in CIELAB space as a three-band VIPS_FORMAT_SHORT image, scaled to fit the full range of bits. It is the best format for computation, being relatively compact, quick, and accurate. Colour values expressed in this way are hard to visualise.

  • Lab

    Lab colourspace represents CIELAB colour values with a three-band VIPS_FORMAT_FLOAT image. This is the simplest format for general work: adding the constant 50 to the L channel, for example, has the expected result.

    VIPS uses D65 LAB, but you can use other colour temperatures with a little effort, see vips_XYZ2Lab().

  • XYZ

    CIE XYZ colour space represented as a three-band VIPS_FORMAT_FLOAT image.

  • Yxy

    CIE Yxy colour space represented as a three-band VIPS_FORMAT_FLOAT image.

  • RGB / sRGB

    VIPS converts XYZ to and from sRGB using the usual formula:

    http://en.wikipedia.org/wiki/SRGB

    You can also use vips_icc_transform() and friends to go to and from device space with a generic profile.

  • LCh

    Like Lab, but rectangular ab coordinates are replaced with polar Ch (Chroma and hue) coordinates. Hue angles are expressed in degrees.

  • CMC

    A colour space based on the CMC(1:1) colour difference measurement. This is a highly uniform colour space, much better than CIELAB for expressing small differences.

    You can calculate metrics like CMC(2:1) by scaling the spaces before finding differences.

Details

VIPS_D93_X0

#define VIPS_D93_X0 (89.7400)

Areas under curves for D93, 2 degree observer.


VIPS_D93_Y0

#define VIPS_D93_Y0 (100.0)


VIPS_D93_Z0

#define VIPS_D93_Z0 (130.7700)


VIPS_D75_X0

#define VIPS_D75_X0 (94.9682)

Areas under curves for D75, 2 degree observer.


VIPS_D75_Y0

#define VIPS_D75_Y0 (100.0)


VIPS_D75_Z0

#define VIPS_D75_Z0 (122.5710)


VIPS_D65_X0

#define VIPS_D65_X0 (95.0470)

Areas under curves for D65, 2 degree observer.


VIPS_D65_Y0

#define VIPS_D65_Y0 (100.0)


VIPS_D65_Z0

#define VIPS_D65_Z0 (108.8827)


VIPS_D55_X0

#define VIPS_D55_X0 (95.6831)

Areas under curves for D55, 2 degree observer.


VIPS_D55_Y0

#define VIPS_D55_Y0 (100.0)


VIPS_D55_Z0

#define VIPS_D55_Z0 (92.0871)


VIPS_D50_X0

#define VIPS_D50_X0 (96.4250)

Areas under curves for D50, 2 degree observer.


VIPS_D50_Y0

#define VIPS_D50_Y0 (100.0)


VIPS_D50_Z0

#define VIPS_D50_Z0 (82.4680)


VIPS_A_X0

#define VIPS_A_X0 (109.8503)

Areas under curves for illuminant A (2856K), 2 degree observer.


VIPS_A_Y0

#define VIPS_A_Y0 (100.0)


VIPS_A_Z0

#define VIPS_A_Z0 (35.5849)


VIPS_B_X0

#define VIPS_B_X0 (99.0720)

Areas under curves for illuminant B (4874K), 2 degree observer.


VIPS_B_Y0

#define VIPS_B_Y0 (100.0)


VIPS_B_Z0

#define VIPS_B_Z0 (85.2230)


VIPS_C_X0

#define VIPS_C_X0 (98.0700)

Areas under curves for illuminant C (6774K), 2 degree observer.


VIPS_C_Y0

#define VIPS_C_Y0 (100.0)


VIPS_C_Z0

#define VIPS_C_Z0 (118.2300)


VIPS_E_X0

#define VIPS_E_X0 (100.0)

Areas under curves for equal energy illuminant E.


VIPS_E_Y0

#define VIPS_E_Y0 (100.0)


VIPS_E_Z0

#define VIPS_E_Z0 (100.0)


VIPS_D3250_X0

#define VIPS_D3250_X0 (105.6590)

Areas under curves for black body at 3250K, 2 degree observer.


VIPS_D3250_Y0

#define VIPS_D3250_Y0 (100.0)


VIPS_D3250_Z0

#define VIPS_D3250_Z0 (45.8501)


enum VipsIntent

typedef enum {
	VIPS_INTENT_PERCEPTUAL = 0,
	VIPS_INTENT_RELATIVE,
	VIPS_INTENT_SATURATION,
	VIPS_INTENT_ABSOLUTE
} VipsIntent;

The rendering intent. VIPS_INTENT_ABSOLUTE is best for scientific work, VIPS_INTENT_RELATIVE is usually best for accurate communication with other imaging libraries.

VIPS_INTENT_PERCEPTUAL

perceptual rendering intent

VIPS_INTENT_RELATIVE

relative colorimetric rendering intent

VIPS_INTENT_SATURATION

saturation rendering intent

VIPS_INTENT_ABSOLUTE

absolute colorimetric rendering intent

vips_colourspace_issupported ()

gboolean            vips_colourspace_issupported        (const VipsImage *image);

Test if image is in a colourspace that vips_colourspace() can process. For example, VIPS_INTERPRETATION_RGB images are not in a well-defined colourspace, but VIPS_INTERPRETATION_sRGB ones are.

Returns :

TRUE if image is in a supported colourspace.

vips_colourspace ()

int                 vips_colourspace                    (VipsImage *in,
                                                         VipsImage **out,
                                                         VipsInterpretation space,
                                                         ...);

This operation looks at the interpretation field of in and runs a set of colourspace conversion functions to move it to space.

For example, given an image tagged as VIPS_INTERPRETATION_YXY, running vips_colourspace() with space set to VIPS_INTERPRETATION_LAB will convert with vips_Yxy2XYZ() and vips_XYZ2Lab().

See also: vips_colourspace_issupported(), vips_image_guess_interpretation().

in :

input image

out :

output image

space :

convert to this colour space

Returns :

0 on success, -1 on error.

vips_LabQ2sRGB ()

int                 vips_LabQ2sRGB                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Unpack a LabQ (VIPS_CODING_LABQ) image to a three-band short image.

See also: vips_LabS2LabQ(), vips_LabQ2sRGB(), vips_rad2float().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_rad2float ()

int                 vips_rad2float                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Unpack a RAD (IM_CODING_RAD) image to a three-band float image.

See also: vips_float2rad(), vips_LabQ2LabS().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_float2rad ()

int                 vips_float2rad                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Convert a three-band float image to Radiance 32-bit packed format.

See also: vips_rad2float(), VipsFormatRad, vips_LabQ2Lab().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_LabS2LabQ ()

int                 vips_LabS2LabQ                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Convert a LabS three-band signed short image to LabQ

See also: vips_LabQ2LabS().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_LabQ2LabS ()

int                 vips_LabQ2LabS                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Unpack a LabQ (IM_CODING_LABQ) image to a three-band short image.

See also: vips_LabS2LabQ(), vips_LabQ2LabS(), vips_rad2float().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_LabQ2Lab ()

int                 vips_LabQ2Lab                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Unpack a LabQ (IM_CODING_LABQ) image to a three-band float image.

See also: vips_LabQ2Lab(), vips_LabQ2LabS(), vips_rad2float().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_Lab2LabQ ()

int                 vips_Lab2LabQ                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Convert a Lab three-band float image to LabQ (IM_CODING_LABQ).

See also: vips_LabQ2Lab().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_LCh2Lab ()

int                 vips_LCh2Lab                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn LCh to Lab.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_Lab2LCh ()

int                 vips_Lab2LCh                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn Lab to LCh.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_Yxy2Lab ()

int                 vips_Yxy2Lab                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);


vips_CMC2XYZ ()

int                 vips_CMC2XYZ                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);


vips_Lab2XYZ ()

int                 vips_Lab2XYZ                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

optional arguments:

temp: colour temperature

Turn Lab to XYZ. The colour temperature defaults to D65, but can be specified with temp.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_XYZ2Lab ()

int                 vips_XYZ2Lab                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

optional arguments:

temp: colour temperature

Turn XYZ to Lab, optionally specifying the colour temperature. temp defaults to D65.

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_XYZ2scRGB ()

int                 vips_XYZ2scRGB                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn XYZ to Yxy.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_scRGB2sRGB ()

int                 vips_scRGB2sRGB                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Optional arguments:

depth: depth of output image in bits

Convert an scRGB image to sRGB. Set depth to 16 to get 16-bit output.

See also: vips_LabS2LabQ(), vips_scRGB2sRGB(), vips_rad2float().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_sRGB2scRGB ()

int                 vips_sRGB2scRGB                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Convert an sRGB image to scRGB.

See also: vips_sRGB2XYZ(), vips_rad2float().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_scRGB2XYZ ()

int                 vips_scRGB2XYZ                      (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn XYZ to scRGB.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_LCh2CMC ()

int                 vips_LCh2CMC                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn LCh to CMC.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_CMC2LCh ()

int                 vips_CMC2LCh                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn LCh to CMC.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_XYZ2Yxy ()

int                 vips_XYZ2Yxy                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn XYZ to Yxy.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_Yxy2XYZ ()

int                 vips_Yxy2XYZ                        (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn XYZ to Yxy.

in :

input image

out :

output image

Returns :

0 on success, -1 on error

vips_LabS2Lab ()

int                 vips_LabS2Lab                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Convert a LabS three-band signed short image to a three-band float image.

See also: vips_LabS2Lab().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_Lab2LabS ()

int                 vips_Lab2LabS                       (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Turn Lab to LabS, signed 16-bit int fixed point.

See also: vips_LabQ2Lab().

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_icc_present ()

int                 vips_icc_present                    (void);

VIPS can optionally be built without the ICC library. Use this function to test for its availability.

Returns :

non-zero if the ICC library is present.

vips_icc_transform ()

int                 vips_icc_transform                  (VipsImage *in,
                                                         VipsImage **out,
                                                         const char *output_profile,
                                                         ...);

Optional arguments:

input_profile: get the input profile from here intent: transform with this intent depth: depth of output image in bits embedded: use profile embedded in input image

Transform an image with a pair of ICC profiles. The input image is moved to profile-connection space with the input profile and then to the output space with the output profile.

If embedded is set, the input profile is taken from the input image metadata, if present. If there is no embedded profile, input_profile is used as a fall-back.

If embedded is not set, the input profile is taken from input_profile. If input_profile is not supplied, the metadata profile, if any, is used as a fall-back.

Use vips_icc_import() and vips_icc_export() to do either the first or second half of this operation in isolation.

in :

input image

out :

output image

output_profile :

get the output profile from here

Returns :

0 on success, -1 on error.

vips_icc_import ()

int                 vips_icc_import                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Optional arguments:

input_profile: get the input profile from here intent: transform with this intent embedded: use profile embedded in input image

Import an image from device space to D65 LAB with an ICC profile.

If embedded is set, the input profile is taken from the input image metadata. If there is no embedded profile, input_profile_filename is used as a fall-back.

If embedded is not set, the input profile is taken from input_profile. If input_profile is not supplied, the metadata profile, if any, is used as a fall-back.

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_icc_export ()

int                 vips_icc_export                     (VipsImage *in,
                                                         VipsImage **out,
                                                         ...);

Optional arguments:

intent: transform with this intent depth: depth of output image in bits output_profile: get the output profile from here

Export an image from D65 LAB to device space with an ICC profile. If output_profile is not set, use the embedded profile, if any. If output_profile is set, export with that and attach it to the output image.

in :

input image

out :

output image

Returns :

0 on success, -1 on error.

vips_icc_ac2rc ()

int                 vips_icc_ac2rc                      (VipsImage *in,
                                                         VipsImage **out,
                                                         const char *profile_filename);

Transform an image from absolute to relative colorimetry using the MediaWhitePoint stored in the ICC profile.

See also: vips_icc_transform(), vips_icc_import().

in :

input image

out :

output image

profile_filename :

use this profile

Returns :

0 on success, -1 on error.

vips_dE76 ()

int                 vips_dE76                           (VipsImage *left,
                                                         VipsImage *right,
                                                         VipsImage **out,
                                                         ...);

Calculate dE 76.

left :

first input image

right :

second input image

out :

output image

Returns :

0 on success, -1 on error

vips_dE00 ()

int                 vips_dE00                           (VipsImage *left,
                                                         VipsImage *right,
                                                         VipsImage **out,
                                                         ...);

Calculate dE 00.

left :

first input image

right :

second input image

out :

output image

Returns :

0 on success, -1 on error

vips_dECMC ()

int                 vips_dECMC                          (VipsImage *left,
                                                         VipsImage *right,
                                                         VipsImage **out,
                                                         ...);

Calculate dE CMC. The input images are transformed to CMC colour space and the euclidean distance between corresponding pixels calculated.

To calculate a colour difference with values for (l:c) other than (1:1), transform the two source images to CMC yourself, scale the channels appropriately, and call this function.

See also: vips_colourspace()

left :

first input image

right :

second input image

out :

output image

Returns :

0 on success, -1 on error

vips_col_Lab2XYZ ()

void                vips_col_Lab2XYZ                    (float L,
                                                         float a,
                                                         float b,
                                                         float *X,
                                                         float *Y,
                                                         float *Z);

Calculate XYZ from Lab, D65.

See also: vips_Lab2XYZ().

L :

Input CIE Lab value

a :

Input CIE Lab value

b :

Input CIE Lab value

X :

Return CIE XYZ colour

Y :

Return CIE XYZ colour

Z :

Return CIE XYZ colour

vips_col_XYZ2Lab ()

void                vips_col_XYZ2Lab                    (float X,
                                                         float Y,
                                                         float Z,
                                                         float *L,
                                                         float *a,
                                                         float *b);

Calculate XYZ from Lab, D65.

See also: vips_XYZ2Lab().

X :

Input CIE XYZ colour

Y :

Input CIE XYZ colour

Z :

Input CIE XYZ colour

L :

Return CIE Lab value

a :

Return CIE Lab value

b :

Return CIE Lab value

vips_col_ab2h ()

double              vips_col_ab2h                       (double a,
                                                         double b);

a :

CIE a

b :

CIE b

Returns :

Hue (degrees)

vips_col_ab2Ch ()

void                vips_col_ab2Ch                      (float a,
                                                         float b,
                                                         float *C,
                                                         float *h);


vips_col_Ch2ab ()

void                vips_col_Ch2ab                      (float C,
                                                         float h,
                                                         float *a,
                                                         float *b);

Calculate ab from Ch, h in degrees.

C :

Chroma

h :

Hue angle (degrees)

a :

return CIE a* value

b :

return CIE b* value

vips_col_L2Lcmc ()

float               vips_col_L2Lcmc                     (float L);

Calculate Lcmc from L.

L :

CIE L*

Returns :

Lcmc

vips_col_C2Ccmc ()

float               vips_col_C2Ccmc                     (float C);

Calculate Ccmc from C.

C :

Chroma

Returns :

Ccmc.

vips_col_Ch2hcmc ()

float               vips_col_Ch2hcmc                    (float C,
                                                         float h);

Calculate hcmc from C and h.

C :

Chroma

h :

Hue (degrees)

Returns :

hcmc.

vips_col_make_tables_CMC ()

void                vips_col_make_tables_CMC            (void);

Make the lookup tables for cmc.


vips_col_Lcmc2L ()

float               vips_col_Lcmc2L                     (float Lcmc);

Calculate L from Lcmc using a table. Call vips_col_make_tables_CMC() at least once before using this function.

Lcmc :

L cmc

Returns :

L*

vips_col_Ccmc2C ()

float               vips_col_Ccmc2C                     (float Ccmc);

Calculate C from Ccmc using a table. Call vips_col_make_tables_CMC() at least once before using this function.

Ccmc :

Ccmc

Returns :

C.

vips_col_Chcmc2h ()

float               vips_col_Chcmc2h                    (float C,
                                                         float hcmc);

Calculate h from C and hcmc, using a table. Call vips_col_make_tables_CMC() at least once before using this function.

C :

Chroma

hcmc :

Hue cmc (degrees)

Returns :

h.

vips_col_sRGB2scRGB_8 ()

int                 vips_col_sRGB2scRGB_8               (int r,
                                                         int g,
                                                         int b,
                                                         float *R,
                                                         float *G,
                                                         float *B);


vips_col_sRGB2scRGB_16 ()

int                 vips_col_sRGB2scRGB_16              (int r,
                                                         int g,
                                                         int b,
                                                         float *R,
                                                         float *G,
                                                         float *B);


vips_col_scRGB2XYZ ()

int                 vips_col_scRGB2XYZ                  (float R,
                                                         float G,
                                                         float B,
                                                         float *X,
                                                         float *Y,
                                                         float *Z);


vips_col_XYZ2scRGB ()

int                 vips_col_XYZ2scRGB                  (float X,
                                                         float Y,
                                                         float Z,
                                                         float *R,
                                                         float *G,
                                                         float *B);


vips_col_scRGB2sRGB_8 ()

int                 vips_col_scRGB2sRGB_8               (float R,
                                                         float G,
                                                         float B,
                                                         int *r,
                                                         int *g,
                                                         int *b,
                                                         int *or_ret);


vips_col_scRGB2sRGB_16 ()

int                 vips_col_scRGB2sRGB_16              (float R,
                                                         float G,
                                                         float B,
                                                         int *r,
                                                         int *g,
                                                         int *b,
                                                         int *or_ret);


vips_pythagoras ()

float               vips_pythagoras                     (float L1,
                                                         float a1,
                                                         float b1,
                                                         float L2,
                                                         float a2,
                                                         float b2);

Pythagorean distance between two points in colour space. Lab/XYZ/CMC etc.

L1 :

Input coordinate 1

a1 :

Input coordinate 1

b1 :

Input coordinate 1

L2 :

Input coordinate 2

a2 :

Input coordinate 2

b2 :

Input coordinate 2

vips_col_dE00 ()

float               vips_col_dE00                       (float L1,
                                                         float a1,
                                                         float b1,
                                                         float L2,
                                                         float a2,
                                                         float b2);

CIEDE2000, from:

Luo, Cui, Rigg, "The Development of the CIE 2000 Colour-Difference Formula: CIEDE2000", COLOR research and application, pp 340

L1 :

Input coordinate 1

a1 :

Input coordinate 1

b1 :

Input coordinate 1

L2 :

Input coordinate 2

a2 :

Input coordinate 2

b2 :

Input coordinate 2

Returns :

CIE dE2000 colour difference.

See Also

arithmetic