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。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。