我正在尝试计算的梯度
out = x.sign()*torch.pow(x.abs(), alpha)
关于阿尔法。
到目前为止,我尝试了以下方法:
class Power(nn.Module):
def __init__(self, alpha=2.):
super(Power, self).__init__()
self.alpha = nn.Parameter(torch.tensor(alpha))
def forward(self, x):
return x.sign()*torch.abs(x)**self.alpha
但是这门课一直nan
在训练我的网络。我希望看到类似的东西,grad=out*torch.log(x)
但无法做到。例如,此代码不返回任何内容:
alpha_rooting = Power()
x = torch.randn((1), device='cpu', dtype=torch.float)
out = (alpha_rooting(x)).sum()
out.backward()
print(out.grad)
我autograd
也没有运气尝试使用它。我应该如何解决这个问题?谢谢。