这是我的工作,只取每个分量的导数(@Yaroslav 也提到过),然后在 2 阶张量(矩阵)的情况下再次将它们打包在一起:
import tensorflow as tf
def twodtensor2list(tensor,m,n):
s = [[tf.slice(tensor,[j,i],[1,1]) for i in range(n)] for j in range(m)]
fs = []
for l in s:
fs.extend(l)
return fs
def grads_all_comp(y, shapey, x, shapex):
yl = twodtensor2list(y,shapey[0],shapey[1])
grads = [tf.gradients(yle,x)[0] for yle in yl]
gradsp = tf.pack(grads)
gradst = tf.reshape(gradsp,shape=(shapey[0],shapey[1],shapex[0],shapex[1]))
return gradst
现在grads_all_comp(y, shapey, x, shapex) 将以所需格式输出等级 4 的张量。这是一种非常低效的方式,因为所有东西都需要被分割并重新包装在一起,所以如果有人找到更好的方法,我会非常有兴趣看到它。