評價此頁

torch.Tensor.sparse_mask#

Tensor.sparse_mask(mask) Tensor#

返回一個使用稀疏張量 mask 的索引過濾的 strided 張量 self 的值的新稀疏張量mask 稀疏張量的值將被忽略。selfmask 張量必須具有相同的形狀。

注意

如果 mask 不是合併的,則返回的稀疏張量可能包含重複值。因此,如果不需要這種行為,建議傳遞 mask.coalesce()

注意

即使 self 中相應的值為零,返回的稀疏張量也具有與稀疏張量 mask 相同的索引。

引數

mask (Tensor) – 一個用於索引過濾的稀疏張量

示例

>>> nse = 5
>>> dims = (5, 5, 2, 2)
>>> I = torch.cat([torch.randint(0, dims[0], size=(nse,)),
...                torch.randint(0, dims[1], size=(nse,))], 0).reshape(2, nse)
>>> V = torch.randn(nse, dims[2], dims[3])
>>> S = torch.sparse_coo_tensor(I, V, dims).coalesce()
>>> D = torch.randn(dims)
>>> D.sparse_mask(S)
tensor(indices=tensor([[0, 0, 0, 2],
                       [0, 1, 4, 3]]),
       values=tensor([[[ 1.6550,  0.2397],
                       [-0.1611, -0.0779]],

                      [[ 0.2326, -1.0558],
                       [ 1.4711,  1.9678]],

                      [[-0.5138, -0.0411],
                       [ 1.9417,  0.5158]],

                      [[ 0.0793,  0.0036],
                       [-0.2569, -0.1055]]]),
       size=(5, 5, 2, 2), nnz=4, layout=torch.sparse_coo)