link nohalo in
This commit is contained in:
parent
b4e79ccb5a
commit
1f20c4bd38
12
TODO
12
TODO
@ -1,3 +1,15 @@
|
||||
- make properties for nickname etc. so we can get class properties from
|
||||
objects
|
||||
|
||||
- dir on a Managedgobject should list properties
|
||||
|
||||
- (get_member "poop" (Managedgobject)) should work
|
||||
|
||||
- dir on a gtype should also list properties? how should we list subclasses?
|
||||
|
||||
|
||||
|
||||
|
||||
- maybe IM_INTERPOLATE() isn't a good idea? maybe just IM_GOBJECT?
|
||||
|
||||
- try making vips_add(), an operator as a class
|
||||
|
@ -674,6 +674,8 @@ vips_object_check_required( VipsObject *object, GParamSpec *pspec,
|
||||
static int
|
||||
vips_object_real_build( VipsObject *object )
|
||||
{
|
||||
VipsObjectClass *object_class = VIPS_OBJECT_GET_CLASS( object );
|
||||
|
||||
int result;
|
||||
|
||||
g_assert( !object->constructed );
|
||||
@ -689,6 +691,14 @@ vips_object_real_build( VipsObject *object )
|
||||
*/
|
||||
object->constructed = TRUE;
|
||||
|
||||
/* It'd be nice if this just copied a pointer rather than did a
|
||||
* strdup(). Set these here rather than in object_init, so that the
|
||||
* class gets a chance to set them.
|
||||
*/
|
||||
g_object_set( object,
|
||||
"nickname", object_class->nickname,
|
||||
"description", object_class->description, NULL );
|
||||
|
||||
return( result );
|
||||
}
|
||||
|
||||
@ -769,7 +779,7 @@ vips_object_class_init( VipsObjectClass *object_class )
|
||||
_( "Nickname" ),
|
||||
_( "Class nickname" ),
|
||||
"",
|
||||
(GParamFlags) G_PARAM_READABLE );
|
||||
(GParamFlags) G_PARAM_READWRITE );
|
||||
g_object_class_install_property( gobject_class,
|
||||
PROP_NICKNAME, pspec );
|
||||
vips_object_class_install_argument( object_class, pspec,
|
||||
@ -780,7 +790,7 @@ vips_object_class_init( VipsObjectClass *object_class )
|
||||
_( "Description" ),
|
||||
_( "Class description" ),
|
||||
"",
|
||||
(GParamFlags) G_PARAM_READABLE );
|
||||
(GParamFlags) G_PARAM_READWRITE );
|
||||
g_object_class_install_property( gobject_class,
|
||||
PROP_DESCRIPTION, pspec );
|
||||
vips_object_class_install_argument( object_class, pspec,
|
||||
@ -792,19 +802,10 @@ vips_object_class_init( VipsObjectClass *object_class )
|
||||
static void
|
||||
vips_object_init( VipsObject *object )
|
||||
{
|
||||
VipsObjectClass *object_class = VIPS_OBJECT_GET_CLASS( object );
|
||||
|
||||
#ifdef DEBUG
|
||||
printf( "vips_object_init: " );
|
||||
vips_object_print( object );
|
||||
#endif /*DEBUG*/
|
||||
|
||||
/* It'd be nice if this just copied a pointer rather than did a
|
||||
* strdup().
|
||||
*/
|
||||
g_object_set( object,
|
||||
"nickname", object_class->nickname,
|
||||
"description", object_class->description, NULL );
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -15,6 +15,7 @@ libmosaicing_la_SOURCES = \
|
||||
interpolate.c \
|
||||
yafrsmooth.cpp \
|
||||
yafrnohalo.c \
|
||||
nohalo.cpp \
|
||||
im_improve.c \
|
||||
im_initialize.c \
|
||||
im_lrcalcon.c \
|
||||
|
@ -447,12 +447,14 @@ vips__interpolate_init( void )
|
||||
extern GType vips_interpolate_bicubic_get_type( void );
|
||||
extern GType vips_interpolate_yafrsmooth_get_type( void );
|
||||
extern GType vips_interpolate_yafrnohalo_get_type( void );
|
||||
extern GType vips_interpolate_nohalo_get_type( void );
|
||||
|
||||
vips_interpolate_nearest_get_type();
|
||||
vips_interpolate_bilinear_get_type();
|
||||
vips_interpolate_bicubic_get_type();
|
||||
vips_interpolate_yafrsmooth_get_type();
|
||||
vips_interpolate_yafrnohalo_get_type();
|
||||
vips_interpolate_nohalo_get_type();
|
||||
}
|
||||
|
||||
/* Make an interpolator from a nickname.
|
||||
|
@ -313,8 +313,7 @@ nohalo1(
|
||||
const double cin_fou,
|
||||
double *r1,
|
||||
double *r2,
|
||||
double *r3,
|
||||
double *r4 )
|
||||
double *r3 )
|
||||
{
|
||||
/* Start of copy-paste from Nicolas's source.
|
||||
*/
|
||||
@ -584,10 +583,9 @@ nohalo1(
|
||||
/* End of copy-paste from Nicolas's source.
|
||||
*/
|
||||
|
||||
*r1 = tre_thr;
|
||||
*r2 = tre_thrfou;
|
||||
*r3 = trequa_thr;
|
||||
*r4 = trequa_thrfou;
|
||||
*r1 = tre_thrfou;
|
||||
*r2 = trequa_thr;
|
||||
*r3 = trequa_thrfou;
|
||||
}
|
||||
|
||||
/* Float/double version.
|
||||
@ -606,6 +604,7 @@ nohalo_float( PEL *pout, const PEL *pin,
|
||||
const int b1 = bands;
|
||||
const int b2 = 2 * b1;
|
||||
const int b3 = 3 * b1;
|
||||
const int b4 = 4 * b1;
|
||||
|
||||
const int l1 = lskip / sizeof( T );
|
||||
const int l2 = 2 * l1;
|
||||
@ -613,23 +612,22 @@ nohalo_float( PEL *pout, const PEL *pin,
|
||||
|
||||
for( int z = 0; z < bands; z++ ) {
|
||||
|
||||
const T dos_two = in[b1];
|
||||
const T dos_thr = in[b2];
|
||||
const T dos_fou = in[b3];
|
||||
|
||||
const T tre_one = in[l1];
|
||||
const T tre_two = in[b1 + l1];
|
||||
const T tre_thr = in[b2 + l1];
|
||||
const T tre_fou = in[b3 + l1];
|
||||
const T tre_fiv = in[b4 + l1];
|
||||
|
||||
const T qua_one = in[l2];
|
||||
const T qua_two = in[b1 + l2];
|
||||
const T qua_thr = in[b2 + l2];
|
||||
const T qua_fou = in[b3 + l2];
|
||||
const T qua_fiv = in[b4 + l2];
|
||||
|
||||
const T cin_two = in[b1 + l3];
|
||||
const T cin_thr = in[b2 + l3];
|
||||
const T cin_fou = in[b3 + l3];
|
||||
|
||||
double tre_thr;
|
||||
double tre_thrfou;
|
||||
double trequa_thr;
|
||||
double trequa_thrfou;
|
||||
@ -639,7 +637,6 @@ nohalo_float( PEL *pout, const PEL *pin,
|
||||
tre_two, tre_thr, tre_fou, tre_fiv,
|
||||
qua_two, qua_thr, qua_fou, qua_fiv,
|
||||
cin_thr, cin_fou,
|
||||
&tre_thr,
|
||||
&tre_thrfou,
|
||||
&trequa_thr,
|
||||
&trequa_thrfou );
|
||||
@ -661,19 +658,23 @@ nohalo_float( PEL *pout, const PEL *pin,
|
||||
}
|
||||
}
|
||||
|
||||
/* We need C linkage for this.
|
||||
*/
|
||||
extern "C" {
|
||||
G_DEFINE_TYPE( VipsInterpolateNohalo, vips_interpolate_nohalo,
|
||||
VIPS_TYPE_INTERPOLATE );
|
||||
}
|
||||
|
||||
static void
|
||||
vips_interpolate_nohalo_interpolate( VipsInterpolate *interpolate,
|
||||
PEL *out, REGION *in, double absolute_x, double absolute_y )
|
||||
{
|
||||
VipsInterpolateNohaloClass *nohalo_class =
|
||||
VIPS_INTERPOLATE_NOHALO_GET_CLASS( interpolate );
|
||||
VipsInterpolateNohalo *nohalo = VIPS_INTERPOLATE_NOHALO( interpolate );
|
||||
|
||||
/* VIPS versions of Nicolas's pixel addressing values.
|
||||
* values_per_tile_row is really how much to add to skip down a row.
|
||||
*/
|
||||
const int channels_per_pixel = in->im->Bands;
|
||||
const int values_per_tile_row =
|
||||
IM_REGION_LSKIP( in ) / IM_IMAGE_SIZEOF_ELEMENT( in );
|
||||
IM_REGION_LSKIP( in ) / IM_IMAGE_SIZEOF_ELEMENT( in->im );
|
||||
|
||||
/* Copy-paste of Nicolas's pixel addressing code starts.
|
||||
*/
|
||||
@ -707,12 +708,6 @@ vips_interpolate_nohalo_interpolate( VipsInterpolate *interpolate,
|
||||
const int relative_x_is_left = ( relative_x < 0. );
|
||||
const int relative_y_is___up = ( relative_y < 0. );
|
||||
|
||||
const int basic_x_reflexion_shift = ( 5 - 1 ) * channels_per_pixel;
|
||||
const int basic_y_reflexion_shift = ( 5 - 1 ) * values_per_tile_row;
|
||||
|
||||
const int x_reflexion_shift = basic_x_reflexion_shift * relative_x_is_left;
|
||||
const int y_reflexion_shift = basic_y_reflexion_shift * relative_y_is___up;
|
||||
|
||||
/*
|
||||
* The direction of movement within the (extended) possibly
|
||||
* reflected stencil is then determined by the following signs:
|
||||
@ -738,25 +733,11 @@ vips_interpolate_nohalo_interpolate( VipsInterpolate *interpolate,
|
||||
const double x = ( 2 * sign_of_relative_x ) * relative_x;
|
||||
const double y = ( 2 * sign_of_relative_y ) * relative_y;
|
||||
|
||||
/*
|
||||
* Basic shifts:
|
||||
*/
|
||||
const int shift_2_pixels = 2 * shift_1_pixel;
|
||||
const int shift_2_rows = 2 * shift_1_row;
|
||||
|
||||
/*
|
||||
* FIRST BILINEAR WEIGHT:
|
||||
*/
|
||||
const double x_times_y = x * y;
|
||||
|
||||
/*
|
||||
* More basic shifts:
|
||||
*/
|
||||
const int shift_3_pixels = shift_2_pixels + shift_1_pixel;
|
||||
const int shift_3_rows = shift_2_rows + shift_1_row;
|
||||
const int shift_4_rows = 2 * shift_2_rows;
|
||||
const int shift_4_pixels = 2 * shift_2_pixels;
|
||||
|
||||
/*
|
||||
* SECOND AND THIRD BILINEAR WEIGHTS:
|
||||
*
|
||||
@ -765,102 +746,82 @@ vips_interpolate_nohalo_interpolate( VipsInterpolate *interpolate,
|
||||
const double w_times_y = y - x_times_y;
|
||||
const double x_times_z = x - x_times_y;
|
||||
|
||||
/*
|
||||
* OVERALL SHIFTS:
|
||||
*/
|
||||
const int dos_thr_shift = shift_1_row + shift_2_pixels;
|
||||
const int dos_fou_shift = shift_1_row + shift_3_pixels;
|
||||
|
||||
const int tre_two_shift = shift_2_rows + shift_1_pixel;
|
||||
const int tre_thr_shift = shift_2_rows + shift_2_pixels;
|
||||
const int tre_fou_shift = shift_2_rows + shift_3_pixels;
|
||||
const int tre_fiv_shift = shift_2_rows + shift_4_pixels;
|
||||
|
||||
const int qua_two_shift = shift_3_rows + shift_1_pixel;
|
||||
const int qua_thr_shift = shift_3_rows + shift_2_pixels;
|
||||
const int qua_fou_shift = shift_3_rows + shift_3_pixels;
|
||||
const int qua_fiv_shift = shift_3_rows + shift_4_pixels;
|
||||
|
||||
const int cin_thr_shift = shift_4_rows + shift_2_pixels;
|
||||
const int cin_fou_shift = shift_4_rows + shift_3_pixels;
|
||||
|
||||
/*
|
||||
* LAST BILINEAR WEIGHT:
|
||||
*/
|
||||
const double w_times_z = 1. - ( x + w_times_y );
|
||||
|
||||
/*
|
||||
* gegl_sampler_get_ptr (self, ix-2, iy-2) should give me access to
|
||||
* a 5 by 5 black of pixel data, where the leftmost/topmost pixel is
|
||||
* located at (ix-2,iy-2)---that is, the data runs from "absolute
|
||||
* indices" ix-2 to ix+2 and iy-2 to iy+2. Note that the four
|
||||
* corners of this 5x5 block are never used.
|
||||
*
|
||||
* Adding x_reflexion_shift and y_reflexion_shift to the input data
|
||||
* pointer, otherwise pointing to the (first channel of the) top
|
||||
* left of the five by five stencil, will bring it to the desired
|
||||
* corner:
|
||||
/* We need to shift and reflect the pointer. IM_REGION_ADDR() is
|
||||
* an untyped pointer to the top-left of our 5x5 window.
|
||||
*/
|
||||
const PEL * restrict in =
|
||||
IM_REGION_ADDR (self, ix-2, iy-2)
|
||||
+
|
||||
(
|
||||
x_reflexion_shift
|
||||
+
|
||||
y_reflexion_shift
|
||||
const PEL * restrict p =
|
||||
(PEL *) IM_REGION_ADDR( in, ix - 2, iy - 2 ) +
|
||||
IM_IMAGE_SIZEOF_ELEMENT( in->im ) * (
|
||||
relative_x_is_left * 4 * channels_per_pixel +
|
||||
relative_y_is___up * 4 * values_per_tile_row
|
||||
);
|
||||
|
||||
switch( in->im->BandFmt ) {
|
||||
/*
|
||||
case IM_BANDFMT_UCHAR:
|
||||
nohalo_unsigned<unsigned char>( out, p, bands, lskip,
|
||||
nohalo_unsigned<unsigned char>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_CHAR:
|
||||
nohalo_signed<signed char>( out, p, bands, lskip,
|
||||
nohalo_signed<signed char>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_USHORT:
|
||||
nohalo_unsigned<unsigned short>( out, p, bands, lskip,
|
||||
nohalo_unsigned<unsigned short>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_SHORT:
|
||||
nohalo_signed<signed short>( out, p, bands, lskip,
|
||||
nohalo_signed<signed short>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_UINT:
|
||||
nohalo_unsigned<unsigned int>( out, p, bands, lskip,
|
||||
nohalo_unsigned<unsigned int>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_INT:
|
||||
nohalo_signed<signed int>( out, p, bands, lskip,
|
||||
nohalo_signed<signed int>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
*/
|
||||
|
||||
case IM_BANDFMT_FLOAT:
|
||||
nohalo_float<float>( out, p, bands, lskip,
|
||||
nohalo_float<float>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
/*
|
||||
case IM_BANDFMT_DOUBLE:
|
||||
nohalo_float<double>( out, p, bands, lskip,
|
||||
nohalo_float<double>( out, p,
|
||||
shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_COMPLEX:
|
||||
nohalo_float<float>( out, p, bands * 2, lskip,
|
||||
nohalo_float<float>( out, p,
|
||||
2 * shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
|
||||
case IM_BANDFMT_DPCOMPLEX:
|
||||
nohalo_float<double>( out, p, bands * 2, lskip,
|
||||
nohalo_float<double>( out, p,
|
||||
2 * shift_1_pixel, shift_1_row,
|
||||
w_times_z, x_times_z, w_times_y, x_times_y );
|
||||
break;
|
||||
*/
|
||||
@ -870,23 +831,15 @@ vips_interpolate_nohalo_interpolate( VipsInterpolate *interpolate,
|
||||
}
|
||||
}
|
||||
|
||||
/* We need C linkage for this.
|
||||
*/
|
||||
extern "C" {
|
||||
G_DEFINE_TYPE( VipsInterpolateNohalo, vips_interpolate_nohalo,
|
||||
VIPS_TYPE_INTERPOLATE );
|
||||
}
|
||||
|
||||
static void
|
||||
vips_interpolate_nohalo_class_init( VipsInterpolateNohaloClass *klass )
|
||||
{
|
||||
GObjectClass *gobject_class = G_OBJECT_CLASS( klass );
|
||||
VipsObjectClass *object_class = VIPS_OBJECT_CLASS( klass );
|
||||
VipsInterpolateClass *interpolate_class =
|
||||
VIPS_INTERPOLATE_CLASS( klass );
|
||||
|
||||
object_class->nickname = "nohalo";
|
||||
object_class->description = _( "nohalo interpolation" );
|
||||
object_class->description = _( "Bilinear plus edge enhance" );
|
||||
|
||||
interpolate_class->interpolate =
|
||||
vips_interpolate_nohalo_interpolate;
|
||||
|
@ -61,6 +61,6 @@ file.
|
||||
.SH COPYRIGHT
|
||||
National Gallery, 1993
|
||||
.SH SEE ALSO
|
||||
im_malloc(3), im_open_local(3).
|
||||
IM_REGION_ADDR(3), im_malloc(3), im_open_local(3).
|
||||
.SH AUTHOR
|
||||
J. Cupitt \- 23/7/93
|
||||
|
@ -58,6 +58,6 @@ file.
|
||||
.SH COPYRIGHT
|
||||
National Gallery, 1993
|
||||
.SH SEE ALSO
|
||||
im_malloc(3), im_open_local(3).
|
||||
IM_IMAGE_ADDR(3), im_malloc(3), im_open_local(3).
|
||||
.SH AUTHOR
|
||||
J. Cupitt \- 23/7/93
|
||||
|
Loading…
Reference in New Issue
Block a user