cleanups
This commit is contained in:
parent
496b4373a4
commit
e0fcc2c517
@ -50,12 +50,6 @@ typedef VipsColorimetricClass VipsLCh2UCSClass;
|
|||||||
|
|
||||||
G_DEFINE_TYPE( VipsLCh2UCS, vips_LCh2UCS, VIPS_TYPE_COLORIMETRIC );
|
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:
|
* vips_col_L2Lucs:
|
||||||
* @L: CIE L*
|
* @L: CIE L*
|
||||||
@ -70,21 +64,13 @@ vips_col_L2Lucs( float L )
|
|||||||
float Lucs;
|
float Lucs;
|
||||||
|
|
||||||
if( L >= 16.0 )
|
if( L >= 16.0 )
|
||||||
Lucs = (c1 * log( L ) + c2 * L - c3);
|
Lucs = (21.75 * log( L ) + 0.3838 * L - 38.54);
|
||||||
else
|
else
|
||||||
Lucs = 1.744 * L;
|
Lucs = 1.744 * L;
|
||||||
|
|
||||||
return( Lucs );
|
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:
|
* vips_col_C2Cucs:
|
||||||
* @C: Chroma
|
* @C: Chroma
|
||||||
@ -98,7 +84,7 @@ vips_col_C2Cucs( float C )
|
|||||||
{
|
{
|
||||||
float Cucs;
|
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 )
|
if( Cucs < 0 )
|
||||||
Cucs = 0;
|
Cucs = 0;
|
||||||
|
|
||||||
|
@ -66,17 +66,18 @@ G_DEFINE_TYPE( VipsUCS2LCh, vips_UCS2LCh, VIPS_TYPE_COLORIMETRIC );
|
|||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
make_LI( void )
|
make_LI( void )
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
float Ll[ 1001 ];
|
float Ll[1001];
|
||||||
int j;
|
|
||||||
|
|
||||||
for( i = 0; i < 1001; i++ )
|
for( i = 0; i < 1001; i++ )
|
||||||
Ll[i] = vips_col_L2Lucs( i / 10.0 );
|
Ll[i] = vips_col_L2Lucs( i / 10.0 );
|
||||||
|
|
||||||
for( j = 0, i = 0; i < 1001; i++ ) {
|
for( i = 0; i < 1001; i++ ) {
|
||||||
while( Ll[j] <= i / 10.0 && j < 1001 )
|
int j;
|
||||||
j++;
|
|
||||||
|
for( j = 0; j < 1001 && Ll[j] <= i / 10.0; j++ )
|
||||||
|
;
|
||||||
|
|
||||||
LI[i] = (j - 1) / 10.0 +
|
LI[i] = (j - 1) / 10.0 +
|
||||||
(i / 10.0 - Ll[j - 1]) / ((Ll[j] - Ll[j - 1]) * 10.0);
|
(i / 10.0 - Ll[j - 1]) / ((Ll[j] - Ll[j - 1]) * 10.0);
|
||||||
@ -87,7 +88,7 @@ make_LI( void )
|
|||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
make_CI( void )
|
make_CI( void )
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
float Cl[3001];
|
float Cl[3001];
|
||||||
|
|
||||||
@ -97,12 +98,6 @@ make_CI( void )
|
|||||||
for( i = 0; i < 3001; i++ ) {
|
for( i = 0; i < 3001; i++ ) {
|
||||||
int j;
|
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++ )
|
for( j = 0; j < 3001 && Cl[j] <= i / 10.0; j++ )
|
||||||
;
|
;
|
||||||
CI[i] = (j - 1) / 10.0 +
|
CI[i] = (j - 1) / 10.0 +
|
||||||
@ -114,8 +109,8 @@ make_CI( void )
|
|||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
make_hI( void )
|
make_hI( void )
|
||||||
{
|
{
|
||||||
int i, j, k;
|
int i, j;
|
||||||
float hl[101][361];
|
float hl[101][361];
|
||||||
|
|
||||||
for( i = 0; i < 361; i++ )
|
for( i = 0; i < 361; i++ )
|
||||||
@ -123,10 +118,11 @@ make_hI( void )
|
|||||||
hl[j][i] = vips_col_Ch2hucs( j * 2.0, i );
|
hl[j][i] = vips_col_Ch2hucs( j * 2.0, i );
|
||||||
|
|
||||||
for( j = 0; j < 101; j++ ) {
|
for( j = 0; j < 101; j++ ) {
|
||||||
k = 0;
|
|
||||||
for( i = 0; i < 361; i++ ) {
|
for( i = 0; i < 361; i++ ) {
|
||||||
while( k < 361 && hl[j][k] <= i )
|
int k;
|
||||||
k++;
|
|
||||||
|
for( k = 0; k < 361 && hl[j][k] <= i; k++ )
|
||||||
|
;
|
||||||
hI[j][i] = k - 1 + (i - hl[j][k - 1]) /
|
hI[j][i] = k - 1 + (i - hl[j][k - 1]) /
|
||||||
(hl[j][k] - hl[j][k - 1]);
|
(hl[j][k] - hl[j][k - 1]);
|
||||||
}
|
}
|
||||||
@ -145,7 +141,7 @@ make_hI( void )
|
|||||||
float
|
float
|
||||||
vips_col_Lucs2L( float Lucs )
|
vips_col_Lucs2L( float Lucs )
|
||||||
{
|
{
|
||||||
int known; /* nearest input value in the table, <= Lucs */
|
int known;
|
||||||
|
|
||||||
known = floor( Lucs * 10.0 );
|
known = floor( Lucs * 10.0 );
|
||||||
known = VIPS_CLIP( 0, known, 1000 );
|
known = VIPS_CLIP( 0, known, 1000 );
|
||||||
@ -167,7 +163,7 @@ vips_col_Lucs2L( float Lucs )
|
|||||||
float
|
float
|
||||||
vips_col_Cucs2C( float Cucs )
|
vips_col_Cucs2C( float Cucs )
|
||||||
{
|
{
|
||||||
int known; /* nearest input value in the table, <= Cucs */
|
int known;
|
||||||
|
|
||||||
known = floor( Cucs * 10.0 );
|
known = floor( Cucs * 10.0 );
|
||||||
known = VIPS_CLIP( 0, known, 3000 );
|
known = VIPS_CLIP( 0, known, 3000 );
|
||||||
@ -190,7 +186,8 @@ vips_col_Cucs2C( float Cucs )
|
|||||||
float
|
float
|
||||||
vips_col_Chucs2h( float C, float hucs )
|
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?
|
/* Which row of the table?
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user