如何使用Tensorflow 1.14为角膜层定义自定义渐变

时间:2019-09-11 03:40:00

标签: tensorflow keras

我正在尝试在tf.keras(tf ver 1.14)中实现渐变反转层。我使用tf.custom_gradient定义了一个自定义渐变,但是从未调用grad函数,结果是错误的。

我正在使用以下内容测试图层

from tensorflow.keras.models import Model
from tensorflow.keras.layers import Input, Dense
from tensorflow.keras import backend as k
import tensorflow as tf
tf.enable_eager_execution()
import numpy as np

@tf.custom_gradient
def custom_op(x):
    result = x
    def custom_grad(dy):
        grad = tf.negative(dy)
        return grad
    return result, custom_grad

class GradientReversal(tf.keras.layers.Layer):
  def __init__(self):
    super(GradientReversal, self).__init__()

  def call(self, inputs):
    return custom_op(inputs)


a = Input(shape=(2,))
b = GradientReversal()(a)
c = Dense(1)(b)
model = Model(inputs=a, outputs=c)
model.compile(loss='binary_crossentropy', optimizer='sgd')

@tf.function
def test():  
  with tf.GradientTape() as tape:
    out = model(np.ones((1, 2)))
  gradients = tape.gradient(out, model.trainable_variables)
  return gradients

print(test())

1 个答案:

答案 0 :(得分:0)

没关系,我应该在密集之后使用GradientReversal层来获得所需的结果。