torch.Tensor.sparse_mask#
- Tensor.sparse_mask(mask) Tensor#
返回一個使用稀疏張量
mask的索引過濾的 strided 張量self的值的新稀疏張量。mask稀疏張量的值將被忽略。self和mask張量必須具有相同的形狀。注意
如果
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)