Basic Graphics with matplotlib
¶
matplotlib
is quite a low-level library, but most of the other
Python graphics libraries are built on top of it, so it is useful to
know.
In [1]:
%matplotlib inline
In [2]:
import matplotlib.pyplot as plt
import numpy as np
Displaying arrays¶
In [3]:
x = np.random.random((80, 80, 3))
In [4]:
plt.imshow(x)
pass
data:image/s3,"s3://crabby-images/739b0/739b0cbef7a53fe2a6e27685f39fc8346c58c412" alt="../_images/notebooks_S04_Graphics_Annotated_5_0.png"
In [5]:
plt.imshow(x, interpolation='bicubic')
pass
data:image/s3,"s3://crabby-images/4549d/4549dedf8e3193231326b76d8b8b65b3a2d87bde" alt="../_images/notebooks_S04_Graphics_Annotated_6_0.png"
In [6]:
plt.imshow(x.mean(axis=-1), cmap='bone')
pass
data:image/s3,"s3://crabby-images/8da5f/8da5f54b92d7e6faf8e6886844aae10f00bf9161" alt="../_images/notebooks_S04_Graphics_Annotated_7_0.png"
In [7]:
plt.imshow(x.mean(axis=-1), cmap='Reds')
plt.xticks(range(0, x.shape[1], 4))
plt.yticks(range(0, x.shape[0], 4))
plt.grid(color='white')
ax = plt.gca()
ax.set_xticklabels([])
ax.set_yticklabels([])
ax.xaxis.set_ticks_position('none')
ax.yaxis.set_ticks_position('none')
pass
data:image/s3,"s3://crabby-images/3d055/3d0553ecd1c932ca7b77d53f31de7b82a76faf8b" alt="../_images/notebooks_S04_Graphics_Annotated_8_0.png"
Line plots¶
In [8]:
import scipy.stats as stats
In [9]:
x = np.linspace(-5, 5, 100)
y = stats.norm().pdf(x)
plt.plot(x, y)
pass
data:image/s3,"s3://crabby-images/d971d/d971daa955fd640b9acfc94f21a17ee8409525b1" alt="../_images/notebooks_S04_Graphics_Annotated_11_0.png"
In [10]:
xs = np.c_[np.zeros(10), np.random.choice([-1,1], (10, 100)).cumsum(axis=1)]
plt.plot(xs.T)
plt.title('10 random walks', fontsize=14)
pass
data:image/s3,"s3://crabby-images/101a0/101a06f2323d0f70850a4751183a663fded1aeb8" alt="../_images/notebooks_S04_Graphics_Annotated_12_0.png"
Scatter plots¶
In [11]:
xs = np.random.multivariate_normal([0,0], np.array([[1,0.5],[0.5, 1]]), 100)
In [12]:
d = np.linalg.norm(xs, ord=2, axis=1)
plt.scatter(xs[:, 0], xs[:, 1], c=d, cmap='jet')
plt.axis('square')
plt.xticks([])
plt.yticks([])
pass
data:image/s3,"s3://crabby-images/932e7/932e7a48d667e474ad54ce2a44113209cc182e84" alt="../_images/notebooks_S04_Graphics_Annotated_15_0.png"
Contour plots¶
In [13]:
x = y = np.linspace(-5, 5, 100)
X, Y = np.meshgrid(x, y)
Z = X**2 + Y**2
plt.contourf(X, Y, Z, cmap=plt.cm.RdPu)
plt.axis('square')
pass
data:image/s3,"s3://crabby-images/22859/2285942d2bd4b9ca0a3ad32185b0320feb95934f" alt="../_images/notebooks_S04_Graphics_Annotated_17_0.png"
Histograms¶
In [14]:
xs = [np.random.normal(mu, 0.5, (100)) for mu in range(5)]
In [15]:
for x in xs:
plt.hist(x, bins=15, alpha=0.4)
data:image/s3,"s3://crabby-images/2bca4/2bca42bf84d044a21750c98cb25adcb1ee29255a" alt="../_images/notebooks_S04_Graphics_Annotated_20_0.png"
Overlaying a density function¶
In [16]:
x = np.random.randn(100)
plt.hist(x, bins=25, histtype='step', normed=True)
mu, sigma = stats.norm.fit(x)
xp = np.linspace(*plt.xlim(), 100)
plt.plot(xp, stats.norm(mu, sigma).pdf(xp))
plt.xlabel('x')
plt.ylabel('Density')
plt.title('MLE fit for normal distribution', fontsize=14)
pass
data:image/s3,"s3://crabby-images/bca32/bca32d97d9c4df598c21fc5d297f3be85ff2e38c" alt="../_images/notebooks_S04_Graphics_Annotated_22_0.png"
Styles¶
In [17]:
plt.style.available
Out[17]:
['seaborn-dark',
'seaborn-darkgrid',
'seaborn-ticks',
'fivethirtyeight',
'seaborn-whitegrid',
'classic',
'_classic_test',
'seaborn-talk',
'seaborn-dark-palette',
'seaborn-bright',
'seaborn-pastel',
'grayscale',
'seaborn-notebook',
'ggplot',
'seaborn-colorblind',
'seaborn-muted',
'seaborn',
'seaborn-paper',
'bmh',
'seaborn-white',
'dark_background',
'seaborn-poster',
'seaborn-deep']
In [18]:
with plt.style.context('ggplot'):
x = np.random.randn(100)
plt.hist(x, bins=25, histtype='step', normed=True)
mu, sigma = stats.norm.fit(x)
xp = np.linspace(*plt.xlim(), 100)
plt.plot(xp, stats.norm(mu, sigma).pdf(xp))
plt.xlabel('x')
plt.ylabel('Density')
plt.title('MLE fit for normal distribution', fontsize=14)
data:image/s3,"s3://crabby-images/e96aa/e96aab40d3a1e8aa4779dccfa53215901dea9d6d" alt="../_images/notebooks_S04_Graphics_Annotated_25_0.png"
If you intend to teach statistics to elementary school children …
In [19]:
with plt.xkcd():
x = np.random.randn(100)
plt.hist(x, bins=25, histtype='step', normed=True)
mu, sigma = stats.norm.fit(x)
xp = np.linspace(*plt.xlim(), 100)
plt.plot(xp, stats.norm(mu, sigma).pdf(xp))
plt.xlabel('x')
plt.ylabel('Density')
plt.title('MLE fit for normal distribution', fontsize=14)
data:image/s3,"s3://crabby-images/7d8f2/7d8f23ed4a92799ad991a71b4f00c3114c0b4379" alt="../_images/notebooks_S04_Graphics_Annotated_27_0.png"
Multiple plots¶
In [20]:
fig, axes = plt.subplots(2, 3, figsize=(9,6), sharey=True)
for i, ax in enumerate(axes.ravel(), 1):
ax.plot(np.random.rand(10), '-o')
ax.set_title('Plot %d' % i, fontsize=16)
ax.set_facecolor((1,0,1,0.2))
plt.tight_layout()
data:image/s3,"s3://crabby-images/67fc8/67fc807efd189119001e782433b1897e83a7f3fd" alt="../_images/notebooks_S04_Graphics_Annotated_29_0.png"