fluxo tensor:: ops:: TensorArrayGrad
#include <data_flow_ops.h>
Cria um TensorArray para armazenar os gradientes de valores no identificador fornecido.
Resumo
Se o gradiente TensorArray fornecido já existir, retorna uma referência a ele.
Bloqueia o tamanho do TensorArray original desativando seu sinalizador de tamanho dinâmico.
Uma observação sobre a entrada flow_in:
O identificador flow_in força a execução da pesquisa de gradiente a ocorrer somente após a ocorrência de algumas outras operações. Por exemplo, quando o TensorArray de encaminhamento é dimensionado dinamicamente, as gravações neste TensorArray podem redimensionar o objeto. O gradiente TensorArray é dimensionado estaticamente com base no tamanho do TensorArray direto quando esta operação é executada. Além disso, o tamanho do TensorArray de encaminhamento é congelado por esta chamada. Como resultado, o fluxo é usado para garantir que a chamada para gerar o gradiente TensorArray só aconteça após todas as gravações serem executadas.
No caso de TensorArrays dimensionados dinamicamente, o cálculo do gradiente só deve ser executado em operações de leitura que foram encadeadas por meio de fluxo para ocorrer somente após a execução de todas as gravações. Dessa forma, o tamanho final do TensorArray direto é conhecido quando esta operação é chamada.
Uma observação sobre o atributo source:
As chamadas de gradiente TensorArray usam um objeto TensorArray acumulador. Se vários gradientes forem calculados e executados na mesma sessão, os vários nós de gradiente poderão fluir acidentalmente pelo mesmo acumulador TensorArray . Isso conta duas vezes e geralmente interrompe o fluxo de gradiente do TensorArray .
A solução é identificar em qual chamada de gradiente esse gradiente TensorArray específico está sendo chamado. Isso é realizado identificando uma string exclusiva (por exemplo, "gradientes", "gradientes_1", ...) do nome do Tensor do gradiente de entrada. Esta string é usada como sufixo ao criar o objeto gradiente TensorArray aqui (o atributo source
).
O atributo source
é adicionado como um sufixo ao nome do TensorArray de encaminhamento ao realizar a criação/pesquisa, para que cada cálculo de gradiente separado obtenha seu próprio acumulador TensorArray .
Argumentos:
- escopo: um objeto Escopo
- handle: O identificador para o TensorArray de encaminhamento.
- flow_in: um escalar flutuante que impõe o encadeamento adequado de operações.
- source: A string de origem do gradiente, usada para decidir qual gradiente TensorArray retornar.
Retorna:
Construtores e Destruidores | |
---|---|
TensorArrayGrad (const :: tensorflow::Scope & scope, :: tensorflow::Input handle, :: tensorflow::Input flow_in, StringPiece source) |
Atributos públicos | |
---|---|
flow_out | |
grad_handle | |
operation |
Atributos públicos
fluxo_out
::tensorflow::Output flow_out
grad_handle
::tensorflow::Output grad_handle
operação
Operation operation
Funções públicas
TensorArrayGrad
TensorArrayGrad( const ::tensorflow::Scope & scope, ::tensorflow::Input handle, ::tensorflow::Input flow_in, StringPiece source )