mindspore.Tensor.topk

查看源文件
mindspore.Tensor.topk(k, dim=- 1, largest=True, sorted=True)

沿给定维度查找 k 个最大或最小元素和对应的索引。

警告

  • 如果 sorted 设置为False,由于不同平台上的内存布局和遍历方法不同:当 sorted 为False时,计算结果的显示顺序可能不一致。

如果 self 是一维Tensor,则查找Tensor中 k 个最大或最小元素,并且将其值和索引输出为Tensor。 values[k]selfk 个最大元素,同时其索引值为 indices[k]

对于多维矩阵,计算给定维度中最大或最小的 k 个元素,因此:

\[values.shape = indices.shape\]

如果两个比较的元素相同,则优先返回索引值较小的元素。

参数:
  • k (int) - 指定计算最大或最小元素的数量,必须为常量。

  • dim (int, 可选) - 需要排序的维度。 默认值: -1

  • largest (bool, 可选) - 如果设置为 False ,则会返回 k 个最小元素。默认值: True

  • sorted (bool, 可选) - 如果设置为 True ,则获取的元素将按值降序排序,如果设置为 False,则不对获取的元素进行排序,默认值:True

返回:

valuesindices 组成的tuple。 - values (Tensor) - 给定维度的每个切片中的 k 最大元素或最小元素。 - indices (Tensor) - k 最大元素的对应索引。

异常:
  • TypeError - 如果 sorted 不是bool。

  • TypeError - 如果 k 不是int。

支持平台:

Ascend

样例:

>>> import mindspore as ms
>>> from mindspore import Tensor
>>> x = ms.Tensor([[0.5368, 0.2447, 0.4302, 0.9673],
...                [0.4388, 0.6525, 0.4685, 0.1868],
...                [0.3563, 0.5152, 0.9675, 0.8230]], dtype=ms.float32)
>>> output = Tensor.topk(x, 2, dim=1)
>>> print(output)
(Tensor(shape=[3, 2], dtype=Float32, value=
[[ 9.67299998e-01,  5.36800027e-01],
 [ 6.52499974e-01,  4.68499988e-01],
 [ 9.67499971e-01,  8.23000014e-01]]), Tensor(shape=[3, 2], dtype=Int32, value=
[[3, 0],
 [1, 2],
 [2, 3]]))
>>> output2 = Tensor.topk(x, 2, dim=1, largest=False)
>>> print(output2)
(Tensor(shape=[3, 2], dtype=Float32, value=
[[ 2.44700000e-01,  4.30200011e-01],
 [ 1.86800003e-01,  4.38800007e-01],
 [ 3.56299996e-01,  5.15200019e-01]]), Tensor(shape=[3, 2], dtype=Int32, value=
[[1, 2],
 [3, 0],
 [0, 1]]))
mindspore.Tensor.topk(k, dim=None, largest=True, sorted=True)

详情请参考 mindspore.ops.topk()