=head1 PDL::Graphics::Prima

A PDL plotting library using the Prima toolkit.

This collection of modules provides a PDL-centric 2D plotting library that
is fast, intelligent, multi-platform and highly interactive. Fast because
it's built on the L<PDL::Drawing::Prima> bindings, which make use of the
L<PDL> threading engine to quickly execute large sets of drawing operations.
Intelligent because I have put a lot of thought into important behavior like
autoscaling and smart tick marking and they Do The Right Thing almost every
time, without the need for manual manipulation. Multi-platform and highly
interactive because it is built upon Prima, the Perl-centric multi-platform
set of drawing functions and GUI toolkit, and because interactive behavior
like panning and zooming are built right into the widget.

For more information, see the documentation for L<PDL::Graphics::Prima>. If
you're new, you should check out the documentation for
L<PDL::Graphics::Prima::Simple>.

=head1 INSTALLATION

There are a number of ways to install this distribution. The simplest is to
install it using CPAN:

  cpan PDL::Graphics::Prima

or using cpanm:

  cpanm PDL::Graphics::Prima

If you have your hands on the actual source code (from the git repository
listed below, or by C<look>ing at this distribution from the CPAN shell), you
would do the following:

  # Unix-like systems       Windows systems
  perl Build.PL             perl Build.PL
  ./Build                   Build
  ./Build test              Build test
  ./Build install           Build install

Users of Unix-like systems may need to invoke superuser privileges for the
installation phase if you install the distribution to your system Perl. Most
Perl folks these days avoid tinkering with their system Perl by using
L<local::lib> or L<App::perlbrew>.

Note that there are almost no tests for this distribution at the moment.
Frankly, I'm not sure exactly how to go about testing this sort of
distribution. One thought of mine is to write an interactive series of tests
that asks the user to verify that the generated plots "look right," but I
have not yet implemented any such tests. Patches welcome! However, there are
a number of examples (and as such, test scripts) in the F<examples> directory
in the source distribution if you want to take the library for a spin.

=head1 DEPENDENCIES

This distribution depends on L<PDL::Drawing::Prima>, which has an important and
nontrivial list of dependencies. However, if you have that distribution
installed, this one should work.

L<PDL::Graphics::Prima> requires Perl 5.8. If you don't have that version of
Perl, I recommend installing Strawberry Perl if you're on Windows, or using
perlbrew if you're on Linux or Mac.

=head1 DEVELOPMENT STATUS AND REPOSITORY

This project is being actively developed at Github. Find the latest at
L<https://github.com/PDLPorters/PDL-Graphics-Prima>.

This project is currently in alpha. I say this not because the software is
unstable to execute but because the API is likely to undergo some
substantial revisions under this name. The interface will have settled when
the distribution hits v 1.00, at which point any API changes will coincide
with an increment in the major version number.

In other words, please play around with this library and use it if you like.
However, if you use it in production code, be sure to pay close attention to
the PDL mailing list for updates regarding incompatible changes to the
library. If you find yourself using the library quite a bit, you should
follow it on Github and contribute your thoughts as it progresses.

=head1 COPYRIGHT AND LICENCE

Unless otherwise stated, all contributions in code and documentation are
copyright (c) their respective authors, all rights reserved.

Portions of this distribution's code are copyright (c) 2011 The Board of
Trustees at the University of Illinois.

Portions of this distribution's code are copyright (c) 2011-2013 Northwestern
University.

Portions of this distribution's code are copyright (c) 2013-2014 Dickinson
College.

This distribution's documentation are copyright (c) 2011-2014 David Mertens.

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

Primary Author: David Mertens <dcmertens.perl@gmail.com>