flujo tensor:: operaciones:: ProfundidadConv2dNativo

#include <nn_ops.h>

Calcula una convolución profunda 2D dada input 4D y los tensores filter .

Resumen

Dado un tensor de entrada de forma [batch, in_height, in_width, in_channels] y un tensor de filtro/núcleo de forma [filter_height, filter_width, in_channels, channel_multiplier] , que contiene filtros convolucionales in_channels de profundidad 1, depthwise_conv2d aplica un filtro diferente a cada canal de entrada. (expandiéndose de 1 canal a canales channel_multiplier canales para cada uno), luego concatena los resultados. Por lo tanto, la salida tiene canales in_channels * channel_multiplier .

for k in 0..in_channels-1
  for q in 0..channel_multiplier-1
    output[b, i, j, k * channel_multiplier + q] =
      sum_{di, dj} input[b, strides[1] * i + di, strides[2] * j + dj, k] *
                        filter[di, dj, k, q]

Debe tener strides[0] = strides[3] = 1 . Para el caso más común de las mismas zancadas horizontales y de vértices, strides = [1, stride, stride, 1] .

Argumentos:

  • alcance: un objeto de alcance
  • zancadas: 1-D de longitud 4. La zancada de la ventana deslizante para cada dimensión de input .
  • padding: el tipo de algoritmo de relleno que se utilizará.

Atributos opcionales (ver Attrs ):

  • data_format: especifique el formato de datos de los datos de entrada y salida. Con el formato predeterminado "NHWC", los datos se almacenan en el orden de: [lote, alto, ancho, canales]. Alternativamente, el formato podría ser "NCHW", el orden de almacenamiento de datos de: [lote, canales, alto, ancho].
  • dilataciones: tensor 1-D de longitud 4. El factor de dilatación para cada dimensión de input . Si se establece en k > 1, se omitirán k-1 celdas entre cada elemento de filtro en esa dimensión. El orden de las dimensiones está determinado por el valor de data_format ; consulte más arriba para obtener más detalles. Las dilataciones en las dimensiones de lote y profundidad deben ser 1.

Devoluciones:

  • Output : El tensor de salida.

Constructores y destructores

DepthwiseConv2dNative (const :: tensorflow::Scope & scope, :: tensorflow::Input input, :: tensorflow::Input filter, const gtl::ArraySlice< int > & strides, StringPiece padding)
DepthwiseConv2dNative (const :: tensorflow::Scope & scope, :: tensorflow::Input input, :: tensorflow::Input filter, const gtl::ArraySlice< int > & strides, StringPiece padding, const DepthwiseConv2dNative::Attrs & attrs)

Atributos públicos

operation
output

Funciones públicas

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

Funciones estáticas públicas

DataFormat (StringPiece x)
Dilations (const gtl::ArraySlice< int > & x)
ExplicitPaddings (const gtl::ArraySlice< int > & x)

estructuras

tensorflow:: operaciones:: DepthwiseConv2dNative:: Atributos

Configuradores de atributos opcionales para DepthwiseConv2dNative .

Atributos públicos

operación

Operation operation

producción

::tensorflow::Output output

Funciones públicas

ProfundidadConv2dNativo

 DepthwiseConv2dNative(
  const ::tensorflow::Scope & scope,
  ::tensorflow::Input input,
  ::tensorflow::Input filter,
  const gtl::ArraySlice< int > & strides,
  StringPiece padding
)

ProfundidadConv2dNativo

 DepthwiseConv2dNative(
  const ::tensorflow::Scope & scope,
  ::tensorflow::Input input,
  ::tensorflow::Input filter,
  const gtl::ArraySlice< int > & strides,
  StringPiece padding,
  const DepthwiseConv2dNative::Attrs & attrs
)

nodo

::tensorflow::Node * node() const 

operador::tensorflow::Entrada

 operator::tensorflow::Input() const 

operador::tensorflow::Salida

 operator::tensorflow::Output() const 

Funciones estáticas públicas

Formato de datos

Attrs DataFormat(
  StringPiece x
)

dilataciones

Attrs Dilations(
  const gtl::ArraySlice< int > & x
)

Rellenos explícitos

Attrs ExplicitPaddings(
  const gtl::ArraySlice< int > & x
)