NAME

Image::Leptonica::Func::gplot

VERSION

version 0.03

gplot.c

gplot.c

   Basic plotting functions
        GPLOT      *gplotCreate()
        void        gplotDestroy()
        l_int32     gplotAddPlot()
        l_int32     gplotSetScaling()
        l_int32     gplotMakeOutput()
        l_int32     gplotGenCommandFile()
        l_int32     gplotGenDataFiles()

   Quick and dirty plots
        l_int32     gplotSimple1()
        l_int32     gplotSimple2()
        l_int32     gplotSimpleN()

   Serialize for I/O
        GPLOT      *gplotRead()
        l_int32     gplotWrite()


   Utility for programmatic plotting using gnuplot 7.3.2 or later
   Enabled:
       - output to png (color), ps (mono), x11 (color), latex (mono)
       - optional title for graph
       - optional x and y axis labels
       - multiple plots on one frame
       - optional title for each plot on the frame
       - optional log scaling on either or both axes
       - choice of 5 plot styles for each plot
       - choice of 2 plot modes, either using one input array
         (Y vs index) or two input arrays (Y vs X).  This
         choice is made implicitly depending on the number of
         input arrays.

   Usage:
       gplotCreate() initializes for plotting
       gplotAddPlot() for each plot on the frame
       gplotMakeOutput() to generate all output files and run gnuplot
       gplotDestroy() to clean up

   Example of use:
       gplot = gplotCreate("tempskew", GPLOT_PNG, "Skew score vs angle",
                  "angle (deg)", "score");
       gplotAddPlot(gplot, natheta, nascore1, GPLOT_LINES, "plot 1");
       gplotAddPlot(gplot, natheta, nascore2, GPLOT_POINTS, "plot 2");
       gplotSetScaling(gplot, GPLOT_LOG_SCALE_Y);
       gplotMakeOutput(gplot);
       gplotDestroy(&gplot);

   Note for output to GPLOT_LATEX:
       This creates latex output of the plot, named <rootname>.tex.
       It needs to be placed in a latex file <latexname>.tex
       that precedes the plot output with, at a minimum:
         \documentclass{article}
         \begin{document}
       and ends with
         \end{document}
       You can then generate a dvi file <latexname>.dvi using
         latex <latexname>.tex
       and a PostScript file <psname>.ps from that using
         dvips -o <psname>.ps <latexname>.dvi

FUNCTIONS

gplotAddPlot

l_int32 gplotAddPlot ( GPLOT *gplot, NUMA *nax, NUMA *nay, l_int32 plotstyle, const char *plottitle )

gplotAddPlot()

    Input:  gplot
            nax (<optional> numa: set to null for Y_VS_I;
                 required for Y_VS_X)
            nay (numa: required for both Y_VS_I and Y_VS_X)
            plotstyle (GPLOT_LINES, GPLOT_POINTS, GPLOT_IMPULSES,
                       GPLOT_LINESPOINTS, GPLOT_DOTS)
            plottitle  (<optional> title for individual plot)
    Return: 0 if OK, 1 on error

Notes:
    (1) There are 2 options for (x,y) values:
          o  To plot an array vs the index, set nax = NULL.
          o  To plot one array vs another, use both nax and nay.
    (2) If nax is defined, it must be the same size as nay.
    (3) The 'plottitle' string can have spaces, double
        quotes and backquotes, but not single quotes.

gplotCreate

GPLOT * gplotCreate ( const char *rootname, l_int32 outformat, const char *title, const char *xlabel, const char *ylabel )

gplotCreate()

    Input:  rootname (root for all output files)
            outformat (GPLOT_PNG, GPLOT_PS, GPLOT_EPS, GPLOT_X11,
                       GPLOT_LATEX)
            title  (<optional> overall title)
            xlabel (<optional> x axis label)
            ylabel (<optional> y axis label)
    Return: gplot, or null on error

Notes:
    (1) This initializes the plot.
    (2) The 'title', 'xlabel' and 'ylabel' strings can have spaces,
        double quotes and backquotes, but not single quotes.

gplotDestroy

void gplotDestroy ( GPLOT **pgplot )

gplotDestroy()

     Input: &gplot (<to be nulled>)
     Return: void

gplotGenCommandFile

l_int32 gplotGenCommandFile ( GPLOT *gplot )

gplotGenCommandFile()

    Input:  gplot
    Return: 0 if OK, 1 on error

gplotGenDataFiles

l_int32 gplotGenDataFiles ( GPLOT *gplot )

gplotGenDataFiles()

    Input:  gplot
    Return: 0 if OK, 1 on error

gplotMakeOutput

l_int32 gplotMakeOutput ( GPLOT *gplot )

gplotMakeOutput()

    Input:  gplot
    Return: 0 if OK; 1 on error

Notes:
    (1) This uses gplot and the new arrays to add a plot
        to the output, by writing a new data file and appending
        the appropriate plot commands to the command file.
    (2) The gnuplot program for windows is wgnuplot.exe.  The
        standard gp426win32 distribution does not have a X11 terminal.

gplotRead

GPLOT * gplotRead ( const char *filename )

gplotRead()

    Input:  filename
    Return: gplot, or NULL on error

gplotSetScaling

l_int32 gplotSetScaling ( GPLOT *gplot, l_int32 scaling )

gplotSetScaling()

    Input:  gplot
            scaling (GPLOT_LINEAR_SCALE, GPLOT_LOG_SCALE_X,
                     GPLOT_LOG_SCALE_Y, GPLOT_LOG_SCALE_X_Y)
    Return: 0 if OK; 1 on error

Notes:
    (1) By default, the x and y axis scaling is linear.
    (2) Call this function to set semi-log or log-log scaling.

gplotSimple1

l_int32 gplotSimple1 ( NUMA *na, l_int32 outformat, const char *outroot, const char *title )

gplotSimple1()

    Input:  na (numa; plot Y_VS_I)
            outformat (GPLOT_PNG, GPLOT_PS, GPLOT_EPS, GPLOT_X11,
                       GPLOT_LATEX)
            outroot (root of output files)
            title  (<optional>, can be NULL)
    Return: 0 if OK, 1 on error

Notes:
    (1) This gives a line plot of a numa, where the array value
        is plotted vs the array index.  The plot is generated
        in the specified output format; the title  is optional.
    (2) When calling this function more than once, be sure the
        outroot strings are different; otherwise, you will
        overwrite the output files.

gplotSimple2

l_int32 gplotSimple2 ( NUMA *na1, NUMA *na2, l_int32 outformat, const char *outroot, const char *title )

gplotSimple2()

    Input:  na1 (numa; we plot Y_VS_I)
            na2 (ditto)
            outformat (GPLOT_PNG, GPLOT_PS, GPLOT_EPS, GPLOT_X11,
                       GPLOT_LATEX)
            outroot (root of output files)
            title  (<optional>)
    Return: 0 if OK, 1 on error

Notes:
    (1) This gives a line plot of two numa, where the array values
        are each plotted vs the array index.  The plot is generated
        in the specified output format; the title  is optional.
    (2) When calling this function more than once, be sure the
        outroot strings are different; otherwise, you will
        overwrite the output files.

gplotSimpleN

l_int32 gplotSimpleN ( NUMAA *naa, l_int32 outformat, const char *outroot, const char *title )

gplotSimpleN()

    Input:  naa (numaa; we plot Y_VS_I for each numa)
            outformat (GPLOT_PNG, GPLOT_PS, GPLOT_EPS, GPLOT_X11,
                       GPLOT_LATEX)
            outroot (root of output files)
            title (<optional>)
    Return: 0 if OK, 1 on error

Notes:
    (1) This gives a line plot of all numas in a numaa (array of numa),
        where the array values are each plotted vs the array index.
        The plot is generated in the specified output format;
        the title  is optional.
    (2) When calling this function more than once, be sure the
        outroot strings are different; otherwise, you will
        overwrite the output files.

gplotWrite

l_int32 gplotWrite ( const char *filename, GPLOT *gplot )

gplotWrite()

    Input:  filename
            gplot
    Return: 0 if OK; 1 on error

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.