TextureScraping / libs /ssn /sparse_utils.py
sunshineatnoon
Add application file
1b2a9b1
raw
history blame
No virus
583 Bytes
import torch
def naive_sparse_bmm(sparse_mat, dense_mat, transpose=False):
if transpose:
return torch.stack([torch.sparse.mm(s_mat, d_mat.t()) for s_mat, d_mat in zip(sparse_mat, dense_mat)], 0)
else:
return torch.stack([torch.sparse.mm(s_mat, d_mat) for s_mat, d_mat in zip(sparse_mat, dense_mat)], 0)
def sparse_permute(sparse_mat, order):
values = sparse_mat.coalesce().values()
indices = sparse_mat.coalesce().indices()
indices = torch.stack([indices[o] for o in order], 0).contiguous()
return torch.sparse_coo_tensor(indices, values)