Matplotlib Cheatsheet
data:image/s3,"s3://crabby-images/6a1ef/6a1efac65229d65b1dca69b3d9ea28af1fc6c21b" alt=""
data:image/s3,"s3://crabby-images/e45d5/e45d58320d6da842b355e966289b3e5169a74958" alt=""
data:image/s3,"s3://crabby-images/a8187/a81877f2be28972994921f58d649d7f38cf3989d" alt=""
data:image/s3,"s3://crabby-images/85c2a/85c2a3c30dcf63a7c343a6478d0f854724677716" alt=""
data:image/s3,"s3://crabby-images/09551/095512742648c6893ba5339fc754ed542fe906a8" alt=""
data:image/s3,"s3://crabby-images/2a021/2a021cf7e463d42848ea1a35d8af240c11337d31" alt=""
data:image/s3,"s3://crabby-images/8e2cb/8e2cbc7df37ce12570dae4fe6925d3de15a09756" alt=""
data:image/s3,"s3://crabby-images/2af5f/2af5f8f3f62bc2877e66081d66319863fc920b66" alt=""
data:image/s3,"s3://crabby-images/fbfba/fbfba1a3465e42c38718fffbf96b55fcdd2d52b4" alt=""
data:image/s3,"s3://crabby-images/3cac0/3cac0882078a9439f37bee8a21223b2346bd2a03" alt=""
data:image/s3,"s3://crabby-images/8b487/8b487ee560df6fbab412ba0b27c9e97784dc12b9" alt=""
data:image/s3,"s3://crabby-images/ac4cc/ac4ccee7e34792e26809e0a10f41ec81502c81f6" alt=""
Basic 2-Axis Plots
Simple Line Plot
data:image/s3,"s3://crabby-images/6a1ef/6a1efac65229d65b1dca69b3d9ea28af1fc6c21b" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-np.pi, np.pi, np.pi/64.0)
x = np.sin(t)
plt.plot(t, x)
plt.show()
Subplot Horizontal
data:image/s3,"s3://crabby-images/e45d5/e45d58320d6da842b355e966289b3e5169a74958" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-np.pi, np.pi, np.pi/64.0)
x = np.sin(t)
y = np.cos(t)
plt.subplot(1, 2, 1)
plt.plot(t, x)
plt.subplot(1, 2, 2)
plt.plot(t, y)
plt.show()
Subplot Vertical
data:image/s3,"s3://crabby-images/a94f1/a94f111f7262380322726885ce580dd5298e49bb" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-np.pi, np.pi, np.pi/64.0)
x = np.sin(t)
y = np.cos(t)
plt.subplot(2, 1, 1)
plt.plot(t, x)
plt.subplot(2, 1, 2)
plt.plot(t, y)
plt.show()
Subplot Gridspec
data:image/s3,"s3://crabby-images/a8187/a81877f2be28972994921f58d649d7f38cf3989d" alt=""
from matplotlib.gridspec import GridSpec
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-np.pi*0.9, np.pi*0.9, np.pi/64.0)
x = np.sin(t)
y = np.cos(t)
z = np.tan(t/2.0)
fig = plt.figure(figsize=(7, 5))
gs = GridSpec(2, 2, figure=fig)
fig.add_subplot(gs[:, 0])
plt.plot(t, z)
fig.add_subplot(gs[0, 1])
plt.plot(t, x)
fig.add_subplot(gs[1, 1])
plt.plot(t, y)
plt.show()
Mutliple Figures
See the real python guide on matplotlib’s figure/axes/axis heirachy.
data:image/s3,"s3://crabby-images/3fbe0/3fbe0d989533ba410b1373749aafc96aed6e69f8" alt=""
data:image/s3,"s3://crabby-images/c3923/c39237259aced267708b27708fc0125bb3bb9ace" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-np.pi, np.pi, np.pi/64.0)
x = np.sin(t)
y = np.cos(t)
fig1 = plt.figure()
ax1 = fig1.add_subplot()
ax1.plot(t, x, 'g')
ax1.set_title("Sinusoid")
fig2 = plt.figure()
ax2 = fig2.add_subplot()
ax2.plot(t, y, 'r')
ax2.set_title("Cosine")
plt.tight_layout()
plt.show()
Bar Plots
Simple Bar Plot
data:image/s3,"s3://crabby-images/85c2a/85c2a3c30dcf63a7c343a6478d0f854724677716" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-10.5, 11.5, 1.0)
x = np.sin(t * np.pi/11.0)
plt.bar(t, x, align='center', alpha=0.5)
plt.show()
Labelled Bar Plot
data:image/s3,"s3://crabby-images/1389e/1389e02ed0f4fee60ab2dd848ac8112047a2c6e3" alt=""
import matplotlib.pyplot as plt
labels = ["Raditz", "Goku", "Napa", "Vegeta", "Piccolo"]
values = [1500, 8000, 4000, 18000, 3500]
plt.bar(labels, values, align='center', alpha=0.5)
plt.title("Power Levels")
plt.show()
Colored Bar Plot
data:image/s3,"s3://crabby-images/09551/095512742648c6893ba5339fc754ed542fe906a8" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-10.5, 11.5, 1.0)
x = np.sin(t * np.pi/11.0)
colors = ["tab:red", "tab:olive", "tab:green",
"tab:cyan", "tab:blue", "tab:purple"]
plt.bar(t, x, align='center', alpha=0.5, color=colors)
plt.show()
Labelled Bar Values
data:image/s3,"s3://crabby-images/2a021/2a021cf7e463d42848ea1a35d8af240c11337d31" alt=""
import matplotlib.pyplot as plt
labels = ["Raditz", "Goku", "Napa", "Vegeta", "Piccolo"]
values = [1500, 8000, 4000, 18000, 3500]
colors = ["tab:olive", "tab:red", "tab:blue", "tab:purple",
"tab:green"]
fig = plt.figure()
ax = fig.add_subplot()
rects = ax.bar(labels, values, align='center', alpha=0.5,
color=colors)
plt.title("Power Levels")
for rect in rects:
y = rect.get_height()
x = rect.get_x() + rect.get_width()/2.0
ax.annotate('{:d}'.format(y), xy=(x, y),
xytext=(0, -3), textcoords="offset points",
ha='center', va='top', color='white')
plt.show()
3D Plots
Simple Mesh
data:image/s3,"s3://crabby-images/8e2cb/8e2cbc7df37ce12570dae4fe6925d3de15a09756" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.linspace(0, 2 * np.pi, 101)
x, y = np.meshgrid(t, t)
z = np.cos(x) - np.sin(y)
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.plot_wireframe(x, y, z)
plt.show()
Simple Surface
data:image/s3,"s3://crabby-images/2af5f/2af5f8f3f62bc2877e66081d66319863fc920b66" alt=""
import matplotlib.pyplot as plt
import numpy as np
SIZE = 101
u, v = np.meshgrid(np.linspace(-np.pi, np.pi, SIZE),
np.linspace(0, np.pi, SIZE))
x = np.cos(u)*np.sin(v)
y = np.sin(u)*np.sin(v)
z = np.cos(v)
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.plot_surface(x, y, z, alpha=0.5)
ax.plot_wireframe(x, y, z, color='w', rstride=10,
cstride=10, alpha=0.5)
plt.show()
Colored 3D Plot
See Matplotlib colormaps for a list of avaliable colormaps.
data:image/s3,"s3://crabby-images/fbfba/fbfba1a3465e42c38718fffbf96b55fcdd2d52b4" alt=""
import matplotlib.pyplot as plt
import numpy as np
SIZE = 101
u, v = np.meshgrid(np.linspace(-np.pi, np.pi, SIZE),
np.linspace(0, np.pi, SIZE))
x = np.cos(u)*np.sin(v)
y = np.sin(u)*np.sin(v)
z = np.cos(v)
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
cax = ax.plot_surface(x, y, z, alpha=0.85, cmap="gist_earth")
cbar = fig.colorbar(cax, ticks=[-1, -0.5, 0, 0.5, 1])
cbar.ax.set_yticklabels(['', '-0.5', '0.0', '0.5', ''])
plt.show()
Animation
Simple Animation
data:image/s3,"s3://crabby-images/3cac0/3cac0882078a9439f37bee8a21223b2346bd2a03" alt=""
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
t = np.linspace(0, 2 * np.pi, 101)
fig = plt.figure()
ax = fig.subplots()
ax.set_xlim(np.min(t), np.max(t))
ax.set_ylim(-1.2, 1.2)
line, = ax.plot([], [])
def animate(i):
line.set_data(t,
0.25 * np.sin(i*np.pi/250) * np.sin(6 * t + i * np.pi / 10) +
0.75 * np.cos(i*np.pi/250) * np.sin(t + i * np.pi / 125))
return line,
ani = animation.FuncAnimation(
fig, animate, interval=100, blit=True)
plt.show()
3D Animation
data:image/s3,"s3://crabby-images/8b487/8b487ee560df6fbab412ba0b27c9e97784dc12b9" alt=""
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
t = np.linspace(0, 2 * np.pi, 101)
x, y = np.meshgrid(t, t)
z = np.cos(x) + np.sin(y)
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
def animate(i):
ax.cla()
ax.plot_surface(x, y, z * np.cos(i * np.pi / 20),
alpha=0.95, cmap="gist_earth", vmin=-2, vmax=2)
ax.set_zlim([-2.0, 2.0])
return ax,
ani = animation.FuncAnimation(fig, animate, interval=50)
plt.show()
Saving Plots
Saving a figure
plt.savefig("myplot.png")
or
fig.savefig("myplot.png")
Saving Animated Plots
- It sometimes helps to not have
blit
set to true in the animator save_count
determines the number of frames to save- Will need to install imagemagick (for gifs)
ani = animation.FuncAnimation(
fig, animate, interval=50, save_count=40)
ani.save('myAnimation.gif', writer='imagemagick', dpi=64)
Style Sheets
See MatplotLib style sheet docs.
data:image/s3,"s3://crabby-images/2910f/2910fe522d98e930829e3bf95b14282e84c014cf" alt=""
data:image/s3,"s3://crabby-images/ac4cc/ac4ccee7e34792e26809e0a10f41ec81502c81f6" alt=""
import matplotlib.pyplot as plt
import numpy as np
t = np.linspace(-np.pi, np.pi, 101)
theta = np.linspace(-np.pi, np.pi, 8)
x = np.array([t, ] * 8).transpose()
y = np.sin(x + np.array([theta, ] * 101))
with plt.style.context("dark_background"):
plt.plot(x, y, '-')
plt.show()
More styles:
data:image/s3,"s3://crabby-images/48f38/48f380540bed26d00cf767782a6258ad75b5a568" alt=""
data:image/s3,"s3://crabby-images/679b7/679b786cd60d69ce0bc86fa141ebb80d61919a38" alt=""
data:image/s3,"s3://crabby-images/393b1/393b1460ddf0c2ffa1690f853444b51c29dfafbd" alt=""
data:image/s3,"s3://crabby-images/3e9ea/3e9eae5940f1d8bd39a626b9a95643539206a1a8" alt=""
Some nice tricks
data:image/s3,"s3://crabby-images/5c9bf/5c9bfc91f45f71ce0b0b1da243c06e636b79128b" alt=""
twinx()
allows us to plot on a different y-scaletight_layout()
rearranges plot elements so they fit nicely
import matplotlib.pyplot as plt
import numpy as np
t = np.arange(-np.pi, np.pi, np.pi/64.0)
x = np.sin(t)
y = 10*np.cos(t)
fig1 = plt.figure()
ax1 = fig1.add_subplot()
ax1.plot(t, x, 'g')
ax1.set_ylabel("Sinusoid")
ax2 = ax1.twinx()
ax2.plot(t, y, ':r')
ax2.set_ylabel("Cosine")
fig1.tight_layout()
plt.show()