Итак, я работаю над написанием нейронной сети GAN, и я хочу установить выход моей сети на 0, если он меньше 0 и 1, если он больше 1, и оставить его без изменений в противном случае. Я новичок в тензорном потоке, но я не знаю ни одной функции тензорного потока или активации, чтобы сделать это без нежелательных побочных эффектов. Итак, я сделал свою функцию потерь, чтобы она вычисляла потери, как если бы вывод был заблокирован, с помощью этого кода:
def discriminator_loss(real_output, fake_output):
real_output_clipped = min(max(real_output.numpy()[0],
0), 1)
fake_output_clipped = min(max(fake_output.numpy()[0],
0), 1)
real_clipped_tensor =
tf.Variable([[real_output_clipped]], dtype = "float32")
fake_clipped_tensor =
tf.Variable([[fake_output_clipped]], dtype = "float32")
real_loss = cross_entropy(tf.ones_like(real_output),
real_clipped_tensor)
fake_loss = cross_entropy(tf.zeros_like(fake_output),
fake_clipped_tensor)
total_loss = real_loss + fake_loss
return total_loss
, но я получаю эту ошибку:
ValueError: No gradients provided for any variable: ['dense_50/kernel:0', 'dense_50/bias:0', 'dense_51/kernel:0', 'dense_51/bias:0', 'dense_52/kernel:0', 'dense_52/bias:0', 'dense_53/kernel:0', 'dense_53/bias:0'].
Кто-нибудь знает лучший способ сделать это или способ исправить эту ошибку?
Спасибо!