Matplotlib from brain surgery to rocket science John
Matplotlib: from brain surgery to rocket science John D. Hunter, Ph. D. Perry Greenfield, Ph. D. http: //matplotlib. sourceforge. net
brain surgery…
dongle
pbrain
loc 3 djr http: //pbrain. sourceforge. net
The three stages of python • Matlab hell • Python purgatory • The path to enlightenment
3 D python fantastic, but 2 D? Py. X, Chart. Director, biggles, DISLIN, gnuplot, chaco, xplt, gplt, pyngl, ppgplot, tkinter canvas, gtkextras, pychart, gist, piddle, graphite…. • Multiple plotting idioms • Cross platform • Publication quality • Permissive license • Extensible (by me!) • Easy plots should be easy (OO not always best) • But app embedding should be supported (OO sometimes best) • GUI agnosticism • The curse of python
# matplotlib 0. 1 ~/python/matplot_gtk 12> ls README matplotlib. py subplot_demo. py data simple_plot. py view_data. py matplot. py stock_demo. py vline_demo. py # matplotlib 0. 73 53 python modules 17 files of extension code 44, 000 lines of code 130 examples • 2 -5 active developers at any time; 25 contributors • Co-developed with NASA STSc. I and JPL • 1200 -1500 downloads/month • approx 10 messages per/day on mailing list
Copy the great architectures E Tufte
backends
The matplotlib API from matplotlib. backends. backend_agg import Figure. Canvas. Agg as Figure. Canvas from matplotlib. figure import Figure fig = Figure() canvas = Figure. Canvas(fig) ax = fig. add_subplot(111) ax. plot([1, 2, 3]) a ax. set_title('hi mom') ax. grid(True) ax. set_xlabel('time') ax. set_ylabel('volts') fig. savefig('test')
• Plotting should just work • Easy plots should be easy pylab interface • GUI / interactive complexity should be managed • ipython to the rescue IPython 0. 6. 12_cvs -- An enhanced Interactive Python. ? -> Introduction to IPython's features. %magic -> Information about IPython's 'magic' % functions. help -> Python's own help system. object? -> Details about 'object'. ? object also works, ? ? prints more. Welcome to pylab, a matplotlib-based Python environment help(matplotlib) -> generic matplotlib information help(pylab) -> matlab-compatible commands from matplotlib help(plotting) -> plotting commands In [1]: plot([1, 2, 3])
The numerix module # numarray # Numeric from Numeric import array, where from MLab import std from Numeric import convolve from FFT import fft from numarray import array, where from numarray. linear_algebra. mlab import std from numarray. convolve import convolve from numarray. fft import fft # matplotlib. numerix from matplotlib. numerix import array, where from matplotlib. numerix. mlab import, mean, std # choose numeric or numarray from the shell C: > python myscript. py --numarray # or in an rc file setting numerix : ‘numarray’
• Cross platform font finding: win 32, linux, OS X • Configurable families: the font engine will pick the best font to match your requirements font manager • W 3 C compliant font. family : sans-serif font. style : normal font. variant : normal font. weight : medium font. stretch : normal font. size : medium font. serif : New Century Schoolbook, Century Schoolbook L, Utopia, ITC Bookman, Bitstream Vera Serif, Nimbus Roman No 9 L, Times New Roman, Times, Palatino, Charter, serif font. sans-serif : Lucida Grande, Verdana, Geneva, Lucida,
tex = r'$cal{R}prod_{i=alpha_{i+1}}^infty a_I … rm{sin}(2 pi f x_i)$' text(1, 1. 6, tex, fontsize=30) mathtext demo
bar demo
stacked bar
pie demo
scatter demo
histogram demo
log demo
polar demo
layer image
subplot demo
axes demo
legend demo
text alignment
mathtext demo 2
basemap toolkit cylindrical equidistant, mercator, lambert conformal conic, lambert azimuthal equal area, albers equal area conic and stereographic.
stock demo
finance demo
MRI with eeg
EEG demo
VTK demo
Did I talk about? • Event handling • set/set Introspection • RC configuration • Embedding • Dynamic/animated plots • Math text • Contouring • Toolkits / basemap • Font management
…from astronomy to zoology? • • Basic 3 D Different colorspaces (CMYK) Arbitrary clipping paths, gradient/pattern fills Unicode support & better Te. X support Domain specific toolkits SWF, PDF, Aqua, … Direction fields, arrows, etc
MATPLOTLIB CREDITS (in order of appearance…) • • • Jeremy O'Donoghue wrote the wx backend Andrew Straw provided much of the log scaling architecture, the fill command, PIL support for imshow, and provided many examples Charles Twardy provided the impetus code for the legend class and has made countless bug reports and suggestions for improvement. Gary Ruben made many enhancements to errorbar to support x and y errorbar plots, and added a number of new marker types to plot. John Gill wrote the table class and examples David Moore wrote the paint backend Todd Miller contributed the Tk. Agg backend and the numerix module, which allows matplotlib to work with either numeric or numarray. He also ported image support to the postscript backend, with much pain and suffering. Paul Barrett overhauled font management to provide an improved, free-standing, platform independent font manager with a WC 3 compliant font finder and cache mechanism and ported truetype and mathtext to PS Perry Greenfield overhauled and modernized the goals and priorities page, implemented an improved colormap framework, and has provided many suggestions and a lot of insight to the overall design and organization of matplotlib. Jared Wahlstrand wrote the SVG backend
MATPLOTLIB CREDITS (continued) • • • Steve Chaplin is the GTK maintainer and wrote the Cairo and GTKCairo backends Jim Benson provided the patch to handle vertical mathttext Gregory Lielens provided the Fltk. Agg backend and several patches for the frontend, including contributions to toolbar 2, and support for log ticking with alternate bases and major and minor log ticking Darren Dale did the work to do mathtext exponential labeling for log plots. Paul Mcguire provided the pyparsing module on which mathtext relies, and made a number of optimizations to the matplotlib mathtext grammar. Fernando Perez has provided numerous bug reports and patches for cleaning up backend imports and expanding pylab functionality, and provided matplotlib support in the pylab mode for ipython. He also provided the matshow command. Andrew Dalke of Dalke Scientific Software contributed the strftime formatting code to handle years earlier than 1900 Jochen Voss maintained the PS backend and has contributed several bugfixes. Nadia Dencheva of STSc. I provided the contouring and contour labeling code Baptiste Carvello provided the key ideas in a patch for proper shared axes support that underlies ganged plots and multiscale plots Sigve Tjoraand Ted Drain and colleagues at the JPL collaborated on the Qt. Agg backend Eric Firing added the contourf function and general contour refactoring
pie demo
- Slides: 39