The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Image::Leptonica::Func::binreduce

VERSION

version 0.04

binreduce.c

  binreduce.c

      Subsampled 2x reduction
           PIX      *pixReduceBinary2()

      Rank filtered 2x reductions
           PIX      *pixReduceRankBinaryCascade()
           PIX      *pixReduceRankBinary2()

      Permutation table for 2x rank binary reduction
           l_uint8  *makeSubsampleTab2x(void)

FUNCTIONS

makeSubsampleTab2x

l_uint8 * makeSubsampleTab2x ( void )

  makeSubsampleTab2x()

  This table permutes the bits in a byte, from
      0 4 1 5 2 6 3 7
  to
      0 1 2 3 4 5 6 7

pixReduceBinary2

PIX * pixReduceBinary2 ( PIX *pixs, l_uint8 *intab )

  pixReduceBinary2()

      Input:  pixs
              tab (<optional>; if null, a table is made here
                   and destroyed before exit)
      Return: pixd (2x subsampled), or null on error

  Notes:
      (1) After folding, the data is in bytes 0 and 2 of the word,
          and the bits in each byte are in the following order
          (with 0 being the leftmost originating pair and 7 being
          the rightmost originating pair):
               0 4 1 5 2 6 3 7
          These need to be permuted to
               0 1 2 3 4 5 6 7
          which is done with an 8-bit table generated by makeSubsampleTab2x().

pixReduceRankBinary2

PIX * pixReduceRankBinary2 ( PIX *pixs, l_int32 level, l_uint8 *intab )

  pixReduceRankBinary2()

      Input:  pixs (1 bpp)
              level (rank threshold: 1, 2, 3, 4)
              intab (<optional>; if null, a table is made here
                     and destroyed before exit)
      Return: pixd (1 bpp, 2x rank threshold reduced), or null on error

  Notes:
      (1) pixd is downscaled by 2x from pixs.
      (2) The rank threshold specifies the minimum number of ON
          pixels in each 2x2 region of pixs that are required to
          set the corresponding pixel ON in pixd.
      (3) Rank filtering is done to the UL corner of each 2x2 pixel block,
          using only logical operations.  Then these pixels are chosen
          in the 2x subsampling process, subsampled, as described
          above in pixReduceBinary2().

pixReduceRankBinaryCascade

PIX * pixReduceRankBinaryCascade ( PIX *pixs, l_int32 level1, l_int32 level2, l_int32 level3, l_int32 level4 )

  pixReduceRankBinaryCascade()

      Input:  pixs (1 bpp)
              level1, ... level 4 (thresholds, in the set {0, 1, 2, 3, 4})
      Return: pixd, or null on error

  Notes:
      (1) This performs up to four cascaded 2x rank reductions.
      (2) Use level = 0 to truncate the cascade.

AUTHOR

Zakariyya Mughal <zmughal@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Zakariyya Mughal.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.