stuff
This commit is contained in:
parent
8d7071c0a2
commit
ea2285f315
18
TODO
18
TODO
@ -2,16 +2,11 @@
|
|||||||
|
|
||||||
- shouldn't it be im_remainder_vec()?
|
- shouldn't it be im_remainder_vec()?
|
||||||
|
|
||||||
- im_add(), im_subtract() etc. could all be in one file and share macros like
|
im_remainderconst_vec() is better? cf.
|
||||||
boolean.c
|
|
||||||
|
|
||||||
quite hard, because of things like complex *, / and liboil
|
im_andimage()
|
||||||
|
im_andimageconst()
|
||||||
- rint/ceil/floor can all common up too
|
im_andimage_vec()
|
||||||
|
|
||||||
- powtra, expntra as well
|
|
||||||
|
|
||||||
- im__math() no longer needs to be global?
|
|
||||||
|
|
||||||
- booolean needs gtkdoc
|
- booolean needs gtkdoc
|
||||||
|
|
||||||
@ -30,6 +25,11 @@
|
|||||||
|
|
||||||
- Joe's new def
|
- Joe's new def
|
||||||
|
|
||||||
|
- im_add(), im_subtract() etc. could all be in one file and share macros like
|
||||||
|
boolean.c
|
||||||
|
|
||||||
|
quite hard, because of things like complex *, / and liboil
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -5,27 +5,26 @@ libarithmetic_la_SOURCES = \
|
|||||||
im_abs.c \
|
im_abs.c \
|
||||||
im_add.c \
|
im_add.c \
|
||||||
im_avg.c \
|
im_avg.c \
|
||||||
im_point_bilinear.c \
|
|
||||||
im_bandmean.c \
|
im_bandmean.c \
|
||||||
im_cross_phase.c \
|
im_cross_phase.c \
|
||||||
im_deviate.c \
|
im_deviate.c \
|
||||||
im_divide.c \
|
im_divide.c \
|
||||||
im_expntra.c \
|
|
||||||
im_invert.c \
|
im_invert.c \
|
||||||
im_linreg.c \
|
im_linreg.c \
|
||||||
im_lintra.c \
|
im_lintra.c \
|
||||||
im_maxpos.c \
|
|
||||||
im_maxpos_avg.c \
|
im_maxpos_avg.c \
|
||||||
|
im_maxpos.c \
|
||||||
im_maxpos_vec.c \
|
im_maxpos_vec.c \
|
||||||
im_measure.c \
|
im_measure.c \
|
||||||
im_minpos.c \
|
im_minpos.c \
|
||||||
im_multiply.c \
|
im_multiply.c \
|
||||||
im_powtra.c \
|
im_point_bilinear.c \
|
||||||
im_remainder.c \
|
im_remainder.c \
|
||||||
round.c \
|
|
||||||
im_sign.c \
|
im_sign.c \
|
||||||
math.c \
|
|
||||||
im_stats.c \
|
im_stats.c \
|
||||||
im_subtract.c
|
im_subtract.c \
|
||||||
|
math.c \
|
||||||
|
power.c \
|
||||||
|
round.c
|
||||||
|
|
||||||
INCLUDES = -I${top_srcdir}/libvips/include @VIPS_CFLAGS@ @VIPS_INCLUDES@
|
INCLUDES = -I${top_srcdir}/libvips/include @VIPS_CFLAGS@ @VIPS_INCLUDES@
|
||||||
|
@ -57,6 +57,7 @@
|
|||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
#include <vips/vips.h>
|
#include <vips/vips.h>
|
||||||
|
#include <vips/internal.h>
|
||||||
|
|
||||||
#ifdef WITH_DMALLOC
|
#ifdef WITH_DMALLOC
|
||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
@ -75,9 +76,9 @@
|
|||||||
|
|
||||||
/* Operator with a single constant on a buffer.
|
/* Operator with a single constant on a buffer.
|
||||||
*/
|
*/
|
||||||
#define CONST1_BUFFER( NAME, FUN ) \
|
#define CONST1_BUFFER( FUN ) \
|
||||||
static void \
|
static void \
|
||||||
NAME ## 1_buffer( PEL *p, PEL *q, int n, PEL *vector, IMAGE *im ) \
|
FUN ## 1_buffer( PEL *p, PEL *q, int n, PEL *vector, IMAGE *im ) \
|
||||||
{ \
|
{ \
|
||||||
/* Complex just doubles the size. \
|
/* Complex just doubles the size. \
|
||||||
*/ \
|
*/ \
|
||||||
@ -165,12 +166,12 @@ FUN ## n_buffer( PEL *p, PEL *q, int n, PEL *vector, IMAGE *im ) \
|
|||||||
double x = (double) (X); \
|
double x = (double) (X); \
|
||||||
double e = (double) (E); \
|
double e = (double) (E); \
|
||||||
\
|
\
|
||||||
if( f == 0.0 && e < 0.0 ) \
|
if( x == 0.0 && e < 0.0 ) \
|
||||||
/* Division by zero! Difficult to report tho' \
|
/* Division by zero! Difficult to report tho' \
|
||||||
*/ \
|
*/ \
|
||||||
(Y) = 0.0; \
|
(Y) = 0.0; \
|
||||||
else \
|
else \
|
||||||
(Y) = pow( f, e ); \
|
(Y) = pow( x, e ); \
|
||||||
}
|
}
|
||||||
|
|
||||||
CONST1_BUFFER( POW )
|
CONST1_BUFFER( POW )
|
||||||
@ -179,12 +180,10 @@ CONSTN_BUFFER( POW )
|
|||||||
|
|
||||||
/* Save a bit of typing.
|
/* Save a bit of typing.
|
||||||
*/
|
*/
|
||||||
#define UC IM_BANDFMT_UCHAR
|
#define F IM_BANDFMT_FLOAT
|
||||||
#define C IM_BANDFMT_CHAR
|
#define X IM_BANDFMT_COMPLEX
|
||||||
#define US IM_BANDFMT_USHORT
|
#define D IM_BANDFMT_DOUBLE
|
||||||
#define S IM_BANDFMT_SHORT
|
#define DX IM_BANDFMT_DPCOMPLEX
|
||||||
#define UI IM_BANDFMT_UINT
|
|
||||||
#define I IM_BANDFMT_INT
|
|
||||||
|
|
||||||
/* Type conversions for boolean.
|
/* Type conversions for boolean.
|
||||||
*/
|
*/
|
||||||
|
@ -140,7 +140,6 @@ int im__arith_binary_const( const char *name,
|
|||||||
IMAGE *in, IMAGE *out, int n, double *c,
|
IMAGE *in, IMAGE *out, int n, double *c,
|
||||||
int format_table[10],
|
int format_table[10],
|
||||||
im_wrapone_fn fn1, im_wrapone_fn fnn );
|
im_wrapone_fn fn1, im_wrapone_fn fnn );
|
||||||
int im__math( const char *name, IMAGE *in, IMAGE *out, im_wrapone_fn gen );
|
|
||||||
int im__value( IMAGE *im, double *value );
|
int im__value( IMAGE *im, double *value );
|
||||||
typedef int (*im__wrapscan_fn)( void *p, int n, void *seq, void *a, void *b );
|
typedef int (*im__wrapscan_fn)( void *p, int n, void *seq, void *a, void *b );
|
||||||
int im__wrapscan( IMAGE *in,
|
int im__wrapscan( IMAGE *in,
|
||||||
|
Loading…
Reference in New Issue
Block a user