Introduction to matplotlib
#
Note
This material is mostly adapted from the following resources:
Matplotlib is a comprehensive library for creating static and animated visualizations in Python.
Website: https://matplotlib.org/
GitHub: matplotlib/matplotlib
Note
Documentation for this package is available at https://matplotlib.org/stable/index.html.
Note
If you have not yet set up Python on your computer, you can execute this tutorial in your browser via Google Colab. Click on the rocket in the top right corner and launch “Colab”. If that doesn’t work download the .ipynb
file and import it in Google Colab
Then, install numpy
and matplotlib
by executing the following command in a Jupyter cell at the top of the notebook.
We will use numpy
to create some of the data that we will visualize with matplotlib
.
!pip install matplotlib numpy
Importing a Package#
Besides numpy, we import the module pyplot
from the matplotlib
library and nicknames it as plt
for brevity in the code.
import numpy as np
from matplotlib import pyplot as plt
Visualizing Arrays with Matplotlib#
Let’s create an array to visualize it.
x = np.linspace(-2 * np.pi, 2 * np.pi, 100)
y = np.linspace(-np.pi, np.pi, 50)
xx, yy = np.meshgrid(x, y)
xx.shape, yy.shape
((50, 100), (50, 100))
For plotting a 1D array as a line, we use the plot
command.
plt.plot(x);
data:image/s3,"s3://crabby-images/07d36/07d36a2266d6dce33ddab23e22e3e6ef20a6ffb5" alt="_images/6c16a6f2637dfb4f96853c90e9b73c317aa42457bc5d46c13a26e3b2fec1af0a.png"
There are many ways to visualize 2D data.
He we use pcolormesh
.
plt.pcolormesh(xx);
data:image/s3,"s3://crabby-images/b5859/b5859120d76bf483ccbb319d7290ad6583172af9" alt="_images/48ca3aa98966c2069e1aa100938f36ecbf0df2d8675c03726aa7b5dca936d9d6.png"
f = np.sin(xx) * np.cos(0.5 * yy)
plt.pcolormesh(f)
<matplotlib.collections.QuadMesh at 0x7f6978716f90>
data:image/s3,"s3://crabby-images/cee74/cee7460cd27fb32cb4f7ed4e9896a21c11f9c43f" alt="_images/80b9fff0cb274566b8e3d3590907d18a28d5d970ab43332a743070cc0f847b15.png"
g = f * x
plt.pcolormesh(g)
<matplotlib.collections.QuadMesh at 0x7f6978312250>
data:image/s3,"s3://crabby-images/2896f/2896ff02bb1456b8d48d8a4f4399db092b79e6bb" alt="_images/b46593f18e4cbb445af2aa985f6e7fdc065b5608a909e80250315da28b6ce24c.png"
# apply on just one axis
g_ymean = g.mean(axis=0)
g_xmean = g.mean(axis=1)
plt.plot(x, g_ymean)
[<matplotlib.lines.Line2D at 0x7f697870fb10>]
data:image/s3,"s3://crabby-images/c2fba/c2fbaeead93c388804da5d518ac8e996ba23ee3d" alt="_images/38e0066018458310c212b110727f176594005fa0ad08c416a93586e857e724c8.png"
plt.plot(g_xmean, y)
[<matplotlib.lines.Line2D at 0x7f697820c250>]
data:image/s3,"s3://crabby-images/5edf4/5edf4f90e8a36f783f8481d824c994147e373a83" alt="_images/ffd3dc4b62cd3506bd30586dd070efe44d7d2d6c9b96215cd75c7af26a501be7.png"
Figures and Axes#
The figure is the highest level of organization of matplotlib
objects.
fig = plt.figure()
<Figure size 640x480 with 0 Axes>
fig = plt.figure(figsize=(13, 5))
<Figure size 1300x500 with 0 Axes>
fig = plt.figure()
ax = fig.add_axes([0, 0, 1, 1])
data:image/s3,"s3://crabby-images/2104c/2104c8177f545a986d55d6c2991d3feb311d9470" alt="_images/8bca872709ac2b0f25d92a4a17e6f88f8c26e62fd976798443d98310b3ed3224.png"
Subplots#
Subplot syntax is a more convenient way to specify the creation of multiple axes.
fig, ax = plt.subplots()
data:image/s3,"s3://crabby-images/418d6/418d6cf29f2f0ec3068d5497ff8e5a4f4ac58875" alt="_images/9e13561b06f5d2c575e2e9d0ab28f3ca3efd7ae4d5738c0cd619a55149090489.png"
ax
<Axes: >
fig, axes = plt.subplots(ncols=2, figsize=(8, 4), subplot_kw={"facecolor": "blue"})
data:image/s3,"s3://crabby-images/50d36/50d361833fb241d35271992fdb65268155440bea" alt="_images/851b990779cdb6eee326ec4afebe14ab1ece59045c52c3d2c1608ab3212c47dd.png"
axes
array([<Axes: >, <Axes: >], dtype=object)
Drawing into Axes#
All plots are drawn into axes.
# create some data to plot
import numpy as np
x = np.linspace(-np.pi, np.pi, 100)
y = np.cos(x)
z = np.sin(6 * x)
fig, ax = plt.subplots()
ax.plot(x, y)
[<matplotlib.lines.Line2D at 0x7f6978310190>]
data:image/s3,"s3://crabby-images/94990/94990822c542551098575cb9c61ce4a3d29c2099" alt="_images/db3db9ea422842a926d9652d0f9b87c5e5aad225c18841732ba5e57d8f0b9ea9.png"
This does the same thing as
plt.plot(x, y)
[<matplotlib.lines.Line2D at 0x7f697822bf50>]
data:image/s3,"s3://crabby-images/94990/94990822c542551098575cb9c61ce4a3d29c2099" alt="_images/db3db9ea422842a926d9652d0f9b87c5e5aad225c18841732ba5e57d8f0b9ea9.png"
This starts to matter when we have multiple axes to manage.
fig, axes = plt.subplots(figsize=(8, 4), ncols=2)
ax0, ax1 = axes
ax0.plot(x, y)
ax1.plot(x, z)
[<matplotlib.lines.Line2D at 0x7f6978190a90>]
data:image/s3,"s3://crabby-images/b1c74/b1c741412c8835a1ad94c0659f9ef5bb20d46162" alt="_images/2cb5896f279d2448236869e762009e2589d50fce3e582edead65912555fe2d44.png"
Labeling Plots#
Labeling plots is very important! We want to know what data is shown and what the units are. matplotlib
offers some functions to label graphics.
fig, ax = plt.subplots(figsize=(4, 4))
ax.plot(x, y)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_title("x vs. y")
# squeeze everything in
plt.tight_layout()
data:image/s3,"s3://crabby-images/b5c8c/b5c8c4b0d5a45c4117893dc5d7d6ea12dd79ee36" alt="_images/c95be4a9e39e7cfb7a6fb9eaf58a0a004e48319ae116ae0fae7ff389498b394d.png"
Customizing Plots#
fig, ax = plt.subplots()
ax.plot(x, y, x, z)
[<matplotlib.lines.Line2D at 0x7f69782bb6d0>,
<matplotlib.lines.Line2D at 0x7f696ff0f990>]
data:image/s3,"s3://crabby-images/f6174/f6174f1227ab515bc86b814dbd2b2657003acbb6" alt="_images/7157c9ecb9ed95a8840266ff53bf42160b891b6f9337af0b92a1c2baa6e0408a.png"
It’s simple to switch axes
fig, ax = plt.subplots()
ax.plot(y, x, z, x)
[<matplotlib.lines.Line2D at 0x7f696ffd9990>,
<matplotlib.lines.Line2D at 0x7f696ffe5bd0>]
data:image/s3,"s3://crabby-images/fceed/fceedeea82aa89c8cb1333119521d327f9d905cd" alt="_images/efcfa8b7611b5d9178e68c2586dd228d929c2f0bafcbcc7a63d9331e2e69f90c.png"
Line Styles#
fig, ax = plt.subplots()
ax.plot(x, y, linestyle="--")
ax.plot(x, z, linestyle=":")
[<matplotlib.lines.Line2D at 0x7f696c95ecd0>]
data:image/s3,"s3://crabby-images/f1c71/f1c71e694afe73dd5c53c874c931f4f2ba32b70d" alt="_images/9ab503c6bc7c9c162bdad176920b81c9d7d0b1122b6e24dc8dfb97d62d2821b4.png"
Colors#
As described in the colors documentation, there are some special codes for commonly used colors.
fig, ax = plt.subplots()
ax.plot(x, y, color="black")
ax.plot(x, z, color="red")
[<matplotlib.lines.Line2D at 0x7f696c9aee50>]
data:image/s3,"s3://crabby-images/4a7d2/4a7d2a0cd8848f5b21e5c3fa056d7d1b04db96ef" alt="_images/d0eb2738066ea7eb22a228ec12ee986cfa1ed7cd337fb352b98eb1129a6458b8.png"
Markers#
There are lots of different markers availabile in matplotlib!
fig, ax = plt.subplots()
ax.plot(x[:20], y[:20], marker="o", markerfacecolor="red", markeredgecolor="black")
ax.plot(x[:20], z[:20], marker="^", markersize=10)
[<matplotlib.lines.Line2D at 0x7f696c9d4090>]
data:image/s3,"s3://crabby-images/e95fa/e95faa23e1eb9b0b4c291937b44c377e228dca02" alt="_images/0073d511e649d6d5d5acca463e0a00cafcfadbbe5fdb1b84c463ddffb1660102.png"
Axis Limits#
fig, ax = plt.subplots()
ax.plot(x, y, x, z)
ax.set_xlim(-5, 5)
ax.set_ylim(-3, 3)
(-3.0, 3.0)
data:image/s3,"s3://crabby-images/2f606/2f606ec48124035ebc9c8e145255dc715fb890d5" alt="_images/cbb644a6b0b81247e30707498f13866996d5ce9ca968f64043b9c8bb503443ca.png"
Scatter Plots#
fig, ax = plt.subplots()
splot = ax.scatter(y, z, c=x, s=(100 * z**2 + 5), cmap="viridis")
fig.colorbar(splot)
<matplotlib.colorbar.Colorbar at 0x7f696c8a7ed0>
data:image/s3,"s3://crabby-images/31942/31942e867062f46e7b6f496748f090bbfe2eaa1c" alt="_images/a0b3276f7cd85b4a5d00bea154c34b640e49d49dcba9036909a169003f32141a.png"
There are many different colormaps available in matplotlib: https://matplotlib.org/stable/tutorials/colors/colormaps.html
Bar Plots#
labels = ["Bhadla", "Noor"]
values = [2225, 1177]
fig, ax = plt.subplots(figsize=(5, 5))
ax.bar(labels, values)
ax.set_ylabel("MW")
plt.tight_layout()
data:image/s3,"s3://crabby-images/2400d/2400d82bb09a91653f052eab8d370e8a6d3d9d9f" alt="_images/34e1aae86c9b847901c1d8e7e273b75eda77417e22e3ec6199ddad2d977f1d33.png"