import tensorflow as tf
from tensorflow.keras.activations import swish, relu, softmax, sigmoid, tanh, linear, softsign

@tf.RegisterGradient("SoftsignGrad")
def _grad(ops,grad):
    eps = 1e-8
    a,b = ops.inputs # a는 ?, b는 input(of softsign)
    c = ops.outputs[0] # c는 softsigngrad가 계산한값이 아니고, a*SoftsignGrad(b)    -> print찍은 결과 넘 확실하게 맞음
    grad_value = 1/(tf.math.abs(b)+1)**2
    second_deriv = -2.0*tf.math.sign(b)*tf.math.pow(grad_value,1.5) # 이거 자체가 값이 불안정해서 안댐
    return grad_value*grad, a*second_deriv*grad
    
def activation_generator(name,beta=1.0):
    func = eval(name)
    if beta is None:
        return lambda x:func(x)
    else:
        beta = float(beta)
        return lambda x:func(x*beta)