このページは Cloud Translation API によって翻訳されました。
Switch to English

tensorflow :: ops :: GatherNd

#include <array_ops.h>

paramsからスライスを収集し、 indices指定された形状のTensorに入れindices

概要

indicesはK次元の整数テンソルであり、 paramsへのインデックスの(K-1)次元のテンソルと考えるのが最適です。ここで、各要素はparamsスライスを定義します:

output[\\(i_0, ..., i_{K-2}\\)] = params[indices[\\(i_0, ..., i_{K-2}\\)]]

一方でtf.gather indices定義スライスの最初の次元へparamsで、 tf.gather_ndindices定義スライス最初にNの寸法paramsN = indices.shape[-1]

indicesの最後の次元は、最大でparamsのランクにすることができます:

indices.shape[-1] <= params.rank

indicesの最後の次元は、 params次元indices.shape[-1]に沿った要素( indices.shape[-1] == params.rank場合)またはスライス( indices.shape[-1] < params.rank場合)に対応します。出力テンソルの形状は

indices.shape[:-1] + params.shape[indices.shape[-1]:]
です。

CPUでは、範囲外のインデックスが見つかった場合、エラーが返されることに注意してください。 GPUでは、範囲外のインデックスが見つかった場合、対応する出力値に0が格納されます。

以下にいくつかの例を示します。

行列への単純なインデックス付け:

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

行列へのインデックスのスライス:

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

3テンソルへのインデックス付け:

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

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

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

マトリックスへのバッチインデックス:

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

マトリックスへのバッチスライスインデックス:

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

3テンソルへのバッチインデックス:

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

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

    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']]

tf.gatherおよびtf.batch_gatherも参照してください。

引数:

  • scope: Scopeオブジェクト
  • params:値を収集するテンソル。
  • インデックス:インデックステンソル。

戻り値:

  • Output :から値paramsによって与えられるインデックスから収集indices形状と、 indices.shape[:-1] + params.shape[indices.shape[-1]:]

コンストラクタとデストラクタ

GatherNd (const :: tensorflow::Scope & scope, :: tensorflow::Input params, :: tensorflow::Input indices)

公開属性

operation
output

公開機能

node () const
::tensorflow::Node *
operator::tensorflow::Input () const
operator::tensorflow::Output () const

公開属性

操作

Operation operation

出力

::tensorflow::Output output

公開機能

GatherNd

 GatherNd(
  const ::tensorflow::Scope & scope,
  ::tensorflow::Input params,
  ::tensorflow::Input indices
)

ノード

::tensorflow::Node * node() const 

operator :: tensorflow :: Input

 operator::tensorflow::Input() const 

operator :: tensorflow :: Output

 operator::tensorflow::Output() const