pranavjha/text-detector

View on GitHub
third-party/leptonica/prog/pixcomp_reg.c

Summary

Maintainability
Test Coverage
/*====================================================================*
 -  Copyright (C) 2001 Leptonica.  All rights reserved.
 -
 -  Redistribution and use in source and binary forms, with or without
 -  modification, are permitted provided that the following conditions
 -  are met:
 -  1. Redistributions of source code must retain the above copyright
 -     notice, this list of conditions and the following disclaimer.
 -  2. Redistributions in binary form must reproduce the above
 -     copyright notice, this list of conditions and the following
 -     disclaimer in the documentation and/or other materials
 -     provided with the distribution.
 -
 -  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 -  ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 -  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 -  A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL ANY
 -  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 -  EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 -  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 -  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 -  OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 -  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 -  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *====================================================================*/

/*
 * pixcomp_reg.c
 *
 *    Regression test for compressed pix and compressed pix arrays
 *    in memory.
 *
 *    Most of the functions tested here require the ability to write
 *    a pix to a compressed string in memory, and conversely to
 *    read a compressed image string from memory to generate a pix.
 *    The gnu runtime provides fmemopen() and open_memstream().  If
 *    these are not available, we work around this by writing data
 *    to a temp file.
 */

#include <math.h>
#include "allheaders.h"


LEPT_DLL extern const char *ImageFileFormatExtensions[];
static void get_format_data(l_int32 i, l_uint8 *data, size_t size);

#define  DO_PNG     1  /* set to 0 for valgrind to remove most png errors */

int main(int    argc,
         char **argv)
{
l_int32     i, n;
BOX        *box;
PIX        *pix, *pixs, *pixd, *pixd2;
PIXA       *pixad, *pixa1, *pixa2, *pixa3;
PIXC       *pixc;
PIXAC      *pixac, *pixac1, *pixac2;

    pixad = pixaCreate(0);

        /* --- Read in the images --- */
    pixac = pixacompCreate(1);
    pixs = pixRead("marge.jpg");
    pixc = pixcompCreateFromPix(pixs, IFF_JFIF_JPEG);
    pixd = pixCreateFromPixcomp(pixc);
    pixSaveTiledOutline(pixd, pixad, 1, 1, 30, 2, 32);
    pixDestroy(&pixd);
    pixcompDestroy(&pixc);
    pixacompAddPix(pixac, pixs, IFF_DEFAULT);
    pixDestroy(&pixs);

    pix = pixRead("feyn.tif");
    pixs = pixScaleToGray6(pix);
    pixc = pixcompCreateFromPix(pixs, IFF_JFIF_JPEG);
    pixd = pixCreateFromPixcomp(pixc);
    pixSaveTiledOutline(pixd, pixad, 1.0, 0, 30, 2, 32);
    pixDestroy(&pixd);
    pixcompDestroy(&pixc);
    pixacompAddPix(pixac, pixs, IFF_DEFAULT);
    pixDestroy(&pixs);

    box = boxCreate(1144, 611, 690, 180);
    pixs = pixClipRectangle(pix, box, NULL);
    pixc = pixcompCreateFromPix(pixs, IFF_TIFF_G4);
    pixd = pixCreateFromPixcomp(pixc);
    pixSaveTiledOutline(pixd, pixad, 1.0, 0, 30, 2, 32);
    pixDestroy(&pixd);
    pixcompDestroy(&pixc);
    pixacompAddPix(pixac, pixs, IFF_DEFAULT);
    pixDestroy(&pixs);
    boxDestroy(&box);
    pixDestroy(&pix);

#if DO_PNG
    pixs = pixRead("weasel4.11c.png");
    pixc = pixcompCreateFromPix(pixs, IFF_PNG);
    pixd = pixCreateFromPixcomp(pixc);
    pixSaveTiledOutline(pixd, pixad, 1.0, 0, 30, 2, 32);
    pixDestroy(&pixd);
    pixcompDestroy(&pixc);
    pixacompAddPix(pixac, pixs, IFF_DEFAULT);
    pixDestroy(&pixs);
#endif

        /* --- Retrieve to pix --- */
    n = pixacompGetCount(pixac);
    for (i = 0; i < n; i++) {
        pixs = pixacompGetPix(pixac, i);
        pixSaveTiledOutline(pixs, pixad, 1.0, i == 0 ? 1 : 0, 30, 2, 32);
        pixDestroy(&pixs);
    }

        /* --- Retrieve to pixa --- */
    pixa1 = pixaCreateFromPixacomp(pixac, L_CLONE);
    for (i = 0; i < n; i++) {
        pixs = pixaGetPix(pixa1, i, L_CLONE);
        pixSaveTiledOutline(pixs, pixad, 1.0, i == 0 ? 1 : 0, 30, 2, 32);
        pixDestroy(&pixs);
    }

        /* --- Do (pixa <==> pixac) conversions --- */
    pixaWrite("/tmp/junkpixa1.pa", pixa1);
    pixac1 = pixacompCreateFromPixa(pixa1, IFF_DEFAULT, L_CLONE);
    pixa2 = pixaCreateFromPixacomp(pixac1, L_CLONE);
    pixaWrite("/tmp/junkpixa2.pa", pixa2);
    pixac2 = pixacompCreateFromPixa(pixa2, IFF_DEFAULT, L_CLONE);
    pixa3 = pixaCreateFromPixacomp(pixac2, L_CLONE);
    pixaWrite("/tmp/junkpixa3.pa", pixa3);

        /* --- Extract formatting info from compressed strings --- */
    for (i = 0; i < n; i++) {
        pixc = pixacompGetPixcomp(pixac1, i);
        get_format_data(i, pixc->data, pixc->size);
    }

        /* --- Display results --- */
    pixd = pixaDisplay(pixad, 0, 0);
    pixDisplay(pixd, 100, 100);
    pixWrite("/tmp/junkcomp.jpg", pixd, IFF_JFIF_JPEG);
    pixDestroy(&pixd);
    pixaDestroy(&pixad);

    pixaDestroy(&pixa1);
    pixaDestroy(&pixa2);
    pixaDestroy(&pixa3);
    pixacompDestroy(&pixac);
    pixacompDestroy(&pixac1);
    pixacompDestroy(&pixac2);

        /* --- Read all the 'weasel' files and display results --- */
    pixac = pixacompCreateFromFiles(".", "weasel", IFF_DEFAULT);
    fprintf(stderr, "found %d weasel files\n", pixacompGetCount(pixac));
    pixcompWriteStreamInfo(stderr, pixac->pixc[7], NULL);
    pixd = pixacompDisplayTiledAndScaled(pixac, 32, 100, 8, 0, 15, 2);
    pixWrite("/tmp/junkweasel.jpg", pixd, IFF_JFIF_JPEG);
    pixDisplay(pixd, 100, 100);
    pixacompDestroy(&pixac);
    pixDestroy(&pixd);

        /* --- Use serialized I/O on the pixacomp --- */
    pixac = pixacompCreateFromFiles(".", "hardlight", IFF_DEFAULT);
    fprintf(stderr, "found %d jpg files\n", pixacompGetCount(pixac));
    pixd = pixacompDisplayTiledAndScaled(pixac, 32, 200, 6, 0, 15, 2);
    pixWrite("/tmp/junkhardlight.png", pixd, IFF_PNG);
    pixDisplay(pixd, 100, 300);
    pixacompWrite("/tmp/junkpixac1.pa", pixac);
    pixac2 = pixacompRead("/tmp/junkpixac1.pa");
    pixacompWrite("/tmp/junkpixac2.pa", pixac2);
    pixd2 = pixacompDisplayTiledAndScaled(pixac2, 32, 1200, 4, 0, 30, 2);
    pixDisplay(pixd2, 500, 300);
    pixacompWriteStreamInfo(stderr, pixac2, NULL);
    pixacompDestroy(&pixac);
    pixacompDestroy(&pixac2);
    pixDestroy(&pixd);
    pixDestroy(&pixd2);

        /* --- Read all the 'tif' files and display results --- */
    pixac = pixacompCreateFromFiles(".", ".tif", IFF_DEFAULT);
    fprintf(stderr, "found %d tiff files\n", pixacompGetCount(pixac));
    pixcompWriteStreamInfo(stderr, pixac->pixc[0], NULL);
    pixd = pixacompDisplayTiledAndScaled(pixac, 32, 200, 6, 0, 15, 2);
    pixWrite("/tmp/junktiffs.png", pixd, IFF_PNG);
    pixDisplay(pixd, 100, 500);
    pixacompDestroy(&pixac);
    pixDestroy(&pixd);

    return 0;
}


static void
get_format_data(l_int32   i,
                l_uint8  *data,
                size_t    size)
{
l_int32  ret, format, w, h, d, bps, spp, iscmap;

    ret = pixReadHeaderMem(data, size, &format, &w, &h, &bps, &spp, &iscmap);
    d = bps * spp;
    if (d == 24) d = 32;
    if (ret)
        fprintf(stderr, "Error: couldn't read data: size = %d\n",
                (l_int32)size);
    else
        fprintf(stderr, "Format data for image %d:\n"
                "  format: %s, size (w, h, d) = (%d, %d, %d)\n"
                "  bps = %d, spp = %d, iscmap = %d\n",
                i, ImageFileFormatExtensions[format], w, h, d,
                bps, spp, iscmap);
    return;
}