1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400
|
% introduction.tex
%
% The documentation in this file is part of Pyxplot
% <http://www.pyxplot.org.uk>
%
% Copyright (C) 2006-2012 Dominic Ford <coders@pyxplot.org.uk>
% 2008-2012 Ross Church
%
% $Id: introduction.tex 1282 2012-07-29 23:30:47Z dcf21 $
%
% Pyxplot is free software; you can redistribute it and/or modify it under the
% terms of the GNU General Public License as published by the Free Software
% Foundation; either version 2 of the License, or (at your option) any later
% version.
%
% You should have received a copy of the GNU General Public License along with
% Pyxplot; if not, write to the Free Software Foundation, Inc., 51 Franklin
% Street, Fifth Floor, Boston, MA 02110-1301, USA
% ----------------------------------------------------------------------------
% LaTeX source for the Pyxplot Users' Guide
\chapter{Introduction}
\label{ch:introduction}
\section{What is Pyxplot?}
Pyxplot is a multi-purpose graph plotting tool, scientific scripting language,
vector graphics suite, and data processing package. Its interface is designed
to make common tasks -- e.g., plotting labelled graphs of data -- accessible
via short, simple, intuitive commands.
But these commands also take many optional settings, allowing their output to
be fine-tuned into styles appropriate for printed publications, talks or
websites. Pyxplot is simple enough to be used without prior programming
experience, but powerful enough that programmers can extensively configure and
script it.
\noindent{\bf A scientific scripting language}
Pyxplot doesn't just plot graphs. It's a scripting language in which variables
can have physical units. Calculations automatically return results in an
appropriate unit, whether that be kilograms, joules or lightyears. \Datafile s
can be converted straightforwardly from one set of units to another. Meanwhile
Pyxplot has all the other features of a scripting language: flow control and
branching, string manipulation, complex data types, an object-oriented class
structure and straightforward file I/O. It also supports vector and matrix
algebra, can integrate or differentiate expressions, and can numerically solve
systems of equations.
\noindent{\bf A vector graphics suite}
The graphical canvas isn't just for plotting graphs on. Circles, polygons and
ellipses can be drawn to build vector graphics. Colors are a native object type
for easy customisation. For the mathematically minded, Pyxplot's canvas
interfaces cleanly with its vector math environment, so that geometric
construction is easy.
\noindent{\bf A data processing package}
Pyxplot can interpolate data, find best-fit lines, and compile histograms. It
can Fourier transform data, calculate statistics, and output results to new
\datafile s. Where fine control is needed, custom code can be used to process
every data point in a file.
\section{Compatibility with \gnuplot}
Pyxplot's plotting interface is very similar to that of \gnuplot: the commands
used for plotting simple graphs in the two programs are virtually identical.
Gnuplot users will have a head start with Pyxplot -- simple \gnuplot\ scripts
often work in Pyxplot with minimal modification -- although the syntax used
for advanced plotting tasks often differs. Although Pyxplot's programming and
mathematical environment is hugely extended over \gnuplot's to provide a
scripting language and vector graphics environment, we have followed the
latter's preference for short simple command line syntax.
\section{The structure of this manual}
This manual serves both as a tutorial guide to Pyxplot, and also as a reference
manual. Part~I provides a step-by-step tutorial and overview of Pyxplot's
features, including numerous worked examples. Part~II provides a detailed
survey of Pyxplot's plotting and vector graphics commands. Part~III provides an
alphabetical reference to all of Pyxplot's commands, mathematical functions and
plotting options. Finally, the appendices provide information which is likely
to be of more specialist interest.
\section{An introductory tour}
This section provides an overview of the wide range of tasks for which Pyxplot
can be used. Detailed explanations of the syntax of Pyxplot commands will
follow in later chapters, but most of the examples here will work if entered
directly at a Pyxplot command prompt.
\subpart{The mathematical environment}
Pyxplot's mathematical environment comes with many standard functions built-in.
To see a list of them\footnote{See also Chapter~\ref{ch:function_list}.}, type
\begin{verbatim}
show functions
\end{verbatim}
The {\tt show} command is Pyxplot's interactive documentation system; to obtain
a list of things that can be shown type
\begin{verbatim}
show
\end{verbatim}
\noindent Pyxplot is an object-orientated language, and its built-in functions
live in a module called {\tt defaults}. Its members may be listed by {\tt
print}ing the module object.
\begin{verbatim}
print defaults
\end{verbatim}
Taking as an example the built-in function {\tt log10(x)}, it can be evaluated
as in almost any other programming language. The {\tt defaults} module
is special in that its functions are always accessible to the user's namespace:
\vspace{3mm}
\input{fragments/tex/intro_print1.tex}
\vspace{3mm}
\noindent This function returns numerical data, but Pyxplot has other data
types too. For example, the {\tt primeFactors} function returns a list:
\vspace{3mm}
\input{fragments/tex/intro_print2.tex}
\vspace{3mm}
\noindent The {\tt rgb(r,g,b)} function returns a color object, which can be
used in Pyxplot's vector graphics commands:
\vspace{3mm}
\input{fragments/tex/intro_print3.tex}
\vspace{3mm}
\noindent and the {\tt time.fromUnix(t)} function returns a date object from a
Unix time:
\vspace{3mm}
\input{fragments/tex/intro_print4.tex}
\vspace{3mm}
Many commonly-used physical constants are built into Pyxplot's physics module,
{\tt phy}. For example, the speed of light:
\vspace{3mm}
\input{fragments/tex/intro_print5.tex}
\vspace{3mm}
\noindent Numbers in Pyxplot have {\bf physical units}, and hence the speed of
light is displayed in km/s. If you would rather know how many miles light
travels in a year, you can change the display unit, here making use of the fact
that the variable {\tt ans} is always set to the result of the last
calculation:
\vspace{3mm}
\input{fragments/tex/intro_print6.tex}
\vspace{3mm}
\noindent It is easy to use Pyxplot as a {\bf desktop calculator} to solve many
problems which would conventionally need careful conversion between physical
units. For example:
\begin{itemize}
\item What is $80^\circ$F in Celsius?
\vspace{3mm}
\input{fragments/tex/intro_tempConvert.tex}
\vspace{3mm}
\item How long does it take for light to travel from the Sun to the
Earth?\footnote{The astronomical unit (AU) is a unit used by astronomers, equal
to the average distance of the Earth from the Sun.}
\vspace{3mm}
\input{fragments/tex/intro_earthDistance.tex}
\vspace{3mm}
\item What wavelength of light corresponds to the ionisation energy of hydrogen
(13.6\,eV)?\footnote{The electron volt (eV) is a unit of energy used by
physicists.}
\vspace{3mm}
\input{fragments/tex/intro_Hionisation.tex}
\vspace{3mm}
\item What is the escape velocity of the Earth?\footnote{The Earth radius and
Earth mass are defined as units in Pyxplot.}
\vspace{3mm}
\input{fragments/tex/intro_escapeVelocity.tex}
\vspace{3mm}
\end{itemize}
\subpart{Graph plotting}
The simplest way to plot a graph in Pyxplot is simply to follow the {\tt plot}
command with the name of a function to be plotted, e.g.:
\begin{verbatim}
plot sin(x)
\end{verbatim}
\noindent If a \datafile\ is to be plotted, its filename is put in place of a
named function. In this example the fifth column of a \datafile\ is plotted
against the second, including only those \datapoint s where the fourth column
is larger than two:
\begin{verbatim}
plot 'data.dat' using 2:5 select $4>2
\end{verbatim}
In the example below, three Bessel functions are plotted over specified
horizontal and vertical ranges:
\begin{verbatim}
plot [0:10][-0.5:1] besselJ(0,x), besselJ(1,x), besselJ(2,x)
\end{verbatim}
\begin{center}
\includegraphics[width=8cm]{examples/eps/ex_intro_bessel}
\end{center}
\noindent With a little additional configuration, it is possible to produce
three-dimensional plots like this (this example is taken from
Section~\ref{sec:surfaces}; see Example~\ref{ex:surface-sinc}):
\begin{center}
\includegraphics[width=8cm]{examples/eps/ex_surface_sinc}
\end{center}
\noindent It is also possible to produce colormaps with custom color scales;
this is documented in full in Section~\ref{sec:colormaps}. Pyxplot includes
functions for converting wavelengths of light into colors; they are used here
to create a color map of the electromagnetic spectrum:
\begin{center}
\includegraphics[width=7cm]{examples/eps/ex_spectrum_1}
\end{center}
\noindent This pair of images demonstrates RGB color mixing (see
Example~\ref{sec:colmap_custom}):
\begin{center}
\includegraphics[width=6cm]{examples/eps/ex_spectrum_colmix1}
\includegraphics[width=6cm]{examples/eps/ex_spectrum_colmix2}
\end{center}
\subpart{Generating data tables}
Pyxplot can output tables of data to disk, using a similar syntax to that used
for plotting graphs. The data can either be sampled from functions, or read in
from another \datafile:
\begin{verbatim}
tabulate tan(x)
\end{verbatim}
\noindent A common application of the {\tt tabulate} command is filter or
re-format the contents of \datafile s. For example, the command below takes
only the third and seventh columns out of a \datafile, and converts the latter
from degrees into radians:
\begin{verbatim}
tabulate 'data.dat' using 3:$7*unit(deg)/unit(rad)
\end{verbatim}
\noindent The same effect could be achieved by setting radians as the default
unit of angle:
\begin{verbatim}
set unit of angle radians
tabulate 'data.dat' using 3:$7*unit(deg)
\end{verbatim}
\noindent More sophisticated data processing is also possible; this example
produces a histogram of the values in the fourth column of a datafile, and then
outputs that histogram as a new \datafile:
\begin{verbatim}
histogram h() 'data.dat' using 4
tabulate h(x)
\end{verbatim}
\subpart{Solving equations}
Pyxplot can solve systems of equations numerically; the following example
evaluates $\int_{0\,\mathrm{s}}^{2\,\mathrm{s}} x^2\,\mathrm{d}x$:
\vspace{3mm}
\input{fragments/tex/intro_integration.tex}
\vspace{3mm}
\noindent The {\tt solve} command can be used to solve systems of simultaneous equations, such as this system with two variables:
\vspace{3mm}
\input{fragments/tex/intro_simultaneousEq.tex}
\vspace{3mm}
\noindent The {\tt minimise} and {\tt maximise} commands find the extrema of functions; here they are used to find the minimum of the function $\cos(x)$ closest to $x=0.5$:
\vspace{3mm}
\input{fragments/tex/intro_cosMin.tex}
\vspace{3mm}
All of the examples shown so far have used only real numbers, but Pyxplot can
also perform algebra on complex numbers. By default, evaluation of {\tt
sqrt(-1)} throws an error -- the emergence of complex numbers is often an
indication that a calculation has gone wrong -- but complex arithmetic can be
enabled by typing\indcmd{set numerics complex}
\vspace{3mm}
\input{fragments/tex/intro_complex1.tex}
\vspace{3mm}
\noindent Many of the mathematical functions which are built into Pyxplot can take complex arguments, for example
\vspace{3mm}
\input{fragments/tex/intro_complex2.tex}
\vspace{3mm}
\subpart{Vector graphics}
Pyxplot's graph-plotting canvas can also be used for drawing general vector graphics, using simple commands such as:
\begin{verbatim}
box from -8,-4 to 8,4 with fillcolor green
text "Pyxplot" at 2,3
arrow from 0,0 to -4,2
line from -5,0 to 5,0
\end{verbatim}
\noindent These commands are described in detail in
Chapter~\ref{ch:vector_graphics}. They interface neatly to the vector data type
in Pyxplot's mathematical environment, to ease geometric construction. Thus, it
is quite possible for mathematically-minded users to multiply transformation
matrices with position vectors on the graphics canvas to calculate where
objects should be drawn. The following example uses a rotation matrix to draw a
big arrow at angle $\theta$ to the vertical:
\begin{verbatim}
rotate(a) = matrix( [[cos(a),-sin(a)], \
[sin(a), cos(a)] ] )
pos = vector(0,5)*unit(cm)
theta = 30*unit(deg)
arrow from 0,0 to rotate(theta)*pos with linewidth 3
\end{verbatim}
\section{License}
This manual and the software which it describes are both copyright \copyright\
Dominic Ford~2006--2012 and Ross Church~2008--2012. They are distributed under
the GNU General Public License (GPL) Version~2, a copy of which is provided in
the {\tt COPYING} file in this distribution.\index{General Public
License}\index{license} Alternatively, it may be downloaded from the web, from
the following location:\\ \url{http://www.gnu.org/copyleft/gpl.html}.
\section{Spelling conventions}
Throughout this manual, US English is used. However, where spelling differs
between US~and UK~English, Pyxplot recognises both variants. For example, where
the word \texttt{color} appears in Pyxplot syntax, it may also be spelt
\texttt{colour}; \texttt{minimize} may also be spelt \texttt{minimise};
\texttt{gray} may also be spelt \texttt{grey}; \texttt{neighbor} may also be
spelt \texttt{neighbour}; etc.
\section{Acknowledgments}
Pyxplot builds on ideas from several pre-existing open-source software
projects. We like \gnuplot's simple and intuitive interface, and Pyxplot's
command syntax is intentionally very similar, to the point of backwards
compatibility in many cases. Even when designing the entirely new parts of
Pyxplot's syntax, we have followed \gnuplot's preference for short simple
command-line syntax. Early versions of Pyxplot utilised the PyX\index{PyX}
graphics library for Python, and we have borrowed many ideas from it in our new
output engine.
Several people have contributed code to Pyxplot. Michael Rutter provided us
with a copy of his public domain code for converting bitmap images into
PostScript, which we used in the implementation of the {\tt image} command and
the {\tt colormap} plot style. Matthew Smith provided C implementations of the
Airy functions and the Riemann zeta function for general complex inputs, and
helped test Pyxplot's mathematical environment. Zolt\'an V\"or\"os worked on
our development team from 2010 until 2011. John Walker has published public
domain code implementing RGB rendering of the electromagnetic spectrum, which
we use in the {\tt colors.\-wave\-length()} function.
We would also like to thank all the users who have got in touch with us by
email since Pyxplot was first released on the web in~2006. Your feedback and
suggestions have been gratefully received.
Final thanks go to our team of alpha testers, without whose work Pyxplot would
doubtless still contain many more bugs. Especial thanks go to Rachel Holdforth
and Stuart Prescott.
|