segment.py 902 Bytes
Newer Older
rusty1s's avatar
rusty1s committed
1
2
3
import torch

from torch_scatter.utils.gen import gen
rusty1s's avatar
rusty1s committed
4
from torch_scatter.add import scatter_add
rusty1s's avatar
rusty1s committed
5
6
7
8
9
10
11
12
13

if torch.cuda.is_available():
    import torch_scatter.segment_cuda


def segment_add(src, index, dim=-1, out=None, dim_size=None, fill_value=0):
    src, out, index, dim = gen(src, index, dim, out, dim_size, fill_value)
    if src.size(dim) == 0:  # pragma: no cover
        return out
rusty1s's avatar
rusty1s committed
14
15
16
17
18
19
20
21
22

    if not src.is_cuda:
        return scatter_add(src, index, dim, out, dim_size, fill_value)

    torch_scatter.segment_cuda.segment_add_thrust(src, index, out)

    return out


rusty1s's avatar
rusty1s committed
23
def segment_add_csr(src, indptr):
rusty1s's avatar
rusty1s committed
24
    return torch_scatter.segment_cuda.segment_add_csr(src, indptr)
rusty1s's avatar
rusty1s committed
25
26
27
28
29
30
31


def segment_add_coo(src, index, dim_size=None):
    dim_size = index.max().item() + 1 if dim_size is None else dim_size
    out = src.new_zeros(dim_size)
    torch_scatter.segment_cuda.segment_add_coo(src, index, out)
    return out