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 filtro/tensor de kernel 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 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 a utilizar.
Atributos opcionales (ver Attrs ):
- data_format: especifique el formato de 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 dedata_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) | |
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 )