快捷方式

isin

class tensordict.utils.isin(input: TensorDictBase, reference: TensorDictBase, key: NestedKey, dim: int = 0)

测试 input 中 keydim 维度上的每个元素是否存在于 reference 中。

此函数返回一个布尔张量,其长度为 input.batch_size[dim],对于 key 入口中也存在于 reference 中的元素,其值为 True。此函数假定 inputreference 具有相同的批处理大小并包含指定的入口,否则将引发错误。

参数:
  • input (TensorDictBase) – 输入 TensorDict。

  • reference (TensorDictBase) – 用于测试的目标 TensorDict。

  • key (Nestedkey) – 要测试的键。

  • dim (int, 可选) – 要测试的维度。默认为 0

返回值:

一个布尔张量,其长度为 input.batch_size[dim],对于位于

input key 张量中且也存在于 reference 中的元素,其值为 True

返回类型:

out (Tensor)

示例

>>> td = TensorDict(
...     {
...         "tensor1": torch.tensor([[1, 2, 3], [4, 5, 6], [1, 2, 3], [7, 8, 9]]),
...         "tensor2": torch.tensor([[10, 20], [30, 40], [40, 50], [50, 60]]),
...     },
...     batch_size=[4],
... )
>>> td_ref = TensorDict(
...     {
...         "tensor1": torch.tensor([[1, 2, 3], [4, 5, 6], [10, 11, 12]]),
...         "tensor2": torch.tensor([[10, 20], [30, 40], [50, 60]]),
...     },
...     batch_size=[3],
... )
>>> in_reference = isin(td, td_ref, key="tensor1")
>>> expected_in_reference = torch.tensor([True, True, True, False])
>>> torch.testing.assert_close(in_reference, expected_in_reference)

© 版权所有 2022, Meta。

使用 Sphinx 构建,主题由 Read the Docs 提供。

文档

访问 PyTorch 的全面开发者文档

查看文档

教程

获取面向初学者和高级开发者的深入教程

查看教程

资源

查找开发资源并解答你的问题

查看资源