『TensorFlow』高级高维切片gather_nd

gather用于高级切片,有关官方文档的介绍,关于维度的说明很是费解,示例也不太直观,这里给出我的解读,示例见下面,

    indices = [[0, 0], [1, 1]]
    params = [['a', 'b'], ['c', 'd']]
    output = ['a', 'd']

    indices = [[[0, 0]], [[0, 1]]]
    params = [['a', 'b'], ['c', 'd']]
    output = [['a'], ['b']]

我们两次被索引对象是相同的:[2, 2]形状,而indice的形状各不相同,按照官网的算法计算输出很不直观,按照我的理解,我们由最后一维度向外看indices即可,即[0, 0]索引到'a'[1, 1]索引到'b',然后我们使用索引到的对象替换掉最后一维度的索引即可,例如,对于[[0, 0], [1, 1]],替换掉[0, 0][1, 1]后,即为['a', 'd'],而[[[0, 0]], [[0, 1]]]替换后保留了外层两个维度:[['a'], ['b']]
我们看官网另一个例子,对应[0, 0, 1]获得'b0'[1, 0, 1]获得'b1'……,简单替换即可。

    indices = [[[0, 0, 1], [1, 0, 1]], [[0, 1, 1], [1, 1, 0]]]
    params = [[['a0', 'b0'], ['c0', 'd0']],
           [['a1', 'b1'], ['c1', 'd1']]]
    output = [['b0', 'b1'], ['d0', 'c1']]

上一篇:OS X升级到10.11后Xcode6.4界面无iOS device选择栏的解决办法


下一篇:Var与Dynamic的区别