Tensorflow: неподдерживаемые типы операндов для -: ‘Sequential’ и ‘Последовательный’

#python #tensorflow #keras

#python #tensorflow #keras

Вопрос:

Я следую руководству по сиамской сети, чтобы построить модель распознавания лиц с помощью tensorflow

 def build_net(img_shape):
    """
    :type img_shape: tuple. Shape of input image. Here is(1,height, width). 1 because pgm file only has one channel.
    :rtype:tensorflow Sequential
    """
    model = tf.keras.Sequential()
    # convolution layer 1
    model.add(tf.keras.layers.Conv2D(filters = 16, kernel_size = 3, strides = 1, activation = "relu", input_shape = img_shape, data_format = "channels_first"))
    model.add(tf.keras.layers.MaxPool2D(pool_size = 2))
    model.add(tf.keras.layers.Dropout(0.1))
    # convolution layer 2
    model.add(tf.keras.layers.Conv2D(filters = 32, kernel_size = 3, strides = 1))
    model.add(tf.keras.layers.MaxPool2D(pool_size = 2))
    model.add(tf.keras.layers.Dropout(0.1))

    model.add(tf.keras.layers.Flatten())
    model.add(tf.keras.layers.Dense(1024))
    model.add(tf.keras.layers.Dropout(0.25))
    model.add(tf.keras.layers.Dense(512, activation='relu'))
    # deep face mentioned that there are 67 points to detect on a human face, so use 70 features.
    model.add(tf.keras.layers.Dense(70, activation='relu'))
    print(model.summary())
    return model
  

И определите dist для подсчета расстояния между двумя выходными векторами.

 im1_features = build_net(input_dim)
im2_features = build_net(input_dim)
dist = tf.keras.layers.Lambda(lambda tensors: tf.keras.backend.abs[tensors[0] - tensors[1]])([im1_features, im2_features])
  

Произошла ошибка в dist

   File "e:SchoolAIASprojbuild_model.py", line 102, in <lambda>
    dist = tf.keras.layers.Lambda(lambda tensors: tf.keras.backend.abs[tensors[0] - tensors[1]])([im1_features, im2_features])
TypeError: unsupported operand type(s) for -: 'Sequential' and 'Sequential'
  

Как я могу заставить функцию build_net возвращать векторы, а не последовательный объект?

Обновить

Я изменил код на:

 def build_net(img_shape):
    """
    :type img_shape: tuple. Shape of input image. Here is(1,height, width). 1 because pgm file only has one channel.
    :rtype:tensorflow Sequential
    """
    model = tf.keras.Sequential()
    # convolution layer 1
    model.add(tf.keras.layers.Conv2D(filters = 16, kernel_size = 3, strides = 1, activation = "relu", input_shape = img_shape, data_format = "channels_first"))
    model.add(tf.keras.layers.MaxPool2D(pool_size = 2))
    model.add(tf.keras.layers.Dropout(0.1))
    # convolution layer 2
    model.add(tf.keras.layers.Conv2D(filters = 32, kernel_size = 3, strides = 1))
    model.add(tf.keras.layers.MaxPool2D(pool_size = 2))
    model.add(tf.keras.layers.Dropout(0.1))

    model.add(tf.keras.layers.Flatten())
    model.add(tf.keras.layers.Dense(1024))
    model.add(tf.keras.layers.Dropout(0.25))
    model.add(tf.keras.layers.Dense(512, activation='relu'))
    # deep face mentioned that there are 67 points to detect on a human face, so use 70 features.
    model.add(tf.keras.layers.Dense(70, activation='relu'))
    img = tf.keras.Input(shape = img_shape)
    res = model(img)
    return res
  

теперь он возвращает этот материал
введите описание изображения здесь

Ошибка становится: function' object is not subscriptable

Я все еще не могу найти вектор

Комментарии:

1. Вы можете получить .output свойство созданных моделей, чтобы получить тензор на выходе.

2. @jdehesa Я отредактировал этот вопрос. Теперь возвращаемый тип точно такой же, как у .output, но он получил новую ошибку: функция’ объект не поддается подписке

Ответ №1:

Попробуйте вызвать tf.keras.abs следующим образом:

 tf.keras.backend.abs(
    x
)
  

Нет

 tf.keras.backend.abs[
    x
]
  

Это функция, а не массив.
Это решило вашу проблему?