set of overloads for new cpp API
all the usual ones .. compiles, but untested
This commit is contained in:
parent
4173ddfa9c
commit
d6a6d7ae71
7
TODO
7
TODO
@ -1,3 +1,5 @@
|
|||||||
|
- need a thing to test overloads
|
||||||
|
|
||||||
- test other arg types
|
- test other arg types
|
||||||
|
|
||||||
input int works
|
input int works
|
||||||
@ -16,11 +18,6 @@
|
|||||||
output imagevec
|
output imagevec
|
||||||
output blob
|
output blob
|
||||||
|
|
||||||
- set of overloads
|
|
||||||
|
|
||||||
- something to make an image from an array of constants, need to set
|
|
||||||
scale/offset too
|
|
||||||
|
|
||||||
- new_from_buffer(), new_from_memory(), write_to_memory() etc etc
|
- new_from_buffer(), new_from_memory(), write_to_memory() etc etc
|
||||||
|
|
||||||
|
|
||||||
|
@ -43,6 +43,54 @@
|
|||||||
|
|
||||||
VIPS_NAMESPACE_START
|
VIPS_NAMESPACE_START
|
||||||
|
|
||||||
|
std::vector<double> to_vectorv( int n, ... )
|
||||||
|
{
|
||||||
|
std::vector<double> vector( n );
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start( ap, n );
|
||||||
|
for( int i = 0; i < n; i++ )
|
||||||
|
vector[i] = va_arg( ap, double );
|
||||||
|
va_end( ap );
|
||||||
|
|
||||||
|
return( vector );
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<double> to_vector( double value )
|
||||||
|
{
|
||||||
|
return( to_vectorv( 1, value ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<double> to_vector( int n, double array[] )
|
||||||
|
{
|
||||||
|
std::vector<double> vector( n );
|
||||||
|
|
||||||
|
for( int i = 0; i < n; i++ )
|
||||||
|
vector[i] = array[i];
|
||||||
|
|
||||||
|
return( vector );
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<double> negate( std::vector<double> vector )
|
||||||
|
{
|
||||||
|
std::vector<double> new_vector( vector.size() );
|
||||||
|
|
||||||
|
for( unsigned int i = 0; i < vector.size(); i++ )
|
||||||
|
new_vector[i] = vector[i] * -1;
|
||||||
|
|
||||||
|
return( new_vector );
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<double> invert( std::vector<double> vector )
|
||||||
|
{
|
||||||
|
std::vector<double> new_vector( vector.size() );
|
||||||
|
|
||||||
|
for( unsigned int i = 0; i < vector.size(); i++ )
|
||||||
|
new_vector[i] = 1.0 / vector[i];
|
||||||
|
|
||||||
|
return( new_vector );
|
||||||
|
}
|
||||||
|
|
||||||
VOption::~VOption()
|
VOption::~VOption()
|
||||||
{
|
{
|
||||||
std::list<Pair *>::iterator i;
|
std::list<Pair *>::iterator i;
|
||||||
@ -424,10 +472,7 @@ VImage VImage::new_from_image( std::vector<double> pixel )
|
|||||||
VImage onepx = VImage::black( 1, 1,
|
VImage onepx = VImage::black( 1, 1,
|
||||||
VImage::option()->set( "bands", bands() ) );
|
VImage::option()->set( "bands", bands() ) );
|
||||||
|
|
||||||
double v[1] = { 1.0 };
|
onepx = onepx.linear( to_vectorv( 1, 1.0 ), pixel ).cast( format() );
|
||||||
std::vector<double> ones( v, v + VIPS_NUMBER( v ) );
|
|
||||||
|
|
||||||
onepx = onepx.linear( ones, pixel ).cast( format() );
|
|
||||||
|
|
||||||
VImage big = onepx.embed( 0, 0, width(), height(),
|
VImage big = onepx.embed( 0, 0, width(), height(),
|
||||||
VImage::option()->set( "extend", VIPS_EXTEND_COPY ) );
|
VImage::option()->set( "extend", VIPS_EXTEND_COPY ) );
|
||||||
@ -446,10 +491,29 @@ VImage VImage::new_from_image( std::vector<double> pixel )
|
|||||||
VImage VImage::new_from_image( double pixel )
|
VImage VImage::new_from_image( double pixel )
|
||||||
throw( VError )
|
throw( VError )
|
||||||
{
|
{
|
||||||
double v[1] = { pixel };
|
return( new_from_image( to_vectorv( 1, pixel ) ) );
|
||||||
std::vector<double> vec( v, v + VIPS_NUMBER( v ) );
|
}
|
||||||
|
|
||||||
return( new_from_image( vec ) );
|
VImage VImage::new_matrix( int width, int height )
|
||||||
|
{
|
||||||
|
return( VImage( vips_image_new_matrix( width, height ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage VImage::new_matrixv( int width, int height, ... )
|
||||||
|
{
|
||||||
|
VImage matrix = new_matrix( width, height );
|
||||||
|
VipsImage *vips_matrix = matrix.get_image();
|
||||||
|
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start( ap, height );
|
||||||
|
for( int y = 0; y < height; y++ )
|
||||||
|
for( int x = 0; x < width; x++ )
|
||||||
|
*VIPS_MATRIX( vips_matrix, x, y ) =
|
||||||
|
va_arg( ap, double );
|
||||||
|
va_end( ap );
|
||||||
|
|
||||||
|
return( matrix );
|
||||||
}
|
}
|
||||||
|
|
||||||
void VImage::write_to_file( const char *name, VOption *options )
|
void VImage::write_to_file( const char *name, VOption *options )
|
||||||
@ -473,27 +537,6 @@ void VImage::write_to_file( const char *name, VOption *options )
|
|||||||
|
|
||||||
#include "vips-operators.cc"
|
#include "vips-operators.cc"
|
||||||
|
|
||||||
VImage VImage::linear( double a, double b, VOption *options )
|
|
||||||
throw( VError )
|
|
||||||
{
|
|
||||||
double av[1] = { a };
|
|
||||||
std::vector<double> avec( av, av + VIPS_NUMBER( av ) );
|
|
||||||
|
|
||||||
double bv[1] = { b };
|
|
||||||
std::vector<double> bvec( bv, bv + VIPS_NUMBER( bv ) );
|
|
||||||
|
|
||||||
VImage out;
|
|
||||||
|
|
||||||
call( "linear",
|
|
||||||
(options ? options : VImage::option()) ->
|
|
||||||
set( "out", &out ) ->
|
|
||||||
set( "in", *this ) ->
|
|
||||||
set( "a", avec ) ->
|
|
||||||
set( "b", bvec ) );
|
|
||||||
|
|
||||||
return( out );
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<VImage> VImage::bandsplit( VOption *options )
|
std::vector<VImage> VImage::bandsplit( VOption *options )
|
||||||
throw( VError )
|
throw( VError )
|
||||||
{
|
{
|
||||||
|
@ -38,6 +38,15 @@
|
|||||||
|
|
||||||
VIPS_NAMESPACE_START
|
VIPS_NAMESPACE_START
|
||||||
|
|
||||||
|
/* Small utility things.
|
||||||
|
*/
|
||||||
|
|
||||||
|
std::vector<double> to_vectorv( int n, ... );
|
||||||
|
std::vector<double> to_vector( double value );
|
||||||
|
std::vector<double> to_vector( int n, double array[] );
|
||||||
|
std::vector<double> negate( std::vector<double> value );
|
||||||
|
std::vector<double> invert( std::vector<double> value );
|
||||||
|
|
||||||
enum VSteal {
|
enum VSteal {
|
||||||
NOSTEAL = 0,
|
NOSTEAL = 0,
|
||||||
STEAL = 1
|
STEAL = 1
|
||||||
@ -324,6 +333,77 @@ public:
|
|||||||
return( vips_image_get_data( get_image() ) );
|
return( vips_image_get_data( get_image() ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void set( const char *field, int value )
|
||||||
|
{
|
||||||
|
vips_image_set_int( this->get_image(), field, value );
|
||||||
|
}
|
||||||
|
|
||||||
|
void set( const char *field, double value )
|
||||||
|
{
|
||||||
|
vips_image_set_double( this->get_image(), field, value );
|
||||||
|
}
|
||||||
|
|
||||||
|
void set( const char *field, const char *value )
|
||||||
|
{
|
||||||
|
vips_image_set_string( this->get_image(), field, value );
|
||||||
|
}
|
||||||
|
|
||||||
|
void set( const char *field,
|
||||||
|
VipsCallbackFn free_fn, void *data, size_t length )
|
||||||
|
{
|
||||||
|
vips_image_set_blob( this->get_image(), field,
|
||||||
|
free_fn, data, length );
|
||||||
|
}
|
||||||
|
|
||||||
|
int get_typeof( const char *field )
|
||||||
|
{
|
||||||
|
return( vips_image_get_typeof( this->get_image(), field ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
int get_int( const char *field )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
int value;
|
||||||
|
|
||||||
|
if( vips_image_get_int( this->get_image(), field, &value ) )
|
||||||
|
throw( VError() );
|
||||||
|
|
||||||
|
return( value );
|
||||||
|
}
|
||||||
|
|
||||||
|
double get_double( const char *field )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
double value;
|
||||||
|
|
||||||
|
if( vips_image_get_double( this->get_image(), field, &value ) )
|
||||||
|
throw( VError() );
|
||||||
|
|
||||||
|
return( value );
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *get_string( const char *field )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
const char *value;
|
||||||
|
|
||||||
|
if( vips_image_get_string( this->get_image(), field, &value ) )
|
||||||
|
throw( VError() );
|
||||||
|
|
||||||
|
return( value );
|
||||||
|
}
|
||||||
|
|
||||||
|
const void *get_blob( const char *field, size_t *length )
|
||||||
|
{
|
||||||
|
void *value;
|
||||||
|
|
||||||
|
if( vips_image_get_blob( this->get_image(), field,
|
||||||
|
&value, length ) )
|
||||||
|
throw( VError() );
|
||||||
|
|
||||||
|
return( value );
|
||||||
|
}
|
||||||
|
|
||||||
static VOption *option()
|
static VOption *option()
|
||||||
{
|
{
|
||||||
return( new VOption() );
|
return( new VOption() );
|
||||||
@ -341,6 +421,8 @@ public:
|
|||||||
throw( VError );
|
throw( VError );
|
||||||
VImage new_from_image( double pixel )
|
VImage new_from_image( double pixel )
|
||||||
throw( VError );
|
throw( VError );
|
||||||
|
VImage new_matrix( int width, int height ) ;
|
||||||
|
VImage new_matrixv( int width, int height, ... );
|
||||||
|
|
||||||
void write_to_file( const char *name, VOption *options = 0 )
|
void write_to_file( const char *name, VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError );
|
||||||
@ -348,15 +430,41 @@ public:
|
|||||||
#include "vips-operators.h"
|
#include "vips-operators.h"
|
||||||
|
|
||||||
// a few useful things
|
// a few useful things
|
||||||
|
|
||||||
VImage linear( double a, double b, VOption *options = 0 )
|
VImage linear( double a, double b, VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( this->linear( to_vector( a ), to_vector( b ),
|
||||||
|
options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage linear( std::vector<double> a, double b, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( this->linear( a, to_vector( b ), options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage linear( double a, std::vector<double> b, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( this->linear( to_vector( a ), b, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
std::vector<VImage> bandsplit( VOption *options = 0 )
|
std::vector<VImage> bandsplit( VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError );
|
||||||
|
|
||||||
VImage bandjoin( VImage other, VOption *options = 0 )
|
VImage bandjoin( VImage other, VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError );
|
||||||
|
VImage bandjoin( double other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( bandjoin( this->new_from_image( other ), options ) );
|
||||||
|
}
|
||||||
|
VImage bandjoin( std::vector<double> other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( bandjoin( this->new_from_image( other ), options ) );
|
||||||
|
}
|
||||||
|
|
||||||
std::complex<double> minpos( VOption *options = 0 )
|
std::complex<double> minpos( VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError );
|
||||||
@ -472,24 +580,570 @@ public:
|
|||||||
return( math( VIPS_OPERATION_MATH_EXP10, options ) );
|
return( math( VIPS_OPERATION_MATH_EXP10, options ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
VImage pow( VImage other, VOption *options = 0 )
|
||||||
VImage ifthenelse( double th, VImage el, VOption *options = 0 )
|
throw( VError )
|
||||||
throw( VError );
|
{
|
||||||
VImage ifthenelse( VImage th, double el, VOption *options = 0 )
|
return( math2( other, VIPS_OPERATION_MATH2_POW, options ) );
|
||||||
throw( VError );
|
}
|
||||||
VImage ifthenelse( double th, double el, VOption *options = 0 )
|
|
||||||
throw( VError );
|
VImage pow( double other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( math2_const( to_vector( other ),
|
||||||
|
VIPS_OPERATION_MATH2_POW, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage pow( std::vector<double> other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( math2_const( other,
|
||||||
|
VIPS_OPERATION_MATH2_POW, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage wop( VImage other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( math2( other, VIPS_OPERATION_MATH2_WOP, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage wop( double other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( math2_const( to_vector( other ),
|
||||||
|
VIPS_OPERATION_MATH2_WOP, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage wop( std::vector<double> other, VOption *options = 0 )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( math2_const( other,
|
||||||
|
VIPS_OPERATION_MATH2_WOP, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
VImage ifthenelse( std::vector<double> th, VImage el,
|
VImage ifthenelse( std::vector<double> th, VImage el,
|
||||||
VOption *options = 0 )
|
VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( ifthenelse( el.new_from_image( th ), el, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
VImage ifthenelse( VImage th, std::vector<double> el,
|
VImage ifthenelse( VImage th, std::vector<double> el,
|
||||||
VOption *options = 0 )
|
VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( ifthenelse( th, th.new_from_image( el ), options ) );
|
||||||
|
}
|
||||||
|
|
||||||
VImage ifthenelse( std::vector<double> th, std::vector<double> el,
|
VImage ifthenelse( std::vector<double> th, std::vector<double> el,
|
||||||
VOption *options = 0 )
|
VOption *options = 0 )
|
||||||
throw( VError );
|
throw( VError )
|
||||||
*/
|
{
|
||||||
|
return( ifthenelse( new_from_image( th ), new_from_image( el ),
|
||||||
|
options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage ifthenelse( double th, VImage el, VOption *options )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( ifthenelse( to_vector( th ), el, options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage ifthenelse( VImage th, double el, VOption *options )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( ifthenelse( th, to_vector( el ), options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
VImage ifthenelse( double th, double el, VOption *options )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( ifthenelse( to_vector( th ), to_vector( el ),
|
||||||
|
options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Operator overloads
|
||||||
|
|
||||||
|
friend VImage operator+( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.add( b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator+( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.linear( 1.0, a ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator+( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( 1.0, b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator+( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.linear( 1.0, a ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator+( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( 1.0, b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator-( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.subtract( b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator-( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.linear( -1.0, a ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator-( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( 1.0, -b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator-( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.linear( -1.0, a ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator-( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( 1.0, vips8::negate( b ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator*( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.multiply( b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator*( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.linear( a, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator*( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( b, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator*( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.linear( a, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator*( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( b, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator/( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.divide( b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator/( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.pow( -1.0 ).linear( a, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator/( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( 1.0 / b, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator/( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.pow( -1.0 ).linear( a, 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator/( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.linear( vips8::invert( b ), 0.0 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator%( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.remainder( b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator%( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.remainder_const( to_vector( b ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator%( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.remainder_const( b ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational( b, VIPS_OPERATION_RELATIONAL_LESS ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_MORE ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESS ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( a,
|
||||||
|
VIPS_OPERATION_RELATIONAL_MORE ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( b,
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESS ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<=( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational( b, VIPS_OPERATION_RELATIONAL_LESSEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<=( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_MOREEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<=( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESSEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<=( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( a,
|
||||||
|
VIPS_OPERATION_RELATIONAL_MOREEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<=( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( b,
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESSEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational( b, VIPS_OPERATION_RELATIONAL_MORE ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESS ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_MORE ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( a,
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESS ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( b,
|
||||||
|
VIPS_OPERATION_RELATIONAL_MORE ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>=( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational( b, VIPS_OPERATION_RELATIONAL_MOREEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>=( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESSEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>=( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_MOREEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>=( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( a,
|
||||||
|
VIPS_OPERATION_RELATIONAL_LESSEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>=( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( b,
|
||||||
|
VIPS_OPERATION_RELATIONAL_MOREEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator==( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational( b, VIPS_OPERATION_RELATIONAL_EQUAL ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator==( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_EQUAL ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator==( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_EQUAL ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator==( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( a,
|
||||||
|
VIPS_OPERATION_RELATIONAL_EQUAL ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator==( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( b,
|
||||||
|
VIPS_OPERATION_RELATIONAL_EQUAL ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator!=( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational( b, VIPS_OPERATION_RELATIONAL_NOTEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator!=( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_NOTEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator!=( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_RELATIONAL_NOTEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator!=( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.relational_const( a,
|
||||||
|
VIPS_OPERATION_RELATIONAL_NOTEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator!=( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.relational_const( b,
|
||||||
|
VIPS_OPERATION_RELATIONAL_NOTEQ ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator&( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean( b, VIPS_OPERATION_BOOLEAN_AND ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator&( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.boolean_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_AND ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator&( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_AND ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator&( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.boolean_const( a, VIPS_OPERATION_BOOLEAN_AND ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator&( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( b, VIPS_OPERATION_BOOLEAN_AND ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator|( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean( b, VIPS_OPERATION_BOOLEAN_OR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator|( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.boolean_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_OR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator|( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_OR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator|( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.boolean_const( a, VIPS_OPERATION_BOOLEAN_OR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator|( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( b, VIPS_OPERATION_BOOLEAN_OR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator^( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean( b, VIPS_OPERATION_BOOLEAN_EOR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator^( double a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.boolean_const( to_vector( a ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_EOR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator^( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_EOR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator^( std::vector<double> a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( b.boolean_const( a, VIPS_OPERATION_BOOLEAN_EOR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator^( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( b, VIPS_OPERATION_BOOLEAN_EOR ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<<( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean( b, VIPS_OPERATION_BOOLEAN_LSHIFT ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<<( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_LSHIFT ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator<<( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( b, VIPS_OPERATION_BOOLEAN_LSHIFT ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>>( VImage a, VImage b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean( b, VIPS_OPERATION_BOOLEAN_RSHIFT ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>>( VImage a, double b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( to_vector( b ),
|
||||||
|
VIPS_OPERATION_BOOLEAN_RSHIFT ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator>>( VImage a, std::vector<double> b )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a.boolean_const( b, VIPS_OPERATION_BOOLEAN_RSHIFT ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
friend VImage operator-( VImage a )
|
||||||
|
throw( VError )
|
||||||
|
{
|
||||||
|
return( a * -1 );
|
||||||
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user