mindspore.ops.BatchToSpace =========================== .. py:class:: mindspore.ops.BatchToSpace(block_size, crops) 将批处理数据重新排列到空间数据中。 此操作将批处理维度N拆分为 `block_size` 大小的块(blocks),输出Tensor的维度N,即为拆分后对应的块数。输出Tensor的H、W维分别是原H、W维和 `block_size` 在给定裁剪量情况下的乘积。 参数: - **block_size** (int) - 指定拆分的块大小,其值不能小于2。 - **crops** (Union[list(int), tuple(int)]) - 指定H和W维度上的裁剪值,包含2个列表。每个列表包含2个整数。所有值都必须不小于0。crops[i]表示指定空间维度i的裁剪值,该维度对应于输入维度i+2。要求 :math:`input\_shape[i+2]*block\_size > crops[i][0]+crops[i][1]` 。 输入: - **input_x** (Tensor) - 输入Tensor。必须是四维,第零维度(维度n)的大小必须可被 `block_size` 的乘积整除。数据类型为float16或float32。 输出: Tensor,数据类型与输入Tensor相同。假设输入shape为 :math:`(n, c, h, w)` ,经过 `block_size` 和 `crops` 计算后。输出shape将为 :math:`(n', c', h', w')` ,其中 - :math:`n' = n//(block\_size*block\_size)` - :math:`c' = c` - :math:`h' = h*block\_size-crops[0][0]-crops[0][1]` - :math:`w' = w*block\_size-crops[1][0]-crops[1][1]` 异常: - **TypeError** - 如果 `block_size` 或 `crops` 的元素不是int。 - **TypeError** - 如果 `crops` 既不是list也不是tuple。 - **ValueError** - 如果 `block_size` 的值小于2。