data-science-ipython-notebooks/matplotlib/04.00-Introduction-To-Matplotlib.ipynb

530 lines
98 KiB
Python
Raw Normal View History

{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<!--BOOK_INFORMATION-->\n",
"<img align=\"left\" style=\"padding-right:10px;\" src=\"figures/PDSH-cover-small.png\">\n",
"*This notebook contains an excerpt from the [Python Data Science Handbook](http://shop.oreilly.com/product/0636920034919.do) by Jake VanderPlas; the content is available [on GitHub](https://github.com/jakevdp/PythonDataScienceHandbook).*\n",
"\n",
"*The text is released under the [CC-BY-NC-ND license](https://creativecommons.org/licenses/by-nc-nd/3.0/us/legalcode), and code is released under the [MIT license](https://opensource.org/licenses/MIT). If you find this content useful, please consider supporting the work by [buying the book](http://shop.oreilly.com/product/0636920034919.do)!*\n",
"\n",
"*No changes were made to the contents of this notebook from the original.*"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<!--NAVIGATION-->\n",
"< [Further Resources](03.13-Further-Resources.ipynb) | [Contents](Index.ipynb) | [Simple Line Plots](04.01-Simple-Line-Plots.ipynb) >"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Visualization with Matplotlib"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We'll now take an in-depth look at the Matplotlib package for visualization in Python.\n",
"Matplotlib is a multi-platform data visualization library built on NumPy arrays, and designed to work with the broader SciPy stack.\n",
"It was conceived by John Hunter in 2002, originally as a patch to IPython for enabling interactive MATLAB-style plotting via gnuplot from the IPython command line.\n",
"IPython's creator, Fernando Perez, was at the time scrambling to finish his PhD, and let John know he wouldnt have time to review the patch for several months.\n",
"John took this as a cue to set out on his own, and the Matplotlib package was born, with version 0.1 released in 2003.\n",
"It received an early boost when it was adopted as the plotting package of choice of the Space Telescope Science Institute (the folks behind the Hubble Telescope), which financially supported Matplotlibs development and greatly expanded its capabilities.\n",
"\n",
"One of Matplotlibs most important features is its ability to play well with many operating systems and graphics backends.\n",
"Matplotlib supports dozens of backends and output types, which means you can count on it to work regardless of which operating system you are using or which output format you wish.\n",
"This cross-platform, everything-to-everyone approach has been one of the great strengths of Matplotlib.\n",
"It has led to a large user base, which in turn has led to an active developer base and Matplotlibs powerful tools and ubiquity within the scientific Python world.\n",
"\n",
"In recent years, however, the interface and style of Matplotlib have begun to show their age.\n",
"Newer tools like ggplot and ggvis in the R language, along with web visualization toolkits based on D3js and HTML5 canvas, often make Matplotlib feel clunky and old-fashioned.\n",
"Still, I'm of the opinion that we cannot ignore Matplotlib's strength as a well-tested, cross-platform graphics engine.\n",
"Recent Matplotlib versions make it relatively easy to set new global plotting styles (see [Customizing Matplotlib: Configurations and Style Sheets](04.11-Settings-and-Stylesheets.ipynb)), and people have been developing new packages that build on its powerful internals to drive Matplotlib via cleaner, more modern APIs—for example, Seaborn (discussed in [Visualization With Seaborn](04.14-Visualization-With-Seaborn.ipynb)), [ggpy](http://yhat.github.io/ggpy/), [HoloViews](http://holoviews.org/), [Altair](http://altair-viz.github.io/), and even Pandas itself can be used as wrappers around Matplotlib's API.\n",
"Even with wrappers like these, it is still often useful to dive into Matplotlib's syntax to adjust the final plot output.\n",
"For this reason, I believe that Matplotlib itself will remain a vital piece of the data visualization stack, even if new tools mean the community gradually moves away from using the Matplotlib API directly."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## General Matplotlib Tips\n",
"\n",
"Before we dive into the details of creating visualizations with Matplotlib, there are a few useful things you should know about using the package."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Importing Matplotlib\n",
"\n",
"Just as we use the ``np`` shorthand for NumPy and the ``pd`` shorthand for Pandas, we will use some standard shorthands for Matplotlib imports:"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"import matplotlib as mpl\n",
"import matplotlib.pyplot as plt"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The ``plt`` interface is what we will use most often, as we shall see throughout this chapter."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Setting Styles\n",
"\n",
"We will use the ``plt.style`` directive to choose appropriate aesthetic styles for our figures.\n",
"Here we will set the ``classic`` style, which ensures that the plots we create use the classic Matplotlib style:"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"plt.style.use('classic')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Throughout this section, we will adjust this style as needed.\n",
"Note that the stylesheets used here are supported as of Matplotlib version 1.5; if you are using an earlier version of Matplotlib, only the default style is available.\n",
"For more information on stylesheets, see [Customizing Matplotlib: Configurations and Style Sheets](04.11-Settings-and-Stylesheets.ipynb)."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### ``show()`` or No ``show()``? How to Display Your Plots"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"A visualization you can't see won't be of much use, but just how you view your Matplotlib plots depends on the context.\n",
"The best use of Matplotlib differs depending on how you are using it; roughly, the three applicable contexts are using Matplotlib in a script, in an IPython terminal, or in an IPython notebook."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Plotting from a script\n",
"\n",
"If you are using Matplotlib from within a script, the function ``plt.show()`` is your friend.\n",
"``plt.show()`` starts an event loop, looks for all currently active figure objects, and opens one or more interactive windows that display your figure or figures.\n",
"\n",
"So, for example, you may have a file called *myplot.py* containing the following:\n",
"\n",
"```python\n",
"# ------- file: myplot.py ------\n",
"import matplotlib.pyplot as plt\n",
"import numpy as np\n",
"\n",
"x = np.linspace(0, 10, 100)\n",
"\n",
"plt.plot(x, np.sin(x))\n",
"plt.plot(x, np.cos(x))\n",
"\n",
"plt.show()\n",
"```\n",
"\n",
"You can then run this script from the command-line prompt, which will result in a window opening with your figure displayed:\n",
"\n",
"```\n",
"$ python myplot.py\n",
"```\n",
"\n",
"The ``plt.show()`` command does a lot under the hood, as it must interact with your system's interactive graphical backend.\n",
"The details of this operation can vary greatly from system to system and even installation to installation, but matplotlib does its best to hide all these details from you.\n",
"\n",
"One thing to be aware of: the ``plt.show()`` command should be used *only once* per Python session, and is most often seen at the very end of the script.\n",
"Multiple ``show()`` commands can lead to unpredictable backend-dependent behavior, and should mostly be avoided."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Plotting from an IPython shell\n",
"\n",
"It can be very convenient to use Matplotlib interactively within an IPython shell (see [IPython: Beyond Normal Python](01.00-IPython-Beyond-Normal-Python.ipynb)).\n",
"IPython is built to work well with Matplotlib if you specify Matplotlib mode.\n",
"To enable this mode, you can use the ``%matplotlib`` magic command after starting ``ipython``:\n",
"\n",
"```ipython\n",
"In [1]: %matplotlib\n",
"Using matplotlib backend: TkAgg\n",
"\n",
"In [2]: import matplotlib.pyplot as plt\n",
"```\n",
"\n",
"At this point, any ``plt`` plot command will cause a figure window to open, and further commands can be run to update the plot.\n",
"Some changes (such as modifying properties of lines that are already drawn) will not draw automatically: to force an update, use ``plt.draw()``.\n",
"Using ``plt.show()`` in Matplotlib mode is not required."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Plotting from an IPython notebook\n",
"\n",
"The IPython notebook is a browser-based interactive data analysis tool that can combine narrative, code, graphics, HTML elements, and much more into a single executable document (see [IPython: Beyond Normal Python](01.00-IPython-Beyond-Normal-Python.ipynb)).\n",
"\n",
"Plotting interactively within an IPython notebook can be done with the ``%matplotlib`` command, and works in a similar way to the IPython shell.\n",
"In the IPython notebook, you also have the option of embedding graphics directly in the notebook, with two possible options:\n",
"\n",
"- ``%matplotlib notebook`` will lead to *interactive* plots embedded within the notebook\n",
"- ``%matplotlib inline`` will lead to *static* images of your plot embedded in the notebook\n",
"\n",
"For this book, we will generally opt for ``%matplotlib inline``:"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"%matplotlib inline"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"After running this command (it needs to be done only once per kernel/session), any cell within the notebook that creates a plot will embed a PNG image of the resulting graphic:"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": "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\nZmofgqJFdafJG9Pyz6W
"text/plain": [
"<matplotlib.figure.Figure at 0x10c21e668>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"import numpy as np\n",
"x = np.linspace(0, 10, 100)\n",
"\n",
"fig = plt.figure()\n",
"plt.plot(x, np.sin(x), '-')\n",
"plt.plot(x, np.cos(x), '--');"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Saving Figures to File\n",
"\n",
"One nice feature of Matplotlib is the ability to save figures in a wide variety of formats.\n",
"Saving a figure can be done using the ``savefig()`` command.\n",
"For example, to save the previous figure as a PNG file, you can run this:"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"fig.savefig('my_figure.png')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We now have a file called ``my_figure.png`` in the current working directory:"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"-rw-r--r-- 1 jakevdp staff 16K Aug 11 10:59 my_figure.png\r\n"
]
}
],
"source": [
"!ls -lh my_figure.png"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"To confirm that it contains what we think it contains, let's use the IPython ``Image`` object to display the contents of this file:"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": "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\nzJ3LO4nxoGn0ZfAo6xG
"text/plain": [
"<IPython.core.display.Image object>"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"from IPython.display import Image\n",
"Image('my_figure.png')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"In ``savefig()``, the file format is inferred from the extension of the given filename.\n",
"Depending on what backends you have installed, many different file formats are available.\n",
"The list of supported file types can be found for your system by using the following method of the figure canvas object:"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"{'eps': 'Encapsulated Postscript',\n",
" 'jpeg': 'Joint Photographic Experts Group',\n",
" 'jpg': 'Joint Photographic Experts Group',\n",
" 'pdf': 'Portable Document Format',\n",
" 'pgf': 'PGF code for LaTeX',\n",
" 'png': 'Portable Network Graphics',\n",
" 'ps': 'Postscript',\n",
" 'raw': 'Raw RGBA bitmap',\n",
" 'rgba': 'Raw RGBA bitmap',\n",
" 'svg': 'Scalable Vector Graphics',\n",
" 'svgz': 'Scalable Vector Graphics',\n",
" 'tif': 'Tagged Image File Format',\n",
" 'tiff': 'Tagged Image File Format'}"
]
},
"execution_count": 8,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"fig.canvas.get_supported_filetypes()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Note that when saving your figure, it's not necessary to use ``plt.show()`` or related commands discussed earlier."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Two Interfaces for the Price of One\n",
"\n",
"A potentially confusing feature of Matplotlib is its dual interfaces: a convenient MATLAB-style state-based interface, and a more powerful object-oriented interface. We'll quickly highlight the differences between the two here."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### MATLAB-style Interface\n",
"\n",
"Matplotlib was originally written as a Python alternative for MATLAB users, and much of its syntax reflects that fact.\n",
"The MATLAB-style tools are contained in the pyplot (``plt``) interface.\n",
"For example, the following code will probably look quite familiar to MATLAB users:"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": "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\n++z02qovnWRlWYqvSRO
"text/plain": [
"<matplotlib.figure.Figure at 0x10d658438>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"plt.figure() # create a plot figure\n",
"\n",
"# create the first of two panels and set current axis\n",
"plt.subplot(2, 1, 1) # (rows, columns, panel number)\n",
"plt.plot(x, np.sin(x))\n",
"\n",
"# create the second panel and set current axis\n",
"plt.subplot(2, 1, 2)\n",
"plt.plot(x, np.cos(x));"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"It is important to note that this interface is *stateful*: it keeps track of the \"current\" figure and axes, which are where all ``plt`` commands are applied.\n",
"You can get a reference to these using the ``plt.gcf()`` (get current figure) and ``plt.gca()`` (get current axes) routines.\n",
"\n",
"While this stateful interface is fast and convenient for simple plots, it is easy to run into problems.\n",
"For example, once the second panel is created, how can we go back and add something to the first?\n",
"This is possible within the MATLAB-style interface, but a bit clunky.\n",
"Fortunately, there is a better way."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Object-oriented interface\n",
"\n",
"The object-oriented interface is available for these more complicated situations, and for when you want more control over your figure.\n",
"Rather than depending on some notion of an \"active\" figure or axes, in the object-oriented interface the plotting functions are *methods* of explicit ``Figure`` and ``Axes`` objects.\n",
"To re-create the previous plot using this style of plotting, you might do the following:"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": "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\n++z02qovnWRlWYqvSRO
"text/plain": [
"<matplotlib.figure.Figure at 0x10d64f240>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"# First create a grid of plots\n",
"# ax will be an array of two Axes objects\n",
"fig, ax = plt.subplots(2)\n",
"\n",
"# Call plot() method on the appropriate object\n",
"ax[0].plot(x, np.sin(x))\n",
"ax[1].plot(x, np.cos(x));"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"For more simple plots, the choice of which style to use is largely a matter of preference, but the object-oriented approach can become a necessity as plots become more complicated.\n",
"Throughout this chapter, we will switch between the MATLAB-style and object-oriented interfaces, depending on what is most convenient.\n",
"In most cases, the difference is as small as switching ``plt.plot()`` to ``ax.plot()``, but there are a few gotchas that we will highlight as they come up in the following sections."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<!--NAVIGATION-->\n",
"< [Further Resources](03.13-Further-Resources.ipynb) | [Contents](Index.ipynb) | [Simple Line Plots](04.01-Simple-Line-Plots.ipynb) >"
]
}
],
"metadata": {
"anaconda-cloud": {},
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.4.3"
}
},
"nbformat": 4,
"nbformat_minor": 0
}