deprecate im_maxpos_avg()
and add wrappers for im_maxpos_vec() / im_minpos_vec()
This commit is contained in:
parent
a4433f1b9f
commit
5b271d16ed
4
TODO
4
TODO
@ -1,6 +1,6 @@
|
|||||||
- im_maxpos_vec()/im_minpos_vec() wrappers need doing
|
- add vips_band()/vips_bor()
|
||||||
|
|
||||||
|
|
||||||
- im_maxpos_avg() should be NaN-avoiding?
|
|
||||||
|
|
||||||
- now we've removed round-to-nearest from NN, we need something extra in the
|
- now we've removed round-to-nearest from NN, we need something extra in the
|
||||||
affine transform to displace the input cods
|
affine transform to displace the input cods
|
||||||
|
@ -7,7 +7,6 @@ libarithmetic_la_SOURCES = \
|
|||||||
deviate.c \
|
deviate.c \
|
||||||
divide.c \
|
divide.c \
|
||||||
im_linreg.c \
|
im_linreg.c \
|
||||||
im_maxpos_avg.c \
|
|
||||||
measure.c \
|
measure.c \
|
||||||
multiply.c \
|
multiply.c \
|
||||||
im_point_bilinear.c \
|
im_point_bilinear.c \
|
||||||
|
@ -6,6 +6,7 @@ libdeprecated_la_SOURCES = \
|
|||||||
deprecated_dispatch.c \
|
deprecated_dispatch.c \
|
||||||
colour_dispatch.c \
|
colour_dispatch.c \
|
||||||
arith_dispatch.c \
|
arith_dispatch.c \
|
||||||
|
im_maxpos_avg.c \
|
||||||
wrapvips7.c \
|
wrapvips7.c \
|
||||||
lazy.c \
|
lazy.c \
|
||||||
im_dif_std.c \
|
im_dif_std.c \
|
||||||
|
@ -2810,13 +2810,66 @@ im_quadratic( IMAGE *in, IMAGE *out, IMAGE *coeff )
|
|||||||
int
|
int
|
||||||
im_maxpos_vec( VipsImage *im, int *xpos, int *ypos, double *maxima, int n )
|
im_maxpos_vec( VipsImage *im, int *xpos, int *ypos, double *maxima, int n )
|
||||||
{
|
{
|
||||||
printf( "im_maxpos_vec: fixme\n" );
|
double max;
|
||||||
return( -1 );
|
VipsArrayDouble *out_array;
|
||||||
|
VipsArrayInt *x_array;
|
||||||
|
VipsArrayInt *y_array;
|
||||||
|
|
||||||
|
if( vips_max( im, &max,
|
||||||
|
"size", n,
|
||||||
|
"out_array", &out_array,
|
||||||
|
"x_array", &x_array,
|
||||||
|
"y_array", &y_array,
|
||||||
|
NULL ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
memcpy( xpos,
|
||||||
|
vips_area_get_data( x_array, NULL, NULL, NULL, NULL ),
|
||||||
|
n * sizeof( int ) );
|
||||||
|
memcpy( ypos,
|
||||||
|
vips_area_get_data( y_array, NULL, NULL, NULL, NULL ),
|
||||||
|
n * sizeof( int ) );
|
||||||
|
memcpy( maxima,
|
||||||
|
vips_area_get_data( out_array, NULL, NULL, NULL, NULL ),
|
||||||
|
n * sizeof( double ) );
|
||||||
|
|
||||||
|
vips_area_unref( (VipsArea *) out_array );
|
||||||
|
vips_area_unref( (VipsArea *) x_array );
|
||||||
|
vips_area_unref( (VipsArea *) y_array );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
im_minpos_vec( VipsImage *im, int *xpos, int *ypos, double *minima, int n )
|
im_minpos_vec( VipsImage *im, int *xpos, int *ypos, double *minima, int n )
|
||||||
{
|
{
|
||||||
printf( "im_minpos_vec: fixme\n" );
|
double min;
|
||||||
return( -1 );
|
VipsArrayDouble *out_array;
|
||||||
|
VipsArrayInt *x_array;
|
||||||
|
VipsArrayInt *y_array;
|
||||||
|
|
||||||
|
if( vips_min( im, &min,
|
||||||
|
"size", n,
|
||||||
|
"out_array", &out_array,
|
||||||
|
"x_array", &x_array,
|
||||||
|
"y_array", &y_array,
|
||||||
|
NULL ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
memcpy( xpos,
|
||||||
|
vips_area_get_data( x_array, NULL, NULL, NULL, NULL ),
|
||||||
|
n * sizeof( int ) );
|
||||||
|
memcpy( ypos,
|
||||||
|
vips_area_get_data( y_array, NULL, NULL, NULL, NULL ),
|
||||||
|
n * sizeof( int ) );
|
||||||
|
memcpy( minima,
|
||||||
|
vips_area_get_data( out_array, NULL, NULL, NULL, NULL ),
|
||||||
|
n * sizeof( double ) );
|
||||||
|
|
||||||
|
vips_area_unref( (VipsArea *) out_array );
|
||||||
|
vips_area_unref( (VipsArea *) x_array );
|
||||||
|
vips_area_unref( (VipsArea *) y_array );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -360,11 +360,6 @@ int vips_stats( VipsImage *in, VipsImage **out, ... )
|
|||||||
int vips_measure( VipsImage *in, VipsImage **out, int h, int v, ... )
|
int vips_measure( VipsImage *in, VipsImage **out, int h, int v, ... )
|
||||||
__attribute__((sentinel));
|
__attribute__((sentinel));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int im_maxpos_avg( VipsImage *im, double *xpos, double *ypos, double *out );
|
|
||||||
|
|
||||||
int im_linreg( VipsImage **ins, VipsImage *out, double *xs );
|
int im_linreg( VipsImage **ins, VipsImage *out, double *xs );
|
||||||
int im_point( VipsImage *im, VipsInterpolate *interpolate,
|
int im_point( VipsImage *im, VipsInterpolate *interpolate,
|
||||||
double x, double y, int band, double *out );
|
double x, double y, int band, double *out );
|
||||||
|
@ -667,6 +667,8 @@ int im_moreeqconst( VipsImage *in, VipsImage *out, double c );
|
|||||||
int im_maxpos_vec( VipsImage *im, int *xpos, int *ypos, double *maxima, int n );
|
int im_maxpos_vec( VipsImage *im, int *xpos, int *ypos, double *maxima, int n );
|
||||||
int im_minpos_vec( VipsImage *im, int *xpos, int *ypos, double *minima, int n );
|
int im_minpos_vec( VipsImage *im, int *xpos, int *ypos, double *minima, int n );
|
||||||
|
|
||||||
|
int im_maxpos_avg( VipsImage *im, double *xpos, double *ypos, double *out );
|
||||||
|
|
||||||
int im_copy( VipsImage *in, VipsImage *out );
|
int im_copy( VipsImage *in, VipsImage *out );
|
||||||
int im_copy_set( VipsImage *in, VipsImage *out,
|
int im_copy_set( VipsImage *in, VipsImage *out,
|
||||||
VipsInterpretation interpretation,
|
VipsInterpretation interpretation,
|
||||||
|
Loading…
Reference in New Issue
Block a user