more cosmetic

This commit is contained in:
John Cupitt 2013-10-02 05:51:14 +01:00
parent 881c6d72f5
commit 81bd3c1b53
2 changed files with 22 additions and 6 deletions

View File

@ -23,7 +23,7 @@
- dzsave basename param now called filename, so you can use .dz as a - dzsave basename param now called filename, so you can use .dz as a
destination (basename is still there but deprecated) destination (basename is still there but deprecated)
- new _UNBUFFERED sequential mode saves memory in some important cases - new _UNBUFFERED sequential mode saves memory in some important cases
- start vips_conv() as a simple wrapper over the old convolution functions - vips_conv() is a simple wrapper over the old convolution functions
- new optimize_coding param for jpeg write produces optimal Huffman tables, - new optimize_coding param for jpeg write produces optimal Huffman tables,
thanks Lovell thanks Lovell

View File

@ -139,14 +139,14 @@ vips_conv_class_init( VipsConvClass *class )
G_STRUCT_OFFSET( VipsConv, precision ), G_STRUCT_OFFSET( VipsConv, precision ),
VIPS_TYPE_PRECISION, VIPS_PRECISION_INTEGER ); VIPS_TYPE_PRECISION, VIPS_PRECISION_INTEGER );
VIPS_ARG_INT( class, "layers", 103, VIPS_ARG_INT( class, "layers", 104,
_( "Layers" ), _( "Layers" ),
_( "Use this many layers in approximation" ), _( "Use this many layers in approximation" ),
VIPS_ARGUMENT_OPTIONAL_INPUT, VIPS_ARGUMENT_OPTIONAL_INPUT,
G_STRUCT_OFFSET( VipsConv, layers ), G_STRUCT_OFFSET( VipsConv, layers ),
1, 1000, 5 ); 1, 1000, 5 );
VIPS_ARG_INT( class, "cluster", 103, VIPS_ARG_INT( class, "cluster", 105,
_( "Cluster" ), _( "Cluster" ),
_( "Cluster lines closer than this in approximation" ), _( "Cluster lines closer than this in approximation" ),
VIPS_ARGUMENT_OPTIONAL_INPUT, VIPS_ARGUMENT_OPTIONAL_INPUT,
@ -179,12 +179,28 @@ vips_conv_init( VipsConv *conv )
* Convolution. * Convolution.
* *
* Perform a convolution of @in with @mask. * Perform a convolution of @in with @mask.
* Each output pixel is
* calculated as sigma[i]{pixel[i] * mask[i]} / scale + offset, where scale
* and offset are part of @mask.
* *
* The output image * If @precision is #VIPS_PRECISION_INTEGER then the convolution is performed
* with integer arithmetic and the output image
* always has the same #VipsBandFmt as the input image. * always has the same #VipsBandFmt as the input image.
* *
* Larger values for @n_layers give more accurate * Convolutions on unsigned 8-bit images are calculated with the
* results, but are slower. As @n_layers approaches the mask radius, the * processor's vector unit, if possible. Disable this with --vips-novector or
* IM_NOVECTOR.
*
* If @precision is #VIPS_PRECISION_FLOAT then the convolution is performed
* with floating-point arithmetic. The output image
* is always %VIPS_FORMAT_FLOAT unless @in is %VIPS_FORMAT_DOUBLE, in which case
* @out is also %VIPS_FORMAT_DOUBLE.
*
* If @precision is #VIPS_PRECISION_APPROXIMATE then the output image
* always has the same #VipsBandFmt as the input image.
*
* Larger values for @layers give more accurate
* results, but are slower. As @layers approaches the mask radius, the
* accuracy will become close to exact convolution and the speed will drop to * accuracy will become close to exact convolution and the speed will drop to
* match. For many large masks, such as Gaussian, @n_layers need be only 10% of * match. For many large masks, such as Gaussian, @n_layers need be only 10% of
* this value and accuracy will still be good. * this value and accuracy will still be good.