Merge branch 'master' of github.com:libvips/libvips

This commit is contained in:
John Cupitt 2020-07-14 10:26:46 +01:00
commit cc3682cb79
15 changed files with 98 additions and 29 deletions

View File

@ -5309,6 +5309,32 @@ im_remosaic( IMAGE *in, IMAGE *out, const char *old_str, const char *new_str )
return( 0 ); return( 0 );
} }
int
im_lrmosaic( IMAGE *ref, IMAGE *sec, IMAGE *out,
int bandno,
int xref, int yref, int xsec, int ysec,
int hwindowsize, int hsearchsize,
int balancetype,
int mwidth )
{
VipsImage *x;
if( vips_mosaic( ref, sec, &x, VIPS_DIRECTION_HORIZONTAL,
xref, yref, xsec, ysec,
"hwindow", hwindowsize,
"harea", hsearchsize,
"mblend", mwidth,
NULL ) )
return( -1 );
if( vips_image_write( x, out ) ) {
g_object_unref( x );
return( -1 );
}
g_object_unref( x );
return( 0 );
}
int int
im_lrmosaic1( IMAGE *ref, IMAGE *sec, IMAGE *out, im_lrmosaic1( IMAGE *ref, IMAGE *sec, IMAGE *out,
int bandno, int bandno,
@ -5338,6 +5364,32 @@ im_lrmosaic1( IMAGE *ref, IMAGE *sec, IMAGE *out,
return( 0 ); return( 0 );
} }
int
im_tbmosaic( IMAGE *ref, IMAGE *sec, IMAGE *out,
int bandno,
int xref, int yref, int xsec, int ysec,
int hwindowsize, int hsearchsize,
int balancetype,
int mwidth )
{
VipsImage *x;
if( vips_mosaic( ref, sec, &x, VIPS_DIRECTION_VERTICAL,
xref, yref, xsec, ysec,
"hwindow", hwindowsize,
"harea", hsearchsize,
"mblend", mwidth,
NULL ) )
return( -1 );
if( vips_image_write( x, out ) ) {
g_object_unref( x );
return( -1 );
}
g_object_unref( x );
return( 0 );
}
int int
im_tbmosaic1( IMAGE *ref, IMAGE *sec, IMAGE *out, im_tbmosaic1( IMAGE *ref, IMAGE *sec, IMAGE *out,
int bandno, int bandno,
@ -5367,6 +5419,16 @@ im_tbmosaic1( IMAGE *ref, IMAGE *sec, IMAGE *out,
return( 0 ); return( 0 );
} }
int
im_correl( VipsImage *ref, VipsImage *sec,
int xref, int yref, int xsec, int ysec,
int hwindowsize, int hsearchsize,
double *correlation, int *x, int *y )
{
return( vips__correl( ref, sec, xref, yref, xsec, ysec,
hwindowsize, hsearchsize, correlation, x, y ) );
}
int int
im_lrmerge( IMAGE *ref, IMAGE *sec, IMAGE *out, im_lrmerge( IMAGE *ref, IMAGE *sec, IMAGE *out,
int dx, int dy, int mwidth ) int dx, int dy, int mwidth )

View File

@ -31,8 +31,8 @@
*/ */
#ifndef IM_MOSAICING_H #ifndef VIPS_MOSAICING_H
#define IM_MOSAICING_H #define VIPS_MOSAICING_H
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -70,4 +70,4 @@ int vips_matrixinvert( VipsImage *m, VipsImage **out, ... )
} }
#endif /*__cplusplus*/ #endif /*__cplusplus*/
#endif /*IM_MOSAICING_H*/ #endif /*VIPS_MOSAICING_H*/

View File

@ -1078,6 +1078,12 @@ int im_tbmerge1( VipsImage *ref, VipsImage *sec, VipsImage *out,
int xr2, int yr2, int xs2, int ys2, int xr2, int yr2, int xs2, int ys2,
int mwidth ); int mwidth );
int im_lrmosaic( VipsImage *ref, VipsImage *sec, VipsImage *out,
int bandno,
int xref, int yref, int xsec, int ysec,
int hwindowsize, int hsearchsize,
int balancetype,
int mwidth );
int im_lrmosaic1( VipsImage *ref, VipsImage *sec, VipsImage *out, int im_lrmosaic1( VipsImage *ref, VipsImage *sec, VipsImage *out,
int bandno, int bandno,
int xr1, int yr1, int xs1, int ys1, int xr1, int yr1, int xs1, int ys1,
@ -1085,6 +1091,12 @@ int im_lrmosaic1( VipsImage *ref, VipsImage *sec, VipsImage *out,
int hwindowsize, int hsearchsize, int hwindowsize, int hsearchsize,
int balancetype, int balancetype,
int mwidth ); int mwidth );
int im_tbmosaic( VipsImage *ref, VipsImage *sec, VipsImage *out,
int bandno,
int xref, int yref, int xsec, int ysec,
int hwindowsize, int hsearchsize,
int balancetype,
int mwidth );
int im_tbmosaic1( VipsImage *ref, VipsImage *sec, VipsImage *out, int im_tbmosaic1( VipsImage *ref, VipsImage *sec, VipsImage *out,
int bandno, int bandno,
int xr1, int yr1, int xs1, int ys1, int xr1, int yr1, int xs1, int ys1,

View File

@ -174,8 +174,8 @@ vips__global_open_image( SymbolTable *st, char *name )
if( !(image = vips_image_new_from_file( name, NULL ))) { if( !(image = vips_image_new_from_file( name, NULL ))) {
/* TODO(kleisauke): Is this behavior the same as im_skip_dir? /* TODO(kleisauke): Is this behavior the same as im_skip_dir?
* i.e. could we open a filename which came * i.e. could we open a filename which came
* from a win32 (`\\`) on a *nix machine? */ * from a win32 (`\\`) on a *nix machine? */
basename = g_path_get_basename( name ); basename = g_path_get_basename( name );
if( !(image = vips_image_new_from_file( basename, NULL ))) { if( !(image = vips_image_new_from_file( basename, NULL ))) {

View File

@ -47,8 +47,8 @@ typedef VipsImage *(*transform_fn)( JoinNode *, void * );
/* Join type. /* Join type.
*/ */
enum _JoinType { enum _JoinType {
JOIN_LR, /* vips_lrmerge join */ JOIN_LR, /* vips__lrmerge join */
JOIN_TB, /* vips_tbmerge join */ JOIN_TB, /* vips__tbmerge join */
JOIN_LRROTSCALE, /* 1st oder lrmerge */ JOIN_LRROTSCALE, /* 1st oder lrmerge */
JOIN_TBROTSCALE, /* 1st oder tbmerge */ JOIN_TBROTSCALE, /* 1st oder tbmerge */
JOIN_CP, /* vips_copy operation */ JOIN_CP, /* vips_copy operation */

View File

@ -3,11 +3,11 @@
* @(#) The rounded integer result is returned into dx, dy * @(#) The rounded integer result is returned into dx, dy
* @(#) No images are involved in this function. * @(#) No images are involved in this function.
* @(#) * @(#)
* @(#) int vips_avgdxdy( points, dx, dy ) * @(#) int vips__avgdxdy( points, dx, dy )
* @(#) TiePoints *points; * @(#) TiePoints *points;
* @(#) int *dx, *dy; * @(#) int *dx, *dy;
* @(#) * @(#)
* @(#) Returns 0 on sucess and -1 on error. * @(#) Returns 0 on success and -1 on error.
* *
* Copyright: 1990, N. Dessipris. * Copyright: 1990, N. Dessipris.
* *
@ -62,7 +62,7 @@ vips__avgdxdy( TiePoints *points, int *dx, int *dy )
int i; int i;
if( points->nopoints == 0 ) { if( points->nopoints == 0 ) {
vips_error( "vips_avgdxdy", "%s", _( "no points to average" ) ); vips_error( "vips__avgdxdy", "%s", _( "no points to average" ) );
return( -1 ); return( -1 );
} }

View File

@ -10,7 +10,7 @@
* @(#) int vips__improve( inpoints, outpoints ) * @(#) int vips__improve( inpoints, outpoints )
* @(#) TiePoints *inpoints, *outpoints; * @(#) TiePoints *inpoints, *outpoints;
* @(#) * @(#)
* @(#) Returns 0 on sucess and -1 on error. * @(#) Returns 0 on success and -1 on error.
* *
* Copyright: 1990, N. Dessipris. * Copyright: 1990, N. Dessipris.
* *

View File

@ -8,7 +8,7 @@
* @(#) Results are saved in the structure points * @(#) Results are saved in the structure points
* @(#) The function expects the following valid data in points: * @(#) The function expects the following valid data in points:
* @(#) deltax, deltay, nopoints, halfcorsize, halfareasize * @(#) deltax, deltay, nopoints, halfcorsize, halfareasize
* @(#) and fills in the memebers: * @(#) and fills in the members:
* @(#) x, y_reference[], contrast and x,y_secondary[], * @(#) x, y_reference[], contrast and x,y_secondary[],
* @(#) based on deltax and deltay * @(#) based on deltax and deltay
* @(#) Input image should are either memory mapped or in a buffer. * @(#) Input image should are either memory mapped or in a buffer.

View File

@ -22,7 +22,7 @@
* @(#) int bandno; * @(#) int bandno;
* @(#) TiePoints *points; see mosaic.h * @(#) TiePoints *points; see mosaic.h
* @(#) * @(#)
* @(#) Returns 0 on sucess and -1 on error. * @(#) Returns 0 on success and -1 on error.
* *
* Copyright: 1990, N. Dessipris. * Copyright: 1990, N. Dessipris.
* *

View File

@ -704,8 +704,8 @@ vips__build_mergestate( const char *domain,
int x; int x;
/* TODO(kleisauke): Copied from vips_insert, perhaps we /* TODO(kleisauke): Copied from vips_insert, perhaps we
* need a separate function for this? * need a separate function for this?
* (just like im__insert_base) * (just like im__insert_base)
*/ */
if( vips_image_pio_input( ref ) || if( vips_image_pio_input( ref ) ||
vips_image_pio_input( sec ) || vips_image_pio_input( sec ) ||

View File

@ -119,7 +119,7 @@ vips__find_lroverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
*/ */
if( halfcorrelation < 0 || halfarea < 0 || if( halfcorrelation < 0 || halfarea < 0 ||
halfarea < halfcorrelation ) { halfarea < halfcorrelation ) {
vips_error( "vips_lrmosaic", "%s", _( "bad area parameters" ) ); vips_error( "vips__lrmosaic", "%s", _( "bad area parameters" ) );
return( -1 ); return( -1 );
} }
@ -139,7 +139,7 @@ vips__find_lroverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
vips_rect_intersectrect( &left, &right, &overlap ); vips_rect_intersectrect( &left, &right, &overlap );
if( overlap.width < 2 * halfarea + 1 || if( overlap.width < 2 * halfarea + 1 ||
overlap.height < 2 * halfarea + 1 ) { overlap.height < 2 * halfarea + 1 ) {
vips_error( "vips_lrmosaic", vips_error( "vips__lrmosaic",
"%s", _( "overlap too small for search" ) ); "%s", _( "overlap too small for search" ) );
return( -1 ); return( -1 );
} }
@ -168,7 +168,7 @@ vips__find_lroverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
return( -1 ); return( -1 );
} }
else { else {
vips_error( "vips_lrmosaic", "%s", _( "unknown Coding type" ) ); vips_error( "vips__lrmosaic", "%s", _( "unknown Coding type" ) );
return( -1 ); return( -1 );
} }

View File

@ -227,7 +227,7 @@ lu_decomp( VipsImage *mat )
* PRESS, W. et al, 1992. Numerical Recipies in C; The Art of Scientific * PRESS, W. et al, 1992. Numerical Recipies in C; The Art of Scientific
* Computing, 2nd ed. Cambridge: Cambridge University Press, pp. 43-50. * Computing, 2nd ed. Cambridge: Cambridge University Press, pp. 43-50.
* *
* See also: im_mattrn(), im_matinv(). * See also: vips__matrixtranspose(), vips__matrixmultiply().
* *
* Returns: 0 on success, -1 on error * Returns: 0 on success, -1 on error
*/ */

View File

@ -135,11 +135,6 @@ int vips__tbmerge1( VipsImage *ref, VipsImage *sec, VipsImage *out,
double a, double b, double dx, double dy, double a, double b, double dx, double dy,
int mwidth ); int mwidth );
int vips_correl( VipsImage *ref, VipsImage *sec,
int xref, int yref, int xsec, int ysec,
int hwindowsize, int hsearchsize,
double *correlation, int *x, int *y );
#define VIPS_MAXPOINTS (60) /* VIPS_MAXPOINTS % AREAS must be zero */ #define VIPS_MAXPOINTS (60) /* VIPS_MAXPOINTS % AREAS must be zero */
#define AREAS (3) #define AREAS (3)

View File

@ -23,7 +23,7 @@
* - ANSIfied * - ANSIfied
* - proper freeing on errors, ready for partial * - proper freeing on errors, ready for partial
* 8/11/93 JC * 8/11/93 JC
* - now propogates both input histories * - now propagates both input histories
* - adds magic lines for global mosaic optimisation * - adds magic lines for global mosaic optimisation
* *
* *

View File

@ -78,7 +78,7 @@ vips__find_tboverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
double *scale1, double *angle1, double *dx1, double *dy1 ) double *scale1, double *angle1, double *dx1, double *dy1 )
{ {
VipsImage **t = (VipsImage **) VipsImage **t = (VipsImage **)
vips_object_local_array( VIPS_OBJECT( out ), 6 ); vips_object_local_array( VIPS_OBJECT( out ), 6 );
VipsRect top, bottom, overlap; VipsRect top, bottom, overlap;
TiePoints points, *p_points; /* defined in mosaic.h */ TiePoints points, *p_points; /* defined in mosaic.h */
@ -90,7 +90,7 @@ vips__find_tboverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
*/ */
if( halfcorrelation < 0 || halfarea < 0 || if( halfcorrelation < 0 || halfarea < 0 ||
halfarea < halfcorrelation ) { halfarea < halfcorrelation ) {
vips_error( "vips_tbmosaic", "%s", _( "bad area parameters" ) ); vips_error( "vips__tbmosaic", "%s", _( "bad area parameters" ) );
return( -1 ); return( -1 );
} }
@ -110,7 +110,7 @@ vips__find_tboverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
vips_rect_intersectrect( &top, &bottom, &overlap ); vips_rect_intersectrect( &top, &bottom, &overlap );
if( overlap.width < 2 * halfarea + 1 || if( overlap.width < 2 * halfarea + 1 ||
overlap.height < 2 * halfarea + 1 ) { overlap.height < 2 * halfarea + 1 ) {
vips_error( "vips_tbmosaic", "%s", vips_error( "vips__tbmosaic", "%s",
_( "overlap too small for search" ) ); _( "overlap too small for search" ) );
return( -1 ); return( -1 );
} }
@ -139,7 +139,7 @@ vips__find_tboverlap( VipsImage *ref_in, VipsImage *sec_in, VipsImage *out,
return( -1 ); return( -1 );
} }
else { else {
vips_error( "vips_tbmosaic", "%s", _( "unknown Coding type" ) ); vips_error( "vips__tbmosaic", "%s", _( "unknown Coding type" ) );
return( -1 ); return( -1 );
} }