PGPLOT, originally developed as a FORTRAN library, is now available with C bindings (which the Perl module uses), though a FORTRAN compiler is still required to build it.
For every PGPLOT C/FORTRAN function the module provides an equivalent Perl function with the same arguments. Thus the user of the module should refer to the PGPLOT manual to learn all about how to use PGPLOT and for the complete list of available functions. This manual comes with the PGPLOT distribution and is also available at the WWW address:
http://astro.caltech.edu/~tjp/pgplot/
Also refer to the extensive set of test scripts (test*.p
) included
in the module distribution for examples of usage of all kinds of
PGPLOT routines.
How the FORTRAN/C function calls map on to Perl calls is detailed below.
Any FORTRAN REAL/INTEGER/CHARACTER* scalar variable maps to a Perl scalar (Perl doesn't care about the differences between strings and numbers and ints and floats).
Thus you can say:
To draw a line to point (42,$x):
To plot 10 points with data in Perl arrays @x
and @y
with plot symbol
no. 17. Note the Perl arrays are passed by reference:
You can also use the old Perl4 style:
but this is deprecated in Perl5.
Label the axes:
Draw ONE point, see how when N=1
pgpoint()
can take a scalar as well as
a array argument:
pggray
) take 2D arrays as
arguments. Several schemes are provided to allow efficient use
from Perl:
Here @x is a 1D array of 1D arrays. (Confused? - see perldata(1)).
Alternatively @x could be a flat 1D array with 128x128 elements, 2D
routines such as pggray()
etc. are programmed to do the right thing
as long as the number of elements match.
Here the read()
function reads the binary data from a file and the
pggray()
function displays it as a grey-scale image.
This saves unpacking the image data in to a potentially very large 2D
perl array. However the types must match. The string must be packed as a
``f*''
for example to use pggray
. This is intended as a short-cut for
sophisticated users. Even more sophisticated users will want to download
the PDL
module which provides a wealth of functions for manipulating
binary data.
pgfunx
) take functions as callback
arguments. In Perl simply pass a subroutine reference or a name,
e.g.:
If your scalar variable (e.g. $x
) holds binary data (i.e. 'packed')
then simply pass PGPLOT a reference to it (e.g. \$x
). Thus one can
say:
This is very efficient as we can be sure the data never gets copied and will always be interpreted as binary.
Again see the PDL
module for sophisticated manipulation of
binary data. PDL
takes great advantage of these facilities.
Be VERY careful binary data is of the right size or your segments might get violated.