【问题标题】:多输入多输出 TensorFlow 模型
【发布时间】:2022-01-23 07:47:09
【问题描述】:

我正在尝试构建一个 tensorflow 模型,该模型将 3 个图像作为输入,并为每个输入图像提供 3 个输出嵌入。 图像保存在名为triplet 的列表中 部分代码如下:

def inner_model(act_func='relu', input_shape=(112,112,3):
    model_input = layers.Input(shape=input_shape)
    x = layers.Conv2D(filters=16, kernel_size=3, padding='same', activation=act_func, name='Conv1')(model_input)
    x = layers.MaxPool2D()(x)
    x = layers.Conv2D(filters=32, kernel_size=3, padding='same', activation=act_func, name='Conv2')(x)
    x = layers.MaxPool2D()(x)
    x = layers.Conv2D(filters=64, kernel_size=3, padding='same', activation=act_func, name='Conv3')(x)
    x = layers.MaxPool2D()(x)
    x = layers.Conv2D(filters=128, kernel_size=3, padding='same', activation=act_func, name='Conv4')(x)
    x = layers.MaxPool2D()(x)
    x = layers.Conv2D(filters=256, kernel_size=3, padding='same', activation=act_func, name='Conv5')(x)
    x = layers.GlobalAvgPool2D(name='GAP')(x)
    output = layers.Dense(128, activation=act_func, name='Dense1')(x)
    model = Model(inputs=model_input, outputs=output)
    model.summary()
    return model

def tripler_trainer(input_shape=(112,112,3)):
    anchor_input = layers.Input(shape=input_shape)
    positive_input = layers.Input(shape=input_shape)
    negative_input = layers.Input(shape=input_shape)

    embedder = inner_model(act_func='relu', input_shape=(112,112,3)

    anchor_embedding = embedder(anchor_input)
    positive_embedding = embedder(positive_input)
    negative_embedding = embedder(negative_input)
    outer_network = Model(inputs=(anchor_input, positive_input, negative_input),
                          outputs=(anchor_embedding, positive_embedding, negative_embedding))
    return outer_network

triplet_model = tripler_trainer(input_shape=(112,112,3))
triplets = triplet_model(triplet[0], triplet[1], triplet[2])

当我尝试运行代码时,出现以下错误:

Traceback (most recent call last):
  File "C:/Users/G5205GK/Desktop/Working Dir/code/con_learning/main.py", line 35, in <module>
    main()
  File "C:/Users/G5205GK/Desktop/Working Dir/code/con_learning/main.py", line 31, in main
    training_instance.train()
  File "C:\Users\G5205GK\Desktop\Working Dir\code\con_learning\train.py", line 36, in train
    anchor_embedding = self.model(triplet[0], triplet[1], triplet[2])
  File "C:\Users\G5205GK\Anaconda3\envs\my_gpu_env\lib\site-packages\tensorflow\python\keras\engine\base_layer.py", line 1013, in __call__
    input_spec.assert_input_compatibility(self.input_spec, inputs, self.name)
  File "C:\Users\G5205GK\Anaconda3\envs\my_gpu_env\lib\site-packages\tensorflow\python\keras\engine\input_spec.py", line 200, in assert_input_compatibility
    raise ValueError('Layer ' + layer_name + ' expects ' +
ValueError: Layer model_1 expects 3 input(s), but it received 1 input tensors. Inputs received: [<tf.Tensor: shape=(112, 112, 3), dtype=float32,

谁能指出问题出在哪里。提供的代码也简化了堆栈溢出。所以它可能有语法问题。 提前致谢。

【问题讨论】:

    标签: python tensorflow keras deep-learning


    【解决方案1】:

    您应该使用方括号为模型提供多个输入和输出,因为您的模型需要输入列表而不是输入元组。试试这个:

    import tensorflow as tf
    
    def inner_model(act_func='relu', input_shape=(112,112,3)):
        model_input = tf.keras.layers.Input(shape=input_shape)
        x = tf.keras.layers.Conv2D(filters=16, kernel_size=3, padding='same', activation=act_func, name='Conv1')(model_input)
        x = tf.keras.layers.MaxPool2D()(x)
        x = tf.keras.layers.Conv2D(filters=32, kernel_size=3, padding='same', activation=act_func, name='Conv2')(x)
        x = tf.keras.layers.MaxPool2D()(x)
        x = tf.keras.layers.Conv2D(filters=64, kernel_size=3, padding='same', activation=act_func, name='Conv3')(x)
        x = tf.keras.layers.MaxPool2D()(x)
        x = tf.keras.layers.Conv2D(filters=128, kernel_size=3, padding='same', activation=act_func, name='Conv4')(x)
        x = tf.keras.layers.MaxPool2D()(x)
        x = tf.keras.layers.Conv2D(filters=256, kernel_size=3, padding='same', activation=act_func, name='Conv5')(x)
        x = tf.keras.layers.GlobalAvgPool2D(name='GAP')(x)
        output = tf.keras.layers.Dense(128, activation=act_func, name='Dense1')(x)
        model = tf.keras.Model(inputs=model_input, outputs=output)
        model.summary()
        return model
    
    def tripler_trainer(input_shape=(112,112,3)):
        anchor_input = tf.keras.layers.Input(shape=input_shape)
        positive_input = tf.keras.layers.Input(shape=input_shape)
        negative_input = tf.keras.layers.Input(shape=input_shape)
    
        embedder = inner_model(act_func='relu', input_shape=(112,112,3))
    
        anchor_embedding = embedder(anchor_input)
        positive_embedding = embedder(positive_input)
        negative_embedding = embedder(negative_input)
        outer_network = tf.keras.Model(inputs=[anchor_input, positive_input, negative_input],
                              outputs=[anchor_embedding, positive_embedding, negative_embedding])
        return outer_network
    
    triplet_model = tripler_trainer(input_shape=(112,112,3))
    triplet1, triplet2, triplet3 = tf.random.normal((1,112,112,3)), tf.random.normal((1,112,112,3)), tf.random.normal((1,112,112,3)) 
    triplets = triplet_model([triplet1, triplet2, triplet3])
    print(triplets[0].shape, triplets[1].shape, triplets[2].shape)
    # (1, 128) (1, 128) (1, 128)
    

    【讨论】:

    • 非常感谢@AloneTogether 帮助我。该解决方案对我有用。我真的很难发现这一点。此外,在我的代码中,图像在输入到网络之前需要重新整形。
    猜你喜欢
    • 2021-12-26
    • 2021-08-20
    • 1970-01-01
    • 2019-08-19
    • 2021-06-14
    • 2021-08-05
    • 1970-01-01
    • 2021-04-18
    • 1970-01-01
    相关资源
    最近更新 更多