.\" This man page was generated by the Netpbm tool 'makeman' from HTML source. Pnmnlfilt User Manual - Online Linux Manual PageSection : 0
Updated : 24 October 2006
Source : netpbm documentation

NAMEpnmnlfilt - non-linear filters: smooth, alpha trim mean, optimal estimation smoothing, edge enhancement. .UN synopsis

SYNOPSISpnmnlfilt alpha radius [pnmfile] .UN description

DESCRIPTIONThis program is part of Netpbm(1)​. pnmnlfilt produces an output image where the pixels are a summary of multiple pixels near the corresponding location in an input image. This program works on multi-image streams. This is something of a swiss army knife filter. It has 3 distinct operating modes. In all of the modes pnmnlfilt examines each pixel in the image and processes it according to the values of it and its surrounding pixels. Rather than using a square block of surrounding pixels (e.g. the subject pixel and its 8 immediate neighbors, in a 3x3 square), pnmnlfilt uses 7 hexagonal areas. You choose the size of the hexagons with the radius parameter. A radius value of 1/3 means that the 7 hexagons essentially fit into the subject pixel (ie. there will be no filtering effect). A radius value of 1.0 means that the 7 hexagons essentially cover the 3x3 immediate neighbor square. Your choice of "alpha" parameter selects among the three modes. .UN alphatrimmedmean

Alpha trimmed mean filter (0.0 <= alpha <= 0.5) The value of the center pixel will be replaced by the mean of the 7 hexagon values, but the 7 values are sorted by size and the top and bottom alpha portion of the 7 are excluded from the mean. This implies that an alpha value of 0.0 gives the same sort of output as a normal convolution (ie. averaging or smoothing filter), where radius will determine the "strength" of the filter. A good value to start from for subtle filtering is alpha = 0.0, radius = 0.55 For a more blatant effect, try alpha 0.0 and radius 1.0 An alpha value of 0.5 will cause the median value of the 7 hexagons to be used to replace the center pixel value. This sort of filter is good for eliminating "pop" or single pixel noise from an image without spreading the noise out or smudging features on the image. Judicious use of the radius parameter will fine tune the filtering. Intermediate values of alpha give effects somewhere between smoothing and "pop" noise reduction. For subtle filtering try starting with values of alpha = 0.4, radius = 0.6 For a more blatant effect try alpha = 0.5, radius = 1.0 .UN optimalestsmooth

Optimal estimation smoothing. (1.0 <= alpha <= 2.0) This type of filter applies a smoothing filter adaptively over the image. For each pixel the variance of the surrounding hexagon values is calculated, and the amount of smoothing is made inversely proportional to it. The idea is that if the variance is small then it is due to noise in the image, while if the variance is large, it is because of "wanted" image features. As usual the radius parameter controls the effective radius, but it probably advisable to leave the radius between 0.8 and 1.0 for the variance calculation to be meaningful. The alpha parameter sets the noise threshold, over which less smoothing will be done. This means that small values of alpha will give the most subtle filtering effect, while large values will tend to smooth all parts of the image. You could start with values like alpha = 1.2, radius = 1.0 and try increasing or decreasing the alpha parameter to get the desired effect. This type of filter is best for filtering out dithering noise in both bitmap and color images. .UN edgeenhance

Edge enhancement. (-0.1 >= alpha >= -0.9)This is the opposite type of filter to the smoothing filter. It enhances edges. The alpha parameter controls the amount of edge enhancement, from subtle (-0.1) to blatant (-0.9). The radius parameter controls the effective radius as usual, but useful values are between 0.5 and 0.9. Try starting with values of alpha = 0.3, radius = 0.8 .UN combination

Combination use.The various modes of pnmnlfilt can be used one after the other to get the desired result. For instance to turn a monochrome dithered image into a grayscale image you could try one or two passes of the smoothing filter, followed by a pass of the optimal estimation filter, then some subtle edge enhancement. Note that using edge enhancement is only likely to be useful after one of the non-linear filters (alpha trimmed mean or optimal estimation filter), as edge enhancement is the direct opposite of smoothing. For reducing color quantization noise in images (ie. turning .gif files back into 24 bit files) you could try a pass of the optimal estimation filter (alpha 1.2, radius 1.0), a pass of the median filter (alpha 0.5, radius 0.55), and possibly a pass of the edge enhancement filter. Several passes of the optimal estimation filter with declining alpha values are more effective than a single pass with a large alpha value. As usual, there is a tradeoff between filtering effectiveness and losing detail. Experimentation is encouraged. .UN options

OPTIONSThere are no command line options defined specifically for pnmnlfilt, but it recognizes the options common to all programs based on libnetpbm (See
 Common Options
​.) .UN references

REFERENCESThe alpha-trimmed mean filter is based on the description in IEEE CG&A May 1990 Page 23 by Mark E. Lee and Richard A. Redner, and has been enhanced to allow continuous alpha adjustment. The optimal estimation filter is taken from an article "Converting Dithered Images Back to Gray Scale" by Allen Stenger, Dr Dobb's Journal, November 1992, and this article references "Digital Image Enhancement and Noise Filtering by Use of Local Statistics", Jong-Sen Lee, IEEE Transactions on Pattern Analysis and Machine Intelligence, March 1980. The edge enhancement details are from "pgmenhance(1)​, which is taken from Philip R. Thompson's "xim" program, which in turn took it from section 6 of "Digital Halftones by Dot Diffusion", D. E. Knuth, ACM Transaction on Graphics Vol. 6, No. 4, October 1987, which in turn got it from two 1976 papers by J. F. Jarvis et. al. .UN parameters

PARAMETERSThe parameters are: alpha  The alpha value (described above), in decimal. May be fractional. radius  The radius (described above), in decimal. May be fractional. .UN seealso

SEE ALSO"pgmenhance(1)​, "pnmconvol(1)​, "pnm(1).UN author

AUTHORGraeme W. Gill graeme@labtam.oz.au

DOCUMENT SOURCEThis manual page was generated by the Netpbm tool 'makeman' from HTML source. The master documentation is at http://netpbm.sourceforge.net/doc/pnmnlfilt.html
0
Johanes Gumabo
Data Size   :   16,470 byte
man-pnmnlfilt.1Build   :   2024-12-05, 20:55   :  
Visitor Screen   :   x
Visitor Counter ( page / site )   :   3 / 200,898
Visitor ID   :     :  
Visitor IP   :   3.135.209.231   :  
Visitor Provider   :   AMAZON-02   :  
Provider Position ( lat x lon )   :   39.962500 x -83.006100   :   x
Provider Accuracy Radius ( km )   :   1000   :  
Provider City   :   Columbus   :  
Provider Province   :   Ohio ,   :   ,
Provider Country   :   United States   :  
Provider Continent   :   North America   :  
Visitor Recorder   :   Version   :  
Visitor Recorder   :   Library   :  
Online Linux Manual Page   :   Version   :   Online Linux Manual Page - Fedora.40 - march=x86-64 - mtune=generic - 24.12.05
Online Linux Manual Page   :   Library   :   lib_c - 24.10.03 - march=x86-64 - mtune=generic - Fedora.40
Online Linux Manual Page   :   Library   :   lib_m - 24.10.03 - march=x86-64 - mtune=generic - Fedora.40
Data Base   :   Version   :   Online Linux Manual Page Database - 24.04.13 - march=x86-64 - mtune=generic - fedora-38
Data Base   :   Library   :   lib_c - 23.02.07 - march=x86-64 - mtune=generic - fedora.36

Very long time ago, I have the best tutor, Wenzel Svojanovsky . If someone knows the email address of Wenzel Svojanovsky , please send an email to johanes_gumabo@yahoo.co.id .
If error, please print screen and send to johanes_gumabo@yahoo.co.id
Under development. Support me via PayPal.

ERROR : Need New Coding :         (rof_escape_sequence|91|pnmnlfilt.1|1/2|\" This man page was generated by the Netpbm tool 'makeman' from HTML source. |.\" This man page was generated by the Netpbm tool 'makeman' from HTML source. )         (parse_manual_page_|249|pnmnlfilt.1|1/2|\"|.\" This man page was generated by the Netpbm tool 'makeman' from HTML source. )         (parse_manual_page_|249|pnmnlfilt.1|13|UN|.UN synopsis )         (parse_manual_page_|249|pnmnlfilt.1|21|UN|.UN description )         (parse_manual_page_|249|pnmnlfilt.1|49|UN|.UN alphatrimmedmean )         (parse_manual_page_|249|pnmnlfilt.1|72|UN|.UN optimalestsmooth )         (parse_manual_page_|249|pnmnlfilt.1|93|UN|.UN edgeenhance )         (parse_manual_page_|249|pnmnlfilt.1|103|UN|.UN combination )         (parse_manual_page_|249|pnmnlfilt.1|124|UN|.UN options )         (parse_manual_page_|249|pnmnlfilt.1|135|UN|.UN references )         (parse_manual_page_|249|pnmnlfilt.1|157|UN|.UN parameters )         (parse_manual_page_|249|pnmnlfilt.1|172|UN|.UN seealso )         (parse_manual_page_|249|pnmnlfilt.1|181|UN|.UN author )