N-D T 类型张量的 SpaceToBatch。
用法
tf.raw_ops.SpaceToBatchND(
input, block_shape, paddings, name=None
)参数
-
input一个Tensor。 N-D 形状为input_shape = [batch] + spatial_shape + remaining_shape,其中 spatial_shape 具有M尺寸。 -
block_shape一个Tensor。必须是以下类型之一:int32,int64。形状为[M]的一维,所有值必须 >= 1。 -
paddings一个Tensor。必须是以下类型之一:int32,int64。具有形状[M, 2]的二维,所有值必须 >= 0。paddings[i] = [pad_start, pad_end]指定输入维度i + 1的填充,它对应于空间维度i。要求block_shape[i]除以input_shape[i + 1] + pad_start + pad_end。 -
name操作的名称(可选)。
返回
-
一个
Tensor。具有与input相同的类型。
此操作将输入的 "spatial" 维度 [1, ..., M] 划分为形状为 block_shape 的块网格,并将这些块与 "batch" 维度 (0) 交错,以便在输出中,空间维度 [1, ..., M] 对应到网格内的位置,批次维度结合了空间块内的位置和原始批次位置。在划分成块之前,根据paddings,输入的空间维度可选地补零。请参阅下面的详细说明。
此操作等效于以下步骤:
Zero-pad 输入的开始和结束维度
[1, ..., M]根据paddings生成形状padded_shape的padded。将
padded重塑为reshaped_padded的形状:[批次] + [padded_shape[1] /block_shape[0], block_shape[0], ..., padded_shape[M] /block_shape[M-1], block_shape[M-1]] + remaining_shape
置换
reshaped_padded的尺寸以产生形状permuted_reshaped_padded:block_shape + [batch] + [padded_shape[1] /block_shape[0], ..., padded_shape[M] /block_shape[M-1]] + remaining_shape
重塑
permuted_reshaped_padded以将block_shape展平为批处理维度,生成形状的输出张量:[batch * prod(block_shape)] + [padded_shape[1] /block_shape[0], ..., padded_shape[M] /block_shape[M-1]] + remaining_shape
一些例子:
(1) 对于以下形状 [1, 2, 2, 1] , block_shape = [2, 2] 和 paddings = [[0, 0], [0, 0]] 的输入:
x = [[[[1], [2]], [[3], [4]]]]
输出张量的形状为 [4, 1, 1, 1] 和值:
[[[[1]]], [[[2]]], [[[3]]], [[[4]]]]
(2) 对于以下形状 [1, 2, 2, 3] , block_shape = [2, 2] 和 paddings = [[0, 0], [0, 0]] 的输入:
x = [[[[1, 2, 3], [4, 5, 6]],
[[7, 8, 9], [10, 11, 12]]]]
输出张量的形状为 [4, 1, 1, 3] 和值:
[[[[1, 2, 3]]], [[[4, 5, 6]]], [[[7, 8, 9]]], [[[10, 11, 12]]]]
(3) 对于以下形状 [1, 4, 4, 1] , block_shape = [2, 2] 和 paddings = [[0, 0], [0, 0]] 的输入:
x = [[[[1], [2], [3], [4]],
[[5], [6], [7], [8]],
[[9], [10], [11], [12]],
[[13], [14], [15], [16]]]]
输出张量的形状为 [4, 2, 2, 1] 和值:
x = [[[[1], [3]], [[9], [11]]],
[[[2], [4]], [[10], [12]]],
[[[5], [7]], [[13], [15]]],
[[[6], [8]], [[14], [16]]]]
(4) 对于形状 [2, 2, 4, 1] 、 block_shape = [2, 2] 和 paddings = [[0, 0], [2, 0]] 的以下输入:
x = [[[[1], [2], [3], [4]],
[[5], [6], [7], [8]]],
[[[9], [10], [11], [12]],
[[13], [14], [15], [16]]]]
输出张量的形状为 [8, 1, 3, 1] 和值:
x = [[[[0], [1], [3]]], [[[0], [9], [11]]],
[[[0], [2], [4]]], [[[0], [10], [12]]],
[[[0], [5], [7]]], [[[0], [13], [15]]],
[[[0], [6], [8]]], [[[0], [14], [16]]]]
除其他外,此操作对于将多孔卷积减少为常规卷积很有用。
相关用法
- Python tf.raw_ops.SpaceToBatch用法及代码示例
- Python tf.raw_ops.SpaceToDepth用法及代码示例
- Python tf.raw_ops.SparseCrossV2用法及代码示例
- Python tf.raw_ops.SparseCross用法及代码示例
- Python tf.raw_ops.SparseConcat用法及代码示例
- Python tf.raw_ops.SparseSegmentSumWithNumSegments用法及代码示例
- Python tf.raw_ops.SparseMatrixSparseMatMul用法及代码示例
- Python tf.raw_ops.SparseMatrixOrderingAMD用法及代码示例
- Python tf.raw_ops.SparseFillEmptyRows用法及代码示例
- Python tf.raw_ops.SparseSlice用法及代码示例
- Python tf.raw_ops.SparseToDense用法及代码示例
- Python tf.raw_ops.SparseSplit用法及代码示例
- Python tf.raw_ops.SparseMatrixSparseCholesky用法及代码示例
- Python tf.raw_ops.SparseSegmentSum用法及代码示例
- Python tf.raw_ops.SparseMatrixMatMul用法及代码示例
- Python tf.raw_ops.SparseCrossHashed用法及代码示例
- Python tf.raw_ops.SelfAdjointEigV2用法及代码示例
- Python tf.raw_ops.Size用法及代码示例
- Python tf.raw_ops.ScatterUpdate用法及代码示例
- Python tf.raw_ops.ScatterNdUpdate用法及代码示例
注:本文由纯净天空筛选整理自tensorflow.org大神的英文原创作品 tf.raw_ops.SpaceToBatchND。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。
