Keras 模型支持多个输出。因此,如果不应该训练鉴别器,只需将鉴别器包含到您的 keras 模型中并冻结鉴别器层。
下一个问题是如何结合自动编码器损失和鉴别器损失。幸运的是 keras model.compile支持损失权重。如果自动编码器是您的第一个输出,而鉴别器是您的第二个输出,您可以执行类似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)
如您所见,使用 keras 构建对抗模型并没有什么神奇之处。