python - Keras-vis 给出以下错误 : AttributeError: Multiple inbound nodes

标签 python deep-learning keras

我正在尝试关注 this example用我自己的模型看起来像这样:

_________________________________________________________________
Layer (type)                 Output Shape              Param #   
=================================================================
input_2 (InputLayer)         (None, 150, 150, 3)       0         
_________________________________________________________________
block1_conv1 (Conv2D)        (None, 150, 150, 64)      1792      
_________________________________________________________________
block1_conv2 (Conv2D)        (None, 150, 150, 64)      36928     
_________________________________________________________________
block1_pool (MaxPooling2D)   (None, 75, 75, 64)        0         
_________________________________________________________________
block2_conv1 (Conv2D)        (None, 75, 75, 128)       73856     
_________________________________________________________________
block2_conv2 (Conv2D)        (None, 75, 75, 128)       147584    
_________________________________________________________________
block2_pool (MaxPooling2D)   (None, 37, 37, 128)       0         
_________________________________________________________________
block3_conv1 (Conv2D)        (None, 37, 37, 256)       295168    
_________________________________________________________________
block3_conv2 (Conv2D)        (None, 37, 37, 256)       590080    
_________________________________________________________________
block3_conv3 (Conv2D)        (None, 37, 37, 256)       590080    
_________________________________________________________________
block3_pool (MaxPooling2D)   (None, 18, 18, 256)       0         
_________________________________________________________________
block4_conv1 (Conv2D)        (None, 18, 18, 512)       1180160   
_________________________________________________________________
block4_conv2 (Conv2D)        (None, 18, 18, 512)       2359808   
_________________________________________________________________
block4_conv3 (Conv2D)        (None, 18, 18, 512)       2359808   
_________________________________________________________________
block4_pool (MaxPooling2D)   (None, 9, 9, 512)         0         
_________________________________________________________________
block5_conv1 (Conv2D)        (None, 9, 9, 512)         2359808   
_________________________________________________________________
block5_conv2 (Conv2D)        (None, 9, 9, 512)         2359808   
_________________________________________________________________
block5_conv3 (Conv2D)        (None, 9, 9, 512)         2359808   
_________________________________________________________________
block5_pool (MaxPooling2D)   (None, 4, 4, 512)         0         
_________________________________________________________________
sequential_1 (Sequential)    (None, 1)                 2097665   
=================================================================

但是我得到这个错误:

AttributeError: Layer sequential_2 has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use get_output_at(node_index) instead.

我不知道从哪里开始。经过一番搜索后,我认为这与最后一层是顺序层而不是示例中 VGG16 模型中的密集层有关。

该模型类似于来自 Keras 的 Cat 或 Dog 示例,并进行了微调。

如果我能从这里得到任何帮助或想法,我将不胜感激!

编辑: 如果它有助于查看代码:

model = load_model('final_finetuned_model.h5')

layer_idx = utils.find_layer_idx(model, 'sequential_1')

model.layers[layer_idx].activation = activations.linear
model = utils.apply_modifications(model)

plt.rcParams['figure.figsize'] = (18, 6)

img1 = utils.load_img('test1/cat/5.jpg', target_size=(150, 150))
img2 = utils.load_img('test1/cat/6.jpg', target_size=(150, 150))

for modifier in [None, 'guided', 'relu']:
    plt.figure()
    f, ax = plt.subplots(1, 2)
    plt.suptitle("vanilla" if modifier is None else modifier)
    for i, img in enumerate([img1, img2]):
        # 20 is the imagenet index corresponding to `ouzel`
        grads = visualize_cam(model, layer_idx, filter_indices=20,
                              seed_input=img, backprop_modifier=modifier)
        # Lets overlay the heatmap onto original image.
        jet_heatmap = np.uint8(cm.jet(grads)[..., :3] * 255)
        ax[i].imshow(overlay(jet_heatmap, img))

plt.show()

最佳答案

对于具有两个输出节点 dense_1_1/Relu:0 和 sequential_2/dense_1/Relu:0 的非常相似的网络,我遇到了类似的错误。我的解决方案是转到 losses.py 并将 layer_output = self.layer.output 更改为 layer_output = self.layer.get_output_at(-1)。这更像是一种解决方法而不是解决方案。当有一个输出节点时,取最后一个 [-1] 就可以了,当有两个节点时,取最后一个对我有用。但这应该会让你领先。也可以尝试 layer_output = self.layer.get_output_at(0) 或其他节点(如果有的话)。 有一个相关的open issue here .

关于python - Keras-vis 给出以下错误 : AttributeError: Multiple inbound nodes,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47440955/

相关文章:

python - 使用钩子(Hook)函数从预训练模型中提取特征

python - TF2/Keras 切片张量使用 [ :, :, 0]

python - 在Keras中,如何对权重矩阵的每一行应用softmax函数?

python - 如何在 python 中使用列表理解修改列表列表中的特定项目

python - iPython为意外的关键字参数 'inputhook'提供了错误

python - 裁剪尺寸 caffe 模型中的错误

machine-learning - 如何将单个单词转换为向量用于神经网络输入

python - 如何计算使用keras训练的语言模型的困惑度?

python - df.plot 添加到自身而不是单独的图中

python - 为什么可以从python中的path.__dict__访问os模块?