NAME

Image::Leptonica::Func::regutils

VERSION

version 0.03

regutils.c

regutils.c

     Regression test utilities
         l_int32    regTestSetup()
         l_int32    regTestCleanup()
         l_int32    regTestCompareValues()
         l_int32    regTestCompareStrings()
         l_int32    regTestComparePix()
         l_int32    regTestCompareSimilarPix()
         l_int32    regTestCheckFile()
         l_int32    regTestCompareFiles()
         l_int32    regTestWritePixAndCheck()

     Static function
         char      *getRootNameFromArgv0()

See regutils.h for how to use this.  Here is a minimal setup:

main(int argc, char **argv) {
...
L_REGPARAMS  *rp;

    if (regTestSetup(argc, argv, &rp))
        return 1;
    ...
    regTestWritePixAndCheck(rp, pix, IFF_PNG);  // 0
    ...
    return regTestCleanup(rp);
}

FUNCTIONS

regTestCheckFile

l_int32 regTestCheckFile ( L_REGPARAMS *rp, const char *localname )

regTestCheckFile()

    Input:  rp (regtest parameters)
            localname (name of output file from reg test)
    Return: 0 if OK, 1 on error (a failure in comparison is not an error)

Notes:
    (1) This function does one of three things, depending on the mode:
         * "generate": makes a "golden" file as a copy @localname.
         * "compare": compares @localname contents with the golden file
         * "display": makes the @localname file but does no comparison
    (2) The canonical format of the golden filenames is:
          /tmp/golden/<root of main name>_golden.<index>.<ext of localname>
        e.g.,
           /tmp/golden/maze_golden.0.png
        It is important to add an extension to the local name, because
        the extension is added to the name of the golden file.

regTestCleanup

l_int32 regTestCleanup ( L_REGPARAMS *rp )

regTestCleanup()

    Input:  rp (regression test parameters)
    Return: 0 if OK, 1 on error

Notes:
    (1) This copies anything written to the temporary file to the
        output file /tmp/reg_results.txt.

regTestCompareFiles

l_int32 regTestCompareFiles ( L_REGPARAMS *rp, l_int32 index1, l_int32 index2 )

regTestCompareFiles()

    Input:  rp (regtest parameters)
            index1 (of one output file from reg test)
            index2 (of another output file from reg test)
    Return: 0 if OK, 1 on error (a failure in comparison is not an error)

Notes:
    (1) This only does something in "compare" mode.
    (2) The canonical format of the golden filenames is:
          /tmp/golden/<root of main name>_golden.<index>.<ext of localname>
        e.g.,
          /tmp/golden/maze_golden.0.png

regTestComparePix

l_int32 regTestComparePix ( L_REGPARAMS *rp, PIX *pix1, PIX *pix2 )

regTestComparePix()

    Input:  rp (regtest parameters)
            pix1, pix2 (to be tested for equality)
    Return: 0 if OK, 1 on error (a failure in comparison is not an error)

Notes:
    (1) This function compares two pix for equality.  On failure,
        this writes to stderr.

regTestCompareSimilarPix

l_int32 regTestCompareSimilarPix ( L_REGPARAMS *rp, PIX *pix1, PIX *pix2, l_int32 mindiff, l_float32 maxfract, l_int32 printstats )

regTestCompareSimilarPix()

    Input:  rp (regtest parameters)
            pix1, pix2 (to be tested for near equality)
            mindiff (minimum pixel difference to be counted; > 0)
            maxfract (maximum fraction of pixels allowed to have
                      diff greater than or equal to mindiff)
            printstats (use 1 to print normalized histogram to stderr)
    Return: 0 if OK, 1 on error (a failure in similarity comparison
            is not an error)

Notes:
    (1) This function compares two pix for near equality.  On failure,
        this writes to stderr.
    (2) The pix are similar if the fraction of non-conforming pixels
        does not exceed @maxfract.  Pixels are non-conforming if
        the difference in pixel values equals or exceeds @mindiff.
        Typical values might be @mindiff = 15 and @maxfract = 0.01.
    (3) The input images must have the same size and depth.  The
        pixels for comparison are typically subsampled from the images.
    (4) Normally, use @printstats = 0.  In debugging mode, to see
        the relation between @mindiff and the minimum value of
        @maxfract for success, set this to 1.

regTestCompareStrings

l_int32 regTestCompareStrings ( L_REGPARAMS *rp, l_uint8 *string1, size_t bytes1, l_uint8 *string2, size_t bytes2 )

regTestCompareStrings()

    Input:  rp (regtest parameters)
            string1 (typ. the expected string)
            bytes1 (size of string1)
            string2 (typ. the computed string)
            bytes2 (size of string2)
    Return: 0 if OK, 1 on error (a failure in comparison is not an error)

regTestCompareValues

l_int32 regTestCompareValues ( L_REGPARAMS *rp, l_float32 val1, l_float32 val2, l_float32 delta )

regTestCompareValues()

    Input:  rp (regtest parameters)
            val1 (typ. the golden value)
            val2 (typ. the value computed)
            delta (allowed max absolute difference)
    Return: 0 if OK, 1 on error (a failure in comparison is not an error)

regTestWritePixAndCheck

l_int32 regTestWritePixAndCheck ( L_REGPARAMS *rp, PIX *pix, l_int32 format )

regTestWritePixAndCheck()

    Input:  rp (regtest parameters)
            pix (to be written)
            format (of output pix)
    Return: 0 if OK, 1 on error (a failure in comparison is not an error)

Notes:
    (1) This function makes it easy to write the pix in a numbered
        sequence of files, and either to:
           (a) write the golden file ("generate" arg to regression test)
           (b) make a local file and "compare" with the golden file
           (c) make a local file and "display" the results
    (3) The canonical format of the local filename is:
          /tmp/<root of main name>.<count>.<format extension string>
        e.g., for scale_reg,
          /tmp/scale.0.png

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.