Редактировать: В настоящее время проще и лучше использовать matplotlib.animation
:
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
def animate(frameno):
x = mu + sigma * np.random.randn(10000)
n, _ = np.histogram(x, bins, normed=True)
for rect, h in zip(patches, n):
rect.set_height(h)
return patches
mu, sigma = 100, 15
fig, ax = plt.subplots()
x = mu + sigma * np.random.randn(10000)
n, bins, patches = plt.hist(x, 50, normed=1, facecolor='green', alpha=0.75)
ani = animation.FuncAnimation(fig, animate, blit=True, interval=10,
repeat=True)
plt.show()
Существует пример создания анимированного графика здесь .Основываясь на этом примере, вы можете попробовать что-то вроде:
import numpy as np
import matplotlib.pyplot as plt
plt.ion()
mu, sigma = 100, 15
fig = plt.figure()
x = mu + sigma*np.random.randn(10000)
n, bins, patches = plt.hist(x, 50, normed=1, facecolor='green', alpha=0.75)
for i in range(50):
x = mu + sigma*np.random.randn(10000)
n, bins = np.histogram(x, bins, normed=True)
for rect,h in zip(patches,n):
rect.set_height(h)
fig.canvas.draw()
Таким образом, я могу получить около 14 кадров в секунду, по сравнению с 4 кадрами в секунду, используя код I , впервые опубликованный .Хитрость заключается в том, чтобы не просить matplotlib рисовать полные фигуры.Вместо этого вызовите plt.hist
один раз, затем манипулируйте существующими matplotlib.patches.Rectangle
s в patches
, чтобы обновить гистограмму, и вызовите fig.canvas.draw()
, чтобы сделать обновления видимыми.