N-D T 类型张量的 BatchToSpace。
用法
tf.batch_to_space(
input, block_shape, crops, name=None
)
参数
-
input
具有形状input_shape = [batch] + spatial_shape + remaining_shape
的 N-DTensor
,其中spatial_shape
具有 M 维。 -
block_shape
形状为 [M] 的一维Tensor
。必须是以下类型之一:int32
,int64
。所有值都必须 >= 1。为了与 TF 1.0 向后兼容,此参数可能是 int,在这种情况下,它会转换为numpy.array([block_shape, block_shape], dtype=numpy.int64)
。 -
crops
二维Tensor
有形状[M, 2]
.必须是以下类型之一:int32
,int64
.所有值必须 >= 0。crops[i] = [crop_start, crop_end]
指定从输入维度裁剪的数量i + 1
, 对应于空间维度i
.要求crop_start[i] + crop_end[i] <= block_shape[i] * input_shape[i + 1]
.此操作等效于以下步骤:- 将
input
重塑为reshaped
of shape:[block_shape[0], ..., block_shape[M-1], batch /prod(block_shape), input_shape[1], ..., input_shape[N-1] ] - 置换
reshaped
的尺寸以产生形状为 [batch /prod(block_shape), input_shape[1], block_shape[0], ..., input_shape[M], block_shape[M-1], input_shape[M] 的permuted
+1], ..., input_shape[N-1]] - 重塑
permuted
以生成形状为reshaped_permuted
[batch /prod(block_shape), input_shape[1] * block_shape[0], ..., input_shape[M] * block_shape[M-1], input_shape[M+1 ], ..., input_shape[N-1]] - 根据
crops
裁剪reshaped_permuted
的维度[1, ..., M]
的开始和结束以产生shape的输出:[batch /prod(block_shape), input_shape[1] * block_shape[0] - crop[0,0] - crop[0,1], ..., input_shape[M] * block_shape[M-1] - crop[M-1,0] - crop[M-1,1], input_shape[M+1], . ..,输入形状[N-1]]
- 将
-
name
操作的名称(可选)。
返回
-
一个
Tensor
。具有与input
相同的类型。
此操作将 "batch" 维度 0 重塑为形状 block_shape + [batch]
的 M + 1
维度,将这些块交错回到由空间维度 [1, ..., M]
定义的网格中,以获得与输入具有相同等级的结果。然后根据crops
选择性地裁剪此中间结果的空间维度以生成输出。这是 SpaceToBatch 的反面(参见 tf.space_to_batch
)。
例子:
对于以下形状
[4, 1, 1, 1]
,block_shape = [2, 2]
和crops = [[0, 0], [0, 0]]
的输入:[[[[1]]], [[[2]]], [[[3]]], [[[4]]]]
输出张量的形状为
[1, 2, 2, 1]
和值:x = [[[[1], [2]], [[3], [4]]]]
对于以下形状
[4, 1, 1, 3]
,block_shape = [2, 2]
和crops = [[0, 0], [0, 0]]
的输入:[[[1, 2, 3]], [[4, 5, 6]], [[7, 8, 9]], [[10, 11, 12]]]
输出张量的形状为
[1, 2, 2, 3]
和值:x = [[[[1, 2, 3], [4, 5, 6 ]], [[7, 8, 9], [10, 11, 12]]]]
对于以下形状
[4, 2, 2, 1]
,block_shape = [2, 2]
和crops = [[0, 0], [0, 0]]
的输入:x = [[[[1], [3]], [[ 9], [11]]], [[[2], [4]], [[10], [12]]], [[[5], [7]], [[13], [15]]], [[[6], [8]], [[14], [16]]]]
输出张量的形状为
[1, 4, 4, 1]
和值:x = [[[1], [2], [ 3], [ 4]], [[5], [6], [ 7], [ 8]], [[9], [10], [11], [12]], [[13], [14], [15], [16]]]
对于以下形状
[8, 1, 3, 1]
,block_shape = [2, 2]
和crops = [[0, 0], [2, 0]]
的输入: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]]]]
输出张量的形状为
[2, 2, 4, 1]
和值:x = [[[[ 1], [ 2], [ 3], [ 4]], [[ 5], [ 6], [ 7], [ 8]]], [[[ 9], [10], [11], [12]], [[13], [14], [15], [16]]]]
相关用法
- Python tf.bitcast用法及代码示例
- Python tf.boolean_mask用法及代码示例
- Python tf.broadcast_to用法及代码示例
- Python tf.bitwise.bitwise_or用法及代码示例
- Python tf.broadcast_static_shape用法及代码示例
- Python tf.broadcast_dynamic_shape用法及代码示例
- Python tf.bitwise.bitwise_and用法及代码示例
- Python tf.bitwise.bitwise_xor用法及代码示例
- Python tf.bitwise.invert用法及代码示例
- Python tf.bitwise.right_shift用法及代码示例
- Python tf.bitwise.left_shift用法及代码示例
- Python tf.compat.v1.distributions.Multinomial.stddev用法及代码示例
- Python tf.compat.v1.distribute.MirroredStrategy.experimental_distribute_dataset用法及代码示例
- Python tf.compat.v1.data.TFRecordDataset.interleave用法及代码示例
- Python tf.summary.scalar用法及代码示例
- Python tf.linalg.LinearOperatorFullMatrix.matvec用法及代码示例
- Python tf.linalg.LinearOperatorToeplitz.solve用法及代码示例
- Python tf.raw_ops.TPUReplicatedInput用法及代码示例
- Python tf.raw_ops.Bitcast用法及代码示例
- Python tf.compat.v1.distributions.Bernoulli.cross_entropy用法及代码示例
注:本文由纯净天空筛选整理自tensorflow.org大神的英文原创作品 tf.batch_to_space。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。