Вот другой подход, использующий animation
:
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
interval = 100 # in ms
rescale_axis = False
# Properties of the data
num_batches = 10
num_obs = [20, 30, 10]
feature_names = ['X VALUE', 'Y VALUE', 'Z VALUE']
feature_colors = ['red', 'green', 'blue']
num_features = len(feature_names)
data_to_plot = [np.random.rand(num_batches, num_obs[f]) for f in range(num_features)]
# Create the figure
plt.style.use('dark_background')
fig, axes = plt.subplots(num_features, 1)
fig.canvas.set_window_title('1D Analysis')
# Initial plot
lines = []
for f in range(num_features):
line, = axes[f].plot(data_to_plot[f][0, :], c=feature_colors[f])
lines.append(line)
axes[f].set_ylabel(feature_names[f])
if not rescale_axis:
axes[f].set_ylim(0, 1)
def plot_stuff(xyz):
x, y, z = xyz
for f, data in enumerate([x, y, z]):
lines[f].set_data([ix for ix in range(len(data))], data)
if rescale_axis:
axes[f].relim()
axes[f].autoscale_view()
return lines
def data_gen():
for x, y, z in zip(*data_to_plot):
yield x, y, z
ani = animation.FuncAnimation(fig, plot_stuff, data_gen, interval=interval)
ani.save('results.gif', dpi=80, writer='imagemagick')
plt.show()
, из которого можно даже извлечь вывод .gif: data:image/s3,"s3://crabby-images/855a2/855a29bcaa18db1a28683f256c9b20f6662231b1" alt="git output example"
Однако яЯ провел такой визуальный анализ данных, и много раз вам приходилось переходить назад и вперед при просмотре результатов, занимая время для одних графиков, в то время как другие не такие интересные, и вы просто их быстро пропускаете.
Я знаю, что это не то, что вы просили, но, возможно, было бы полезно сохранить графики в .pdf
вместо этого, с каждым графиком на отдельной странице:
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.backends.backend_pdf import PdfPages
rescale_axis = False
output_pdf_file = 'results.pdf'
# Properties of the data
num_batches = 10
num_obs = [20, 30, 10]
feature_names = ['X VALUE', 'Y VALUE', 'Z VALUE']
feature_colors = ['red', 'green', 'blue']
num_features = len(feature_names)
data_to_plot = [np.random.rand(num_batches, num_obs[f]) for f in range(num_features)]
# Create the figure
plt.style.use('dark_background')
fig, axes = plt.subplots(num_features, 1)
fig.canvas.set_window_title('1D Analysis')
# Initial plot
lines = []
for f in range(num_features):
line, = axes[f].plot(data_to_plot[f][0, :], c=feature_colors[f])
lines.append(line)
axes[f].set_ylabel(feature_names[f])
if not rescale_axis:
axes[f].set_ylim(0, 1)
def plot_stuff(x, y, z):
for f, data in enumerate([x, y, z]):
lines[f].set_data([ix for ix in range(len(data))], data)
if rescale_axis:
axes[f].relim()
axes[f].autoscale_view()
return lines
with PdfPages(output_pdf_file) as pdf:
for x, y, z in zip(*data_to_plot):
plot_stuff(x, y, z)
pdf.savefig()