import matplotlib.pyplot as plt
import numpy as np
mu, sigma = 100, 15
x = mu + sigma * np.random.randn(10000)
hist, bins = np.histogram(x, bins=50)
width = 0.7 * (bins[1] - bins[0])
center = (bins[:-1] + bins[1:]) / 2
plt.bar(center, hist, align='center', width=width)
plt.show()
data:image/s3,"s3://crabby-images/bf032/bf032206ccedc01522313858ed7e1c4e92024c4c" alt="insira a descrição da imagem aqui"
A interface orientada a objetos também é direta:
fig, ax = plt.subplots()
ax.bar(center, hist, align='center', width=width)
fig.savefig("1.png")
Se estiver usando escaninhos personalizados (não constantes), você pode passar calcular as larguras usando np.diff
, passar as larguras para ax.bar
e usar ax.set_xticks
para rotular as bordas do depósito:
import matplotlib.pyplot as plt
import numpy as np
mu, sigma = 100, 15
x = mu + sigma * np.random.randn(10000)
bins = [0, 40, 60, 75, 90, 110, 125, 140, 160, 200]
hist, bins = np.histogram(x, bins=bins)
width = np.diff(bins)
center = (bins[:-1] + bins[1:]) / 2
fig, ax = plt.subplots(figsize=(8,3))
ax.bar(center, hist, align='center', width=width)
ax.set_xticks(bins)
fig.savefig("/tmp/out.png")
plt.show()
data:image/s3,"s3://crabby-images/7fddc/7fddc79dd00084523a80dff86b62a886f3bfeb7d" alt="insira a descrição da imagem aqui"