Plan 9 from Bell Labs’s /usr/web/sources/contrib/fgb/root/sys/src/ape/lib/jbig/pbmtools/pbmtojbg.txt

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


PBMTOJBG(1)                                           PBMTOJBG(1)



NAME
       pbmtojbg - portable bitmap to JBIG1 file converter

SYNOPSIS
       pbmtojbg [ options ] [ input-file | -  [ output-file ]]

DESCRIPTION
       Reads  in  a portable bitmap (PBM) from a file or standard
       input, compresses it, and outputs the image as a JBIG1 bi-
       level image entity (BIE) file.

       JBIG1 is a highly effective lossless compression algorithm
       for bi-level images (one bit per pixel), which is particu-
       larly suitable for scanned document pages.

       A JBIG1 encoded image can be stored in several resolutions
       (progressive mode).  These resolution layers can be stored
       all  in  one  single  BIE or they can be stored in several
       separate BIE files.  All resolution layers except the low-
       est one are stored merely as differences to the next lower
       resolution layer, because this requires  less  space  than
       encoding  the full image completely every time. Each reso-
       lution layer has twice the number of horizontal and verti-
       cal  pixels  than  the  next lower layer.  JBIG1 files can
       also store several  bits  per  pixel  as  separate  bitmap
       planes,  and pbmtojbg can read a PGM file and transform it
       into a multi-bitplane BIE.


OPTIONS
       -             A single hyphen instead  of  an  input  file
                     name  will  cause  pbmtojbg to read the data
                     from standard input instead from a file.

       -q            Encode the image in  one  single  resolution
                     layer (sequential mode). This is usually the
                     most  efficient   compression   method.   By
                     default,  the number of resolution layers is
                     chosen automatically such  that  the  lowest
                     layer  image  is  not  larger than 640 x 480
                     pixels.

       -x number     Specify the maximal horizontal size  of  the
                     lowest resolution layer.  The default is 640
                     pixels.

       -y number     Specify the maximal  vertical  size  of  the
                     lowest resolution layer.  The default is 480
                     pixels.

       -l number     Select the lowest resolution layer that will
                     be  written  to  the  BIE. It is possible to
                     store the various  resolution  layers  of  a
                     JBIG1 image in progressive mode into differ-
                     ent BIEs. Options -l and -h allow to  select
                     the   resolution-layer  interval  that  will
                     appear in the created BIE. The lowest  reso-
                     lution  layer  has number 0 and this is also
                     the default value.  By  default  all  layers
                     will be written.

       -h number     Select  the  highest  resolution  layer that
                     will be written to the BIE. By  default  all
                     layers  will be written. See also option -l.

       -b            Use binary values instead of Gray code words
                     in  order to encode pixel values in multiple
                     bitplanes. This option has only an effect if
                     the input is a PGM file and if more than one
                     bitplane is produced. Note that the  decoder
                     has  to  make  the same selection but cannot
                     determine from  the  BIE,  whether  Gray  or
                     binary  code words were used by the encoder.

       -d number     Specify the  total  number  of  differential
                     resolution layers into which the input image
                     will be split  in  addition  to  the  lowest
                     layer.  Each  additional  layer  reduces the
                     size of layer 0 by 50 %. This  option  over-
                     rides  options -x and -y which are usually a
                     more comfortable way of selecting the number
                     of resolution layers.

       -s number     The JBIG1 algorithm splits each image into a
                     number of horizontal  stripes.  This  option
                     specifies that each stripe shall have number
                     lines in  layer  0.  The  default  value  is
                     selected  so  that  approximately 35 stripes
                     will be used for the whole image.

       -m number     Select the maximum horizontal offset of  the
                     adaptive  template pixel.  The JBIG1 encoder
                     uses a number of neighbour pixels  in  order
                     to get statistical a priori knowledge of the
                     probability, whether the next pixel will  be
                     black or white. One single pixel out of this
                     template of context neighbor pixels  can  be
                     moved around. Especially for dithered images
                     it can be a significant  advantage  to  have
                     one  neighbor  pixel  which  has  a distance
                     large enough to cover the period of a dither
                     function.  By default, the adaptive template
                     pixel can be moved up to 8 pixels away. This
                     encoder supports up to 23 pixels, however as
                     decoders are only  required  to  support  at
                     least  a  distance of 16 pixels by the stan-
                     dard, no higher value than 16 for number  is
                     recommended  in order to maintain interoper-
                     ability with  other  JBIG1  implementations.
                     The  maximal vertical offset of the adaptive
                     template pixel is always zero.

       -t number     Encode only the  specified  number  of  most
                     significant  bit  planes. This option allows
                     to reduce the depth of an input PGM file  if
                     not  all  bits  per  pixel are needed in the
                     output.

       -o number     JBIG1 separates an image into several  hori-
                     zontal   stripes,   resolution   layers  and
                     planes, were each plane contains one bit per
                     pixel.  One  single  stripe in one plane and
                     layer is  encoded  as  a  data  unit  called
                     stripe  data  entity  (SDE)  inside the BIE.
                     There are 12 different  possible  orders  in
                     which  the SDEs can be stored inside the BIE
                     and number selects which one shall be  used.
                     The  order  of the SDEs is only relevant for
                     applications that want  to  decode  a  JBIG1
                     file  which  has  not yet completely arrived
                     from e.g. a slow  network  connection.   For
                     instance  some  applications prefer that the
                     outermost of the three loops (stripes,  lay-
                     ers,  planes) is over all layers so that all
                     data  of  the  lowest  resolution  layer  is
                     transmitted first.
                     The following values for number select these
                     loop arrangements for writing the SDEs (out-
                     ermost loop first):

                        0      planes, layers, stripes
                        2      layers, planes, stripes
                        3      layers, stripes, planes
                        4      stripes, planes, layers
                        5      planes, stripes, layers
                        6      stripes, layers, planes

                     All  loops count starting with zero, however
                     by adding 8 to the  above  order  code,  the
                     layer loop can be reversed so that it counts
                     down to zero and then higher resolution lay-
                     ers  will  be  stored  before  lower layers.
                     Default order is 3 which writes at first all
                     planes  of  the  first  stripe and then com-
                     pletes layer 0 before  continuing  with  the
                     next layer and so on.

       -p number     This option allows to activate or deactivate
                     various optional algorithms defined  in  the
                     JBIG1  standard. Just add the numbers of the
                     following options which you want to activate
                     in order to get the number value:

                        4      deterministic prediction (DPON)
                        8      layer 0 typical prediction (TPBON)
                       16      diff. layer typ. pred. (TPDON)
                       64      layer 0 two-line template (LRLTWO)

                     Except for special applications (like commu-
                     nication with JBIG1 subset  implementations)
                     and for debugging purposes you will normally
                     not  want  to  change  anything  here.   The
                     default  is 28, which provides the best com-
                     pression result.

       -c            Determine the adaptive template pixel  move-
                     ment  as  suggested  in annex C of the stan-
                     dard. By default the template  change  takes
                     place  directly  in  the next line, which is
                     most effective. However, a  few  conformance
                     test  examples  in  the standard require the
                     adaptive template change to be delayed until
                     the  first  line  of  the  next stripe. This
                     option selects this special behavior,  which
                     is  normally not required except in order to
                     pass some conformance tests.

       -Y number     A long time ago,  there  were  fax  machines
                     that  couldn't  even  hold  a single page in
                     memory. They had to start transmitting  data
                     before  the  page  was scanned in completely
                     and the length of the image was known.   The
                     authors  of the standard added a rather ugly
                     hack to the otherwise beautiful JBIG1 format
                     to  support  this. The NEWLEN marker segment
                     can override the image height stated in  the
                     BIE   header  anywhere  later  in  the  data
                     stream. Normally  pbmtojbg  never  generates
                     NEWLEN marker segments, as it knows the cor-
                     rect  image  height  when  it  outputs   the
                     header.  This  option is solely intended for
                     the purpose of generating  test  files  with
                     NEWLEN  marker  segments.  It can be used to
                     specify a higher initial  image  height  for
                     use  in  the  BIE  header, and pbmtojbg will
                     then add a NEWLEN marker segment at the lat-
                     est  possible opportunity to the data stream
                     to signal the correct final height.

       -v            After the BIE has been created, a few  tech-
                     nical  details  of  the created file will be
                     listed (verbose mode).

BUGS
       Using standard input and standard output for  binary  data
       works only on systems where there is no difference between
       binary and text streams (e.g.,  Unix).  On  other  systems
       (e.g.,  MS-DOS),  using  standard input or standard output
       may cause control characters like CR or LF to be  inserted
       or deleted and this will damage the binary data.

STANDARDS
       This  program  implements the JBIG1 image coding algorithm
       as specified in ISO/IEC 11544:1993 and ITU-T T.82(1993).

AUTHOR
       The pbmtojbg program is  part  of  the  JBIG-KIT  package,
       which  has been developed by Markus Kuhn.  The most recent
       version of this portable JBIG1 library and  tools  set  is
       available  from <http://www.cl.cam.ac.uk/~mgk25/jbigkit/>.

SEE ALSO
       pbm(5), pgm(5), jbgtopbm(1)



                            2003-06-04                PBMTOJBG(1)

Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to [email protected].