Модель Keras поддерживает несколько выходов. Так что просто включите ваш дискриминатор в вашу модель keras и заморозьте слои дискриминатора, если дискриминатор не нужно обучать.
Следующий вопрос заключается в том, как объединить потерю автоэнкодера и потерю дискриминатора. К счастью, keras model.compile поддерживает веса потерь. Если autoencoder - ваш первый выход, а дискриминатор - второй, вы можете сделать что-то вроде loss_weights=[1, -1]
. Так что лучший дискриминатор хуже для автоэнкодера.
Изменить: Вот пример, как реализовать сеть противника:
# Build your architecture
auto_encoder_input = Input((5,))
auto_encoder_net = Dense(10)(auto_encoder_input)
auto_encoder_output = Dense(5)(auto_encoder_net)
discriminator_net = Dense(20)(auto_encoder_output)
discriminator_output = Dense(5)(discriminator_net)
# Define outputs of your model
train_autoencoder_model = Model(auto_encoder_input, [auto_encoder_output, discriminator_output])
train_discriminator_model = Model(auto_encoder_input, discriminator_output)
# Compile the models (compile the first model and then change the trainable attribute for the second)
for layer_index, layer in enumerate(train_autoencoder_model.layers):
layer.trainable = layer_index < 3
train_autoencoder_model.compile('Adam', loss=['mse', 'mse'], loss_weights=[1, -1])
for layer_index, layer in enumerate(train_discriminator_model.layers):
layer.trainable = layer_index >= 3
train_discriminator_model.compile('Adam', loss='mse')
# A simple example how a training can look like
for i in range(10):
auto_input = np.random.sample((10,5))
discrimi_output = np.random.sample((10,5))
train_discriminator_model.fit(auto_input, discrimi_output, steps_per_epoch=5, epochs=1)
train_autoencoder_model.fit(auto_input, [auto_input, discrimi_output], steps_per_epoch=1, epochs=1)
Как видите, за созданием модели противника с помощью керас не так много магии.