__init__.py 2.67 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
2
# flake8: noqa

rusty1s's avatar
rusty1s committed
3
import importlib
rusty1s's avatar
typo  
rusty1s committed
4
5
6
7
import os.path as osp

import torch

rusty1s's avatar
rusty1s committed
8
__version__ = '2.0.3'
rusty1s's avatar
clean  
rusty1s committed
9
expected_torch_version = (1, 4)
rusty1s's avatar
rusty1s committed
10
11
12
13
14

try:
    torch.ops.load_library(importlib.machinery.PathFinder().find_spec(
        '_version', [osp.dirname(__file__)]).origin)
except OSError as e:
rusty1s's avatar
clean  
rusty1s committed
15
16
17
18
19
20
21
    if 'undefined symbol' in str(e):
        major, minor = [int(x) for x in torch.__version__.split('.')[:2]]
        t_major, t_minor = expected_torch_version
        if major != t_major or (major == t_major and minor != t_minor):
            raise RuntimeError(
                'Expected PyTorch version {}.{} but found version '
                '{}.{}.'.format(t_major, t_minor, major, minor))
rusty1s's avatar
rusty1s committed
22
23
    raise OSError(e)

rusty1s's avatar
rusty1s committed
24
25
from .scatter import (scatter_sum, scatter_add, scatter_mean, scatter_min,
                      scatter_max, scatter)
rusty1s's avatar
rusty1s committed
26
27
from .segment_csr import (segment_sum_csr, segment_add_csr, segment_mean_csr,
                          segment_min_csr, segment_max_csr, segment_csr,
rusty1s's avatar
rusty1s committed
28
                          gather_csr)
rusty1s's avatar
rusty1s committed
29
30
from .segment_coo import (segment_sum_coo, segment_add_coo, segment_mean_coo,
                          segment_min_coo, segment_max_coo, segment_coo,
rusty1s's avatar
rusty1s committed
31
                          gather_coo)
rusty1s's avatar
rusty1s committed
32
33
from .composite import (scatter_std, scatter_logsumexp, scatter_softmax,
                        scatter_log_softmax)
rusty1s's avatar
rusty1s committed
34

rusty1s's avatar
rusty1s committed
35
cuda_version = torch.ops.torch_scatter.cuda_version()
rusty1s's avatar
rusty1s committed
36
if cuda_version != -1 and torch.version.cuda is not None:  # pragma: no cover
rusty1s's avatar
rusty1s committed
37
38
39
40
41
    if cuda_version < 10000:
        major, minor = int(str(cuda_version)[0]), int(str(cuda_version)[2])
    else:
        major, minor = int(str(cuda_version)[0:2]), int(str(cuda_version)[3])
    t_major, t_minor = [int(x) for x in torch.version.cuda.split('.')]
rusty1s's avatar
rusty1s committed
42
43
    cuda_version = str(major) + '.' + str(minor)

rusty1s's avatar
rusty1s committed
44
45
46
47
48
49
50
    if t_major != major or t_minor != minor:
        raise RuntimeError(
            'Detected that PyTorch and torch_scatter were compiled with '
            'different CUDA versions. PyTorch has CUDA version={}.{} and '
            'torch_scatter has CUDA version={}.{}. Please reinstall the '
            'torch_scatter that matches your PyTorch install.'.format(
                t_major, t_minor, major, minor))
rusty1s's avatar
cleaner  
rusty1s committed
51

rusty1s's avatar
rusty1s committed
52
__all__ = [
rusty1s's avatar
rusty1s committed
53
54
55
56
57
58
    'scatter_sum',
    'scatter_add',
    'scatter_mean',
    'scatter_min',
    'scatter_max',
    'scatter',
rusty1s's avatar
rusty1s committed
59
60
61
62
63
    'segment_sum_csr',
    'segment_add_csr',
    'segment_mean_csr',
    'segment_min_csr',
    'segment_max_csr',
rusty1s's avatar
rusty1s committed
64
    'segment_csr',
rusty1s's avatar
rusty1s committed
65
    'gather_csr',
rusty1s's avatar
rusty1s committed
66
67
68
69
70
71
72
    'segment_sum_coo',
    'segment_add_coo',
    'segment_mean_coo',
    'segment_min_coo',
    'segment_max_coo',
    'segment_coo',
    'gather_coo',
rusty1s's avatar
rusty1s committed
73
74
75
76
    'scatter_std',
    'scatter_logsumexp',
    'scatter_softmax',
    'scatter_log_softmax',
77
    'torch_scatter',
rusty1s's avatar
rusty1s committed
78
    '__version__',
rusty1s's avatar
rusty1s committed
79
]