morph docs

This commit is contained in:
John Cupitt 2010-11-07 10:57:11 +00:00
parent 379f9ad4c9
commit 29f62c1aa8
2 changed files with 60 additions and 2 deletions

View File

@ -41,6 +41,7 @@
- add FITS reader - add FITS reader
- land the vector branmch ... we have SSE erode/dilate/add/conv - land the vector branmch ... we have SSE erode/dilate/add/conv
- add IM_SWAP - add IM_SWAP
- dilate/erode do (!=0) on non-uchar images
12/5/10 started 7.22.2 12/5/10 started 7.22.2
- the conditional image of ifthenelse can be any format, a (!=0) is added if - the conditional image of ifthenelse can be any format, a (!=0) is added if

View File

@ -16,6 +16,9 @@
* 29/10/10 * 29/10/10
* - use VipsVector * - use VipsVector
* - do erode as well * - do erode as well
* 7/11/10
* - gtk-doc
* - do (!=0) to make uchar, if we're not given uchar
*/ */
/* /*
@ -287,6 +290,18 @@ morph_new( IMAGE *in, IMAGE *out, INTMASK *mask, MorphOp op )
Morph *morph; Morph *morph;
int i; int i;
/* If in is not uchar, do (!=0) to make a uchar image.
*/
if( in->BandFmt != IM_BANDFMT_UCHAR ) {
IMAGE *t;
if( !(t = im_open_local( out, "morph_new", "p" )) ||
im_notequalconst( in, t, 0 ) )
return( NULL );
in = t;
}
if( im_piocheck( in, out ) || if( im_piocheck( in, out ) ||
im_check_uncoded( "morph", in ) || im_check_uncoded( "morph", in ) ||
im_check_format( "morph", in, IM_BANDFMT_UCHAR ) || im_check_format( "morph", in, IM_BANDFMT_UCHAR ) ||
@ -737,6 +752,8 @@ morphology( IMAGE *in, IMAGE *out, INTMASK *mask, MorphOp op )
return( 0 ); return( 0 );
} }
/* Keep the _raw versions for compat.
*/
int int
im_dilate_raw( IMAGE *in, IMAGE *out, INTMASK *mask ) im_dilate_raw( IMAGE *in, IMAGE *out, INTMASK *mask )
{ {
@ -755,10 +772,30 @@ im_erode_raw( IMAGE *in, IMAGE *out, INTMASK *mask )
* @out: output image * @out: output image
* @mask: mask * @mask: mask
* *
* im_dilate() performs a morphological dilate operation on @in using @mask as a
* structuring element. The output pixel is set if any part of the mask
* matches, that is, the result is the logical OR of the selected input pixels.
*
* The image should have 0 (black) for no object and 255
* (non-zero) for an object. Note that this is the reverse of the usual
* convention for these operations, but more convenient when combined with the
* boolean operators im_andimage() and friends. The output image is the same
* size as the input image: edge pxels are made by expanding the input image
* as necessary in the manner of im_conv().
*
* Mask coefficients can be either 0 (for object) or 255 (for background)
* or 128 (for do not care). The origin of the mask is at location
* (m.xsize / 2, m.ysize / 2), integer division. All algorithms have been
* based on the book "Fundamentals of Digital Image Processing" by A. Jain,
* pp 384-388, Prentice-Hall, 1989.
*
* See the boolean operations im_andimage(), im_orimage() and im_eorimage()
* for analogues of the usual set difference and set union operations.
*
* Operations are performed using the processor's vector unit, * Operations are performed using the processor's vector unit,
* if possible. Disable this with --vips-novector or IM_NOVECTOR. * if possible. Disable this with --vips-novector or IM_NOVECTOR.
* *
* See also: * See also: im_erode().
* *
* Returns: 0 on success, -1 on error * Returns: 0 on success, -1 on error
*/ */
@ -786,10 +823,30 @@ im_dilate( IMAGE *in, IMAGE *out, INTMASK *mask )
* @out: output image * @out: output image
* @mask: mask * @mask: mask
* *
* im_erode() performs a morphological erode operation on @in using @mask as a
* structuring element. The whole mask must match for the output pixel to be
* set, that is, the result is the logical AND of the selected input pixels.
*
* The image should have 0 (black) for no object and 255
* (non-zero) for an object. Note that this is the reverse of the usual
* convention for these operations, but more convenient when combined with the
* boolean operators im_andimage() and friends. The output image is the same
* size as the input image: edge pxels are made by expanding the input image
* as necessary in the manner of im_conv().
*
* Mask coefficients can be either 0 (for object) or 255 (for background)
* or 128 (for do not care). The origin of the mask is at location
* (m.xsize / 2, m.ysize / 2), integer division. All algorithms have been
* based on the book "Fundamentals of Digital Image Processing" by A. Jain,
* pp 384-388, Prentice-Hall, 1989.
*
* See the boolean operations im_andimage(), im_orimage() and im_eorimage()
* for analogues of the usual set difference and set union operations.
*
* Operations are performed using the processor's vector unit, * Operations are performed using the processor's vector unit,
* if possible. Disable this with --vips-novector or IM_NOVECTOR. * if possible. Disable this with --vips-novector or IM_NOVECTOR.
* *
* See also: * See also: im_dilate().
* *
* Returns: 0 on success, -1 on error * Returns: 0 on success, -1 on error
*/ */