stuff
This commit is contained in:
parent
3c18b0f0c1
commit
fb4a191ab7
32
TODO
32
TODO
@ -1,35 +1,3 @@
|
|||||||
- im_fastcor() could use a rewrite
|
|
||||||
|
|
||||||
- im_spcor a.value a.value fails, argh
|
|
||||||
|
|
||||||
nip2: im_prepare.c:324: im_prepare_to:
|
|
||||||
Assertion `clipped.left == r->left' failed.
|
|
||||||
|
|
||||||
also, im_spcor a rectangular image one pixel smaller with itself and the
|
|
||||||
peak comes at (eg. 134x134) rather than in the centre of the image
|
|
||||||
|
|
||||||
suspicious!
|
|
||||||
|
|
||||||
looks like it's a problem with im_embed()
|
|
||||||
|
|
||||||
$ header t1.v
|
|
||||||
Xsize: 183
|
|
||||||
Ysize: 119
|
|
||||||
Bands: 1
|
|
||||||
Bbits: 8
|
|
||||||
|
|
||||||
then
|
|
||||||
|
|
||||||
$ vips im_embed t1.v out2.v 1 100 74 364 240
|
|
||||||
$ vips im_embed t1.v out2.v 1 100 73 364 240
|
|
||||||
vips: error calling function
|
|
||||||
im_prepare_to: valid clipped to nothing
|
|
||||||
im__write_extension_block: file has been truncated
|
|
||||||
|
|
||||||
though 74 fails too, tiles are in the wrong place
|
|
||||||
|
|
||||||
seems fixed, test this
|
|
||||||
|
|
||||||
- doing im_create_fmask() and friends
|
- doing im_create_fmask() and friends
|
||||||
|
|
||||||
- how about im_invalidate_area()? we currently repaint the whole window on
|
- how about im_invalidate_area()? we currently repaint the whole window on
|
||||||
|
@ -1314,18 +1314,18 @@ static im_arg_desc wrap_args[] = {
|
|||||||
static int
|
static int
|
||||||
wrap_vec (im_object * argv)
|
wrap_vec (im_object * argv)
|
||||||
{
|
{
|
||||||
return im_wrap( (IMAGE*)argv[0], (IMAGE*)argv[1], *(int*)argv[2], *(int*)argv[3] );
|
return im_wrap( argv[0], argv[1], *(int*)argv[2], *(int*)argv[3] );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Description of im_wrap.
|
/* Description of im_wrap.
|
||||||
*/
|
*/
|
||||||
static im_function wrap_desc = {
|
static im_function wrap_desc = {
|
||||||
"im_wrap", /* Name */
|
"im_wrap", /* Name */
|
||||||
"shift image origin, wrapping at sides",
|
"shift image origin, wrapping at sides",
|
||||||
IM_FN_PIO | IM_FN_TRANSFORM, /* Flags */
|
IM_FN_PIO | IM_FN_TRANSFORM, /* Flags */
|
||||||
wrap_vec, /* Dispatch function */
|
wrap_vec, /* Dispatch function */
|
||||||
IM_NUMBER (wrap_args), /* Size of arg list */
|
IM_NUMBER (wrap_args), /* Size of arg list */
|
||||||
wrap_args /* Arg list */
|
wrap_args /* Arg list */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Args for im_embed.
|
/* Args for im_embed.
|
||||||
@ -1336,8 +1336,8 @@ static im_arg_desc embed_args[] = {
|
|||||||
IM_INPUT_INT( "type" ),
|
IM_INPUT_INT( "type" ),
|
||||||
IM_INPUT_INT( "x" ),
|
IM_INPUT_INT( "x" ),
|
||||||
IM_INPUT_INT( "y" ),
|
IM_INPUT_INT( "y" ),
|
||||||
IM_INPUT_INT( "w" ),
|
IM_INPUT_INT( "width" ),
|
||||||
IM_INPUT_INT( "h" )
|
IM_INPUT_INT( "height" )
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Call im_embed via arg vector.
|
/* Call im_embed via arg vector.
|
||||||
@ -1348,10 +1348,10 @@ embed_vec( im_object *argv )
|
|||||||
int type = *((int *) argv[2]);
|
int type = *((int *) argv[2]);
|
||||||
int x = *((int *) argv[3]);
|
int x = *((int *) argv[3]);
|
||||||
int y = *((int *) argv[4]);
|
int y = *((int *) argv[4]);
|
||||||
int w = *((int *) argv[5]);
|
int width = *((int *) argv[5]);
|
||||||
int h = *((int *) argv[6]);
|
int height = *((int *) argv[6]);
|
||||||
|
|
||||||
return( im_embed( argv[0], argv[1], type, x, y, w, h ) );
|
return( im_embed( argv[0], argv[1], type, x, y, width, height ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Description of im_embed.
|
/* Description of im_embed.
|
||||||
@ -1361,7 +1361,7 @@ static im_function embed_desc = {
|
|||||||
"embed in within a set of borders",
|
"embed in within a set of borders",
|
||||||
IM_FN_PIO | IM_FN_TRANSFORM, /* Flags */
|
IM_FN_PIO | IM_FN_TRANSFORM, /* Flags */
|
||||||
embed_vec, /* Dispatch function */
|
embed_vec, /* Dispatch function */
|
||||||
IM_NUMBER( embed_args ), /* Size of arg list */
|
IM_NUMBER( embed_args ), /* Size of arg list */
|
||||||
embed_args /* Arg list */
|
embed_args /* Arg list */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -73,10 +73,6 @@ fastcor_gen( REGION *or, void *seq, void *a, void *b )
|
|||||||
IMAGE *ref = (IMAGE *) b;
|
IMAGE *ref = (IMAGE *) b;
|
||||||
Rect irect;
|
Rect irect;
|
||||||
Rect *r = &or->valid;
|
Rect *r = &or->valid;
|
||||||
int le = r->left;
|
|
||||||
int to = r->top;
|
|
||||||
int bo = IM_RECT_BOTTOM(r);
|
|
||||||
int ri = IM_RECT_RIGHT(r);
|
|
||||||
|
|
||||||
int x, y, i, j;
|
int x, y, i, j;
|
||||||
int lsk;
|
int lsk;
|
||||||
@ -94,29 +90,30 @@ fastcor_gen( REGION *or, void *seq, void *a, void *b )
|
|||||||
|
|
||||||
/* Loop over or.
|
/* Loop over or.
|
||||||
*/
|
*/
|
||||||
for( y = to; y < bo; y++ ) {
|
for( y = 0; y < r->height; y++ ) {
|
||||||
PEL *a = (PEL *) IM_REGION_ADDR( ir, le, y );
|
unsigned int *q = (unsigned int *)
|
||||||
unsigned int *q = (unsigned int *) IM_REGION_ADDR( or, le, y );
|
IM_REGION_ADDR( or, r->left, r->top + y );
|
||||||
|
|
||||||
for( x = le; x < ri; x++ ) {
|
for( x = 0; x < r->width; x++ ) {
|
||||||
int sum = 0;
|
|
||||||
PEL *b = (PEL *) ref->data;
|
PEL *b = (PEL *) ref->data;
|
||||||
PEL *a1 = a;
|
PEL *a = (PEL *)
|
||||||
|
IM_REGION_ADDR( ir, r->left + x, r->top + y );
|
||||||
|
|
||||||
|
int sum;
|
||||||
|
|
||||||
|
sum = 0;
|
||||||
for( j = 0; j < ref->Ysize; j++ ) {
|
for( j = 0; j < ref->Ysize; j++ ) {
|
||||||
PEL *a2 = a1;
|
|
||||||
|
|
||||||
for( i = 0; i < ref->Xsize; i++ ) {
|
for( i = 0; i < ref->Xsize; i++ ) {
|
||||||
int t = *b++ - *a2++;
|
int t = b[i] - a[i];
|
||||||
|
|
||||||
sum += t * t;
|
sum += t * t;
|
||||||
}
|
}
|
||||||
|
|
||||||
a1 += lsk;
|
a += lsk;
|
||||||
|
b += ref->Xsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
*q++ = sum;
|
q[x] = sum;
|
||||||
a += 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -137,7 +134,8 @@ im_fastcor_raw( IMAGE *in, IMAGE *ref, IMAGE *out )
|
|||||||
/* Check sizes.
|
/* Check sizes.
|
||||||
*/
|
*/
|
||||||
if( in->Xsize < ref->Xsize || in->Ysize < ref->Ysize ) {
|
if( in->Xsize < ref->Xsize || in->Ysize < ref->Ysize ) {
|
||||||
im_error( "im_fastcor", "%s", _( "ref not smaller than in" ) );
|
im_error( "im_fastcor", "%s",
|
||||||
|
_( "ref not smaller than or equal to in" ) );
|
||||||
return( -1 );
|
return( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -183,7 +181,8 @@ im_fastcor_raw( IMAGE *in, IMAGE *ref, IMAGE *out )
|
|||||||
*
|
*
|
||||||
* @ref is placed at every position in @in and the sum of squares of
|
* @ref is placed at every position in @in and the sum of squares of
|
||||||
* differences calculated. One-band, 8-bit unsigned images only. The output
|
* differences calculated. One-band, 8-bit unsigned images only. The output
|
||||||
* image is always %IM_BANDFMT_UINT. @ref must be smaller than @in. The output
|
* image is always %IM_BANDFMT_UINT. @ref must be smaller than or equal to
|
||||||
|
* @in. The output
|
||||||
* image is the same size as the input.
|
* image is the same size as the input.
|
||||||
*
|
*
|
||||||
* See also: im_spcor().
|
* See also: im_spcor().
|
||||||
|
@ -248,7 +248,7 @@ im_spcor_raw( IMAGE *in, IMAGE *ref, IMAGE *out )
|
|||||||
if( in->Xsize < ref->Xsize ||
|
if( in->Xsize < ref->Xsize ||
|
||||||
in->Ysize < ref->Ysize ) {
|
in->Ysize < ref->Ysize ) {
|
||||||
im_error( "im_spcor_raw",
|
im_error( "im_spcor_raw",
|
||||||
"%s", _( "ref not smaller than in" ) );
|
"%s", _( "ref not smaller than or equal to in" ) );
|
||||||
return( -1 );
|
return( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,7 +304,8 @@ im_spcor_raw( IMAGE *in, IMAGE *ref, IMAGE *out )
|
|||||||
* @ref is placed at every position in @in and the correlation coefficient
|
* @ref is placed at every position in @in and the correlation coefficient
|
||||||
* calculated. One-band, 8 or 16-bit images only. @in and @ref must have the
|
* calculated. One-band, 8 or 16-bit images only. @in and @ref must have the
|
||||||
* same #VipsBandFmt. The output
|
* same #VipsBandFmt. The output
|
||||||
* image is always %IM_BANDFMT_FLOAT. @ref must be smaller than @in. The output
|
* image is always %IM_BANDFMT_FLOAT. @ref must be smaller than or equal to
|
||||||
|
* @in. The output
|
||||||
* image is the same size as the input.
|
* image is the same size as the input.
|
||||||
*
|
*
|
||||||
* The correlation coefficient is calculated as:
|
* The correlation coefficient is calculated as:
|
||||||
|
Loading…
Reference in New Issue
Block a user