This commit is contained in:
John Cupitt 2012-09-19 15:03:31 +01:00
parent 496b4373a4
commit e0fcc2c517
2 changed files with 20 additions and 37 deletions

View File

@ -50,12 +50,6 @@ typedef VipsColorimetricClass VipsLCh2UCSClass;
G_DEFINE_TYPE( VipsLCh2UCS, vips_LCh2UCS, VIPS_TYPE_COLORIMETRIC );
/* Constants for Lucs.
*/
#define c1 21.75
#define c2 0.3838
#define c3 38.54
/**
* vips_col_L2Lucs:
* @L: CIE L*
@ -70,21 +64,13 @@ vips_col_L2Lucs( float L )
float Lucs;
if( L >= 16.0 )
Lucs = (c1 * log( L ) + c2 * L - c3);
Lucs = (21.75 * log( L ) + 0.3838 * L - 38.54);
else
Lucs = 1.744 * L;
return( Lucs );
}
/* Constants for Cucs.
*/
#define c4 0.162
#define c5 10.92
#define c6 0.638
#define c7 0.07216
#define c8 4.907
/**
* vips_col_C2Cucs:
* @C: Chroma
@ -98,7 +84,7 @@ vips_col_C2Cucs( float C )
{
float Cucs;
Cucs = c4 * C + c5 * log( c6 + c7 * C ) + c8;
Cucs = 0.162 * C + 10.92 * log( 0.638 + 0.07216 * C ) + 4.907;
if( Cucs < 0 )
Cucs = 0;

View File

@ -69,14 +69,15 @@ make_LI( void )
{
int i;
float Ll[1001];
int j;
for( i = 0; i < 1001; i++ )
Ll[i] = vips_col_L2Lucs( i / 10.0 );
for( j = 0, i = 0; i < 1001; i++ ) {
while( Ll[j] <= i / 10.0 && j < 1001 )
j++;
for( i = 0; i < 1001; i++ ) {
int j;
for( j = 0; j < 1001 && Ll[j] <= i / 10.0; j++ )
;
LI[i] = (j - 1) / 10.0 +
(i / 10.0 - Ll[j - 1]) / ((Ll[j] - Ll[j - 1]) * 10.0);
@ -97,12 +98,6 @@ make_CI( void )
for( i = 0; i < 3001; i++ ) {
int j;
/*
*
why isn't this loop the same as the one for L above
or for h below
*/
for( j = 0; j < 3001 && Cl[j] <= i / 10.0; j++ )
;
CI[i] = (j - 1) / 10.0 +
@ -115,7 +110,7 @@ make_CI( void )
static void
make_hI( void )
{
int i, j, k;
int i, j;
float hl[101][361];
for( i = 0; i < 361; i++ )
@ -123,10 +118,11 @@ make_hI( void )
hl[j][i] = vips_col_Ch2hucs( j * 2.0, i );
for( j = 0; j < 101; j++ ) {
k = 0;
for( i = 0; i < 361; i++ ) {
while( k < 361 && hl[j][k] <= i )
k++;
int k;
for( k = 0; k < 361 && hl[j][k] <= i; k++ )
;
hI[j][i] = k - 1 + (i - hl[j][k - 1]) /
(hl[j][k] - hl[j][k - 1]);
}
@ -145,7 +141,7 @@ make_hI( void )
float
vips_col_Lucs2L( float Lucs )
{
int known; /* nearest input value in the table, <= Lucs */
int known;
known = floor( Lucs * 10.0 );
known = VIPS_CLIP( 0, known, 1000 );
@ -167,7 +163,7 @@ vips_col_Lucs2L( float Lucs )
float
vips_col_Cucs2C( float Cucs )
{
int known; /* nearest input value in the table, <= Cucs */
int known;
known = floor( Cucs * 10.0 );
known = VIPS_CLIP( 0, known, 3000 );
@ -190,7 +186,8 @@ vips_col_Cucs2C( float Cucs )
float
vips_col_Chucs2h( float C, float hucs )
{
int r, known; /* nearest input value in the table, <= hucs */
int r;
int known;
/* Which row of the table?
*/