mindspore.nn.OneHot ==================== .. py:class:: mindspore.nn.OneHot(axis=-1, depth=1, on_value=1.0, off_value=0.0, dtype=mstype.float32) 对输入进行one-hot编码并返回。 输入的 `indices` 表示的位置取值为on_value,其他所有位置取值为off_value。 .. note:: 如果indices是n阶Tensor,那么返回的one-hot Tensor则为n+1阶Tensor。 如果 `indices` 是Scalar,则输出shape将是长度为 `depth` 的向量。 如果 `indices` 是长度为 `features` 的向量,则输出shape为: .. code-block:: features * depth if axis == -1 depth * features if axis == 0 如果 `indices` 是shape为 `[batch, features]` 的矩阵,则输出shape为: .. code-block:: batch * features * depth if axis == -1 batch * depth * features if axis == 1 depth * batch * features if axis == 0 **参数:** - **axis** (int) - 指定第几阶为 `depth` 维one-hot向量,如果轴为-1,则 `features * depth` ,如果轴为0,则 `depth * features` 。默认值:-1。 - **depth** (int) - 定义one-hot向量的深度。默认值:1。 - **on_value** (float) - one-hot值,当 `indices[j] = i` 时,填充output[i][j]的取值。默认值:1.0。 - **off_value** (float) - 非one-hot值,当 `indices[j] != i` 时,填充output[i][j]的取值。默认值:0.0。 - **dtype** (:class:`mindspore.dtype`) - 是'on_value'和'off_value'的数据类型,而不是输入的数据类型。默认值:mindspore.float32。 **输入:** - **indices** (Tensor) - 输入索引,任意维度的Tensor,数据类型为int32或int64。 **输出:** Tensor,输出Tensor,数据类型 `dtype` 的one-hot Tensor,维度为 `axis` 扩展到 `depth`,并填充on_value和off_value。`Outputs` 的维度等于 `indices` 的维度加1。 **异常:** - **TypeError** - `axis` 或 `depth` 不是int。 - **TypeError** - `indices` 的dtype既不是int32,也不是int64。 - **ValueError** - 如果 `axis` 不在范围[-1, len(indices_shape)]内。 - **ValueError** - `depth` 小于0。