\ .\" This man page was generated by the Netpbm tool 'makeman' from HTML source. .\" Do not hand-hack it! If you have bug fixes or improvements, please find .\" the corresponding HTML page on the Netpbm website, generate a patch .\" against that, and send it to the Netpbm maintainer. .TH "Pnmquant User Manual" 1 "09 February 2019" "netpbm documentation" .SH NAME pnmquant - quantize the colors in a Netpbm image to a smaller set .UN synopsis .SH SYNOPSIS \fBpnmquant\fP [\fB-center\fP|\fB-meancolor\fP|\fB-meanpixel\fP] [\fB-floyd\fP|\fB-fs\fP] [\fB-nofloyd\fP|\fB-nofs\fP] [\fB-spreadbrightness\fP|\fB-spreadluminosity\fP] {[\fB-norandom\fP]|[\fB-randomseed=\fP\fIn\fP]} \fIncolors\fP [\fIpnmfile\fP] .PP All options can be abbreviated to their shortest unique prefix. You may use two hyphens instead of one to designate an option. You may use either white space or equals signs between an option name and its value. .UN description .SH DESCRIPTION .PP This program is part of .BR "Netpbm" (1)\c \&. .PP \fBpnmquant\fP reads a PNM image as input. It chooses \fIncolors\fP colors to best represent the image, maps the existing colors to the new ones, and writes a PNM image as output. .PP This program is simply a combination of \fBpnmcolormap\fP and \fBpnmremap\fP, where the colors of the input are remapped using a color map which is generated from the colors in that same input. The options have the same meaning as in those programs. See their documentation to understand \fBpnmquant\fP. .PP You may actually get fewer than \fBncolors\fP colors in the output because the method \fBpnmcolormap\fP uses to choose the best set of colors for the image is not the same as the method \fBpnmremap\fP uses to determine the best color from the set to represent an individual color. For example, \fBpnmcolormap\fP may include salmon in the color map as the best representative of a pink pixel in the input and include coral in the color map as the best representative of an actual coral pixel in the input. But \fBpnmremap\fP is free to use any color in the color map to represent that pink pixel and would find coral is a closer match for pink than salmon and therefore use coral for pink. \fBpnmremap\fP might not use salmon for \fIany\fP pixel. .PP This waste of a slot in the color map is a consequence of the approximate method \fBpnmcolormap\fP uses in order to compute the color map with a practical amount of computation. .UN separate .SS Running \fBpnmcolormap\fP and \fBpnmremap\fP Separately .PP It is much faster to call \fBpnmcolormap\fP and \fBpnmremap\fP directly than to run \fBpnmquant\fP. You save the overhead of the Perl interpreter and creating two extra processes. \fBpnmquant\fP is just a convenience. .PP Here is an example of the relationship between the programs: .PP This: .nf \f(CW $ pnmquant 256 myimage.pnm >/tmp/colormap.pnm >myimage256.pnm \fP .fi .PP does essentially this: .nf \f(CW $ pnmcolormap 256 myimage.pnm >/tmp/colormap.pnm $ pnmremap -mapfile=/tmp/colormap.pnm myimage.pnm >myimage256.pnm \fP .fi .UN options .SH OPTIONS .PP In addition to the options common to all programs based on libnetpbm (most notably \fB-quiet\fP, see .UR index.html#commonoptions Common Options .UE \&), \fBpnmquant\fP recognizes the following command line options: .UN pnmcolormapopt .SS Options Passed to \fBpnmcolormap\fP .PP These options control the selection of the palette. They are options to .BR "\fBpnmcolormap\fP" (1)\c \&. .TP \fB-center\fP .TP \fB-meancolor\fP .TP \fB-meanpixel\fP .TP \fB-spreadbrightness\fP .TP \fB-spreadluminosity\fP .UN pnmremapopt .SS Options Passed to \fBpnmremap\fP .PP These options control which color from the palette the program uses to replace a pixel of a certain color from the input. They are options to .BR "\fBpnmremap\fP" (1)\c \&. .TP \fB-floyd\fP .TP \fB-fs\fP .TP \fB-nofloyd\fP .TP \fB-nofs\fP .TP \fB-norandom\fP .TP \fB-randomseed\fP .TP \fB-norandom\fP .UN history .SH HISTORY .PP \fBpnmquant\fP did not exist before Netpbm 9.21 (January 2001). Before that, \fBppmquant\fP did the same thing, but only on PPM images. \fBppmquant\fP continues to exist, but is only a front end (for name compatibility) to \fBpnmquant\fP. .PP \fB-version\fP did not exist before Netpbm 10.75 (June 2016). .PP \fB-norandom\fP did not exist before Netpbm 10.82 (March 2018). .UN seealso .SH SEE ALSO .BR "pnmcolormap" (1)\c \&, .BR "pnmremap" (1)\c \&, .BR "pnmquantall" (1)\c \&, .BR "pamdepth" (1)\c \&, .BR "ppmdither" (1)\c \&, .BR "ppmquant" (1)\c \&, .BR "pnm" (1)\c \& .SH DOCUMENT SOURCE This manual page was generated by the Netpbm tool 'makeman' from HTML source. The master documentation is at .IP .B http://netpbm.sourceforge.net/doc/pnmquant.html .PP