hist hacking

This commit is contained in:
John Cupitt 2010-03-26 10:03:37 +00:00
parent b95486c345
commit 3268bd0aaf
7 changed files with 68 additions and 62 deletions

2
TODO
View File

@ -1,3 +1,5 @@
- new is_monotonic() needs testing ... move somewhere else? tone.c isn't an
obvious place for it
- lots of stupid little files in hist, eg. im_hsp.c ... paste them into larger - lots of stupid little files in hist, eg. im_hsp.c ... paste them into larger
modules modules

View File

@ -78,10 +78,8 @@ im_compass( IMAGE *in, IMAGE *out, INTMASK *mask )
for( i = 0; i < 8; i++ ) { for( i = 0; i < 8; i++ ) {
if( im_conv( in, filtered[i], mask ) || if( im_conv( in, filtered[i], mask ) ||
!(mask = (INTMASK *) im_local( out, !(mask = im_local_imask( out,
(im_construct_fn) im_rotate_imask45, im_rotate_imask45( mask, mask->filename ) )) )
(im_callback_fn) im_free_imask,
mask, mask->filename, NULL )) )
return( -1 ); return( -1 );
} }
@ -119,10 +117,8 @@ im_lindetect( IMAGE *in, IMAGE *out, INTMASK *mask )
for( i = 0; i < 4; i++ ) { for( i = 0; i < 4; i++ ) {
if( im_conv( in, filtered[i], mask ) || if( im_conv( in, filtered[i], mask ) ||
!(mask = (INTMASK *) im_local( out, !(mask = im_local_imask( out,
(im_construct_fn) im_rotate_imask45, im_rotate_imask45( mask, mask->filename ) )) )
(im_callback_fn) im_free_imask,
mask, mask->filename, NULL )) )
return( -1 ); return( -1 );
} }
@ -155,9 +151,8 @@ im_gradient( IMAGE *in, IMAGE *out, INTMASK *mask )
if( im_open_local_array( out, t, 4, "im_gradient", "p" ) ) if( im_open_local_array( out, t, 4, "im_gradient", "p" ) )
return( -1 ); return( -1 );
if( !(rmask = (INTMASK *) im_local( out, if( !(rmask = im_local_imask( out,
(im_construct_fn) im_rotate_imask90, im_rotate_imask90( mask, mask->filename ) )) )
(im_callback_fn) im_free_imask, mask, mask->filename, NULL )) )
return( -1 ); return( -1 );
if( im_conv( in, t[0], mask ) || if( im_conv( in, t[0], mask ) ||

View File

@ -333,10 +333,7 @@ im_sharpen( IMAGE *in, IMAGE *out,
/* Set up data structures we need. First, the convolution mask we will /* Set up data structures we need. First, the convolution mask we will
* use. * use.
*/ */
if( !(mask = (INTMASK *) im_local( out, if( !(mask = im_local_imask( out, sharpen_mask_new( mask_size ) )) )
(im_construct_fn) sharpen_mask_new,
(im_callback_fn) im_free_imask,
GINT_TO_POINTER( mask_size ), NULL, NULL )) )
return( -1 ); return( -1 );
/* Make the lut we will use. We need to scale up x1, x2, x3 to the /* Make the lut we will use. We need to scale up x1, x2, x3 to the

View File

@ -337,38 +337,29 @@ im_tone_build( IMAGE *out,
int int
im_ismonotonic( IMAGE *lut, int *out ) im_ismonotonic( IMAGE *lut, int *out )
{ {
IMAGE *t[3]; IMAGE *t[2];
INTMASK *mask;
double m; double m;
if( im_open_local_array( lut, t, 3, "im_ismonotonic", "p" ) || if( im_check_hist( "im_ismonotonic", lut ) ||
im_check_hist( "im_ismonotonic", lut ) ) im_open_local_array( lut, t, 2, "im_ismonotonic", "p" ) )
return( -1 ); return( -1 );
/* Can be either a horizontal or vertical LUT. if( !(mask = im_local_imask( lut,
*/ im_create_imaskv( "im_ismonotonic", 2, 1, 1, -1 ) )) )
if( lut->Xsize != 1 && lut->Ysize != 1 ) {
im_error( "im_ismonotonic",
"%s", _( "not 1 by n or n by 1 image" ) );
return( -1 ); return( -1 );
} mask->offset = 128;
/* Extract two areas, offset by 1 pixel.
*/
if( lut->Xsize == 1 ) { if( lut->Xsize == 1 ) {
if( im_extract_area( lut, t[0], 0, 0, 1, lut->Ysize - 1 ) || if( !(mask = im_local_imask( lut,
im_extract_area( lut, t[1], 0, 1, 1, lut->Ysize - 1 ) ) im_rotate_imask90( mask, mask->filename ) )) )
return( -1 );
}
else {
if( im_extract_area( lut, t[0], 0, 0, lut->Xsize - 1, 1 ) ||
im_extract_area( lut, t[1], 1, 0, lut->Xsize - 1, 1 ) )
return( -1 ); return( -1 );
} }
/* Now t2 should be >= than t1 everywhere! /* We want >=128 everywhere, ie. no -ve transitions.
*/ */
if( im_moreeq( t[1], t[0], t[2] ) || if( im_conv( lut, t[0], mask ) ||
im_min( t[2], &m ) ) im_moreeqconst( t[0], t[1], 128 ) ||
im_min( t[1], &m ) )
return( -1 ); return( -1 );
*out = m; *out = m;

View File

@ -103,6 +103,9 @@ int im_lu_solve( const DOUBLEMASK *lu, double *vec );
DOUBLEMASK *im_matinv( const DOUBLEMASK *mat, const char *name ); DOUBLEMASK *im_matinv( const DOUBLEMASK *mat, const char *name );
int im_matinv_inplace( DOUBLEMASK *mat ); int im_matinv_inplace( DOUBLEMASK *mat );
DOUBLEMASK *im_local_dmask( struct _VipsImage *out, DOUBLEMASK *mask );
INTMASK *im_local_imask( struct _VipsImage *out, INTMASK *mask );
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /*__cplusplus*/ #endif /*__cplusplus*/

View File

@ -774,3 +774,37 @@ im_print_dmask( DOUBLEMASK *m )
printf( "\n" ); printf( "\n" );
} }
} }
/* Make a DOUBLEMASK local to an image descriptor.
*/
DOUBLEMASK *
im_local_dmask( VipsImage *out, DOUBLEMASK *mask )
{
if( !mask )
return( NULL );
if( im_add_close_callback( out,
(im_callback_fn) im_free_dmask, mask, NULL ) ) {
im_free_dmask( mask );
return( NULL );
}
return( mask );
}
/* Make an INTMASK local to an image descriptor.
*/
INTMASK *
im_local_imask( VipsImage *out, INTMASK *mask )
{
if( !mask )
return( NULL );
if( im_add_close_callback( out,
(im_callback_fn) im_free_imask, mask, NULL ) ) {
im_free_imask( mask );
return( NULL );
}
return( mask );
}

View File

@ -969,23 +969,6 @@ print_overlap_errors( JoinNode *node, double *fac, double *total )
} }
#endif /*DEBUG*/ #endif /*DEBUG*/
/* Make a DOUBLEMASK local to an image descriptor.
*/
static DOUBLEMASK *
local_mask( IMAGE *out, DOUBLEMASK *mask )
{
if( !mask )
return( NULL );
if( im_add_close_callback( out,
(im_callback_fn) im_free_dmask, mask, NULL ) ) {
im_free_dmask( mask );
return( NULL );
}
return( mask );
}
/* Extract a rect. /* Extract a rect.
*/ */
static int static int
@ -1052,7 +1035,7 @@ find_image_stats( IMAGE *in, IMAGE *mask, Rect *area )
/* Get stats from masked image. /* Get stats from masked image.
*/ */
if( !(stats = local_mask( in, im_stats( t[3] ) )) ) if( !(stats = im_local_dmask( in, im_stats( t[3] ) )) )
return( NULL ); return( NULL );
/* Number of non-zero pixels in mask. /* Number of non-zero pixels in mask.
@ -1464,8 +1447,9 @@ find_factors( SymbolTable *st, double gamma )
/* Make output matricies. /* Make output matricies.
*/ */
if( !(K = local_mask( st->im, im_create_dmask( "K", 1, st->novl ) )) || if( !(K = im_local_dmask( st->im,
!(M = local_mask( st->im, im_create_dmask( "K", 1, st->novl ) )) ||
!(M = im_local_dmask( st->im,
im_create_dmask( "M", st->nim-1, st->novl ) )) ) im_create_dmask( "M", st->nim-1, st->novl ) )) )
return( -1 ); return( -1 );
fill_matricies( st, gamma, K, M ); fill_matricies( st, gamma, K, M );
@ -1476,15 +1460,15 @@ find_factors( SymbolTable *st, double gamma )
/* Calculate LMS. /* Calculate LMS.
*/ */
if( !(m1 = local_mask( st->im, im_mattrn( M, "lms:1" ) )) ) if( !(m1 = im_local_dmask( st->im, im_mattrn( M, "lms:1" ) )) )
return( -1 ); return( -1 );
if( !(m2 = local_mask( st->im, im_matmul( m1, M, "lms:2" ) )) ) if( !(m2 = im_local_dmask( st->im, im_matmul( m1, M, "lms:2" ) )) )
return( -1 ); return( -1 );
if( !(m3 = local_mask( st->im, im_matinv( m2, "lms:3" ) )) ) if( !(m3 = im_local_dmask( st->im, im_matinv( m2, "lms:3" ) )) )
return( -1 ); return( -1 );
if( !(m4 = local_mask( st->im, im_matmul( m3, m1, "lms:4" ) )) ) if( !(m4 = im_local_dmask( st->im, im_matmul( m3, m1, "lms:4" ) )) )
return( -1 ); return( -1 );
if( !(m5 = local_mask( st->im, im_matmul( m4, K, "lms:5" ) )) ) if( !(m5 = im_local_dmask( st->im, im_matmul( m4, K, "lms:5" ) )) )
return( -1 ); return( -1 );
/* Make array of correction factors. /* Make array of correction factors.