评价此页

torch.where#

torch.where(condition, input, other, *, out=None) Tensor#

返回一个张量,其元素根据 conditioninputother 中选择。

操作定义如下:

outi={inputiif conditioniotheriotherwise\text{out}_i = \begin{cases} \text{input}_i & \text{if } \text{condition}_i \\ \text{other}_i & \text{otherwise} \\ \end{cases}

注意

张量 conditioninputother 必须是 可广播的

参数
  • **condition** (*BoolTensor*) – 当为 True (非零)时,返回 input,否则返回 other

  • **input** (TensorScalar) – 当 input 为标量时为值,或在 conditionTrue 的索引处选择的值

  • **other** (TensorScalar) – 当 other 为标量时为值,或在 conditionFalse 的索引处选择的值

关键字参数

out (Tensor, optional) – 输出张量。

返回

一个张量,其形状等于 conditioninputother 的广播形状

返回类型

张量

示例

>>> x = torch.randn(3, 2)
>>> y = torch.ones(3, 2)
>>> x
tensor([[-0.4620,  0.3139],
        [ 0.3898, -0.7197],
        [ 0.0478, -0.1657]])
>>> torch.where(x > 0, 1.0, 0.0)
tensor([[0., 1.],
        [1., 0.],
        [1., 0.]])
>>> torch.where(x > 0, x, y)
tensor([[ 1.0000,  0.3139],
        [ 0.3898,  1.0000],
        [ 0.0478,  1.0000]])
>>> x = torch.randn(2, 2, dtype=torch.double)
>>> x
tensor([[ 1.0779,  0.0383],
        [-0.8785, -1.1089]], dtype=torch.float64)
>>> torch.where(x > 0, x, 0.)
tensor([[1.0779, 0.0383],
        [0.0000, 0.0000]], dtype=torch.float64)
torch.where(condition) tuple of LongTensor

torch.where(condition) 等同于 torch.nonzero(condition, as_tuple=True)

注意

另请参阅 torch.nonzero()