Я пытаюсь построить несколько графиков через субплот.Код «работает», но он всегда дает мне ошибку индекса, которую я не могу понять на всю жизнь.
В качестве дополнительного вопроса мне было интересно, знает ли кто-нибудь, как сохранить каждый отдельный графиктот же размер.Например, если я добавлю больше строк или столбцов, то каждый график станет меньше.Спасибо.
count = 0
n_rows = 2
n_columns = 2
f, axarr = plt.subplots(n_rows, n_columns)
plt.figure(figsize=(20,20))
for column in range(n_cols):
for row in range(n_rows):
axarr[row, column].imshow(generate_pattern('block3_conv1', count, size=150))
count += 1

Ошибка
IndexError Traceback (most recent call last)
<ipython-input-37-7f7ae19e07e9> in <module>()
7 for column in range(n_cols):
8 for row in range(n_rows):
----> 9 axarr[row, column].imshow(generate_pattern('block3_conv1', count, size=150))
10
11 count += 1
IndexError: index 2 is out of bounds for axis 1 with size 2
Код для используемых функций
def generate_pattern(layer_name, filter_index, size=150):
# Build a loss function that maximizes the activation
# of the nth filter of the layer considered.
layer_output = model.get_layer(layer_name).output
loss = K.mean(layer_output[:, :, :, filter_index])
# Compute the gradient of the input picture wrt this loss
grads = K.gradients(loss, model.input)[0]
# Normalization trick: we normalize the gradient
grads /= (K.sqrt(K.mean(K.square(grads))) + 1e-5)
# This function returns the loss and grads given the input picture
iterate = K.function([model.input], [loss, grads])
# We start from a gray image with some noise
input_img_data = np.random.random((1, size, size, 3)) * 20 + 128.
# Run gradient ascent for 40 steps
step = 1.
for i in range(40):
loss_value, grads_value = iterate([input_img_data])
input_img_data += grads_value * step
img = input_img_data[0]
return deprocess_image(img)
def deprocess_image(x):
x -= x.mean()
x /= (x.std() + 1e-5)
x *= 0.1
x += 0.5
x = np.clip(x,0,1)
x *= 255
x = np.clip(x,0,255).astype('uint8')
return x