__init__.py 3.18 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
2
3
4
5
6
7
8
9
import importlib
import os.path as osp

import torch

__version__ = '0.5.1'
expected_torch_version = (1, 4)

try:
rusty1s's avatar
rusty1s committed
10
11
12
    for library in ['_version', '_convert', '_diag', '_spmm', '_spspmm']:
        torch.ops.load_library(importlib.machinery.PathFinder().find_spec(
            library, [osp.dirname(__file__)]).origin)
rusty1s's avatar
rusty1s committed
13
14
15
16
17
18
19
20
21
22
except OSError as e:
    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(
                f'Expected PyTorch version {t_major}.{t_minor} but found '
                f'version {major}.{minor}.')
    raise OSError(e)

rusty1s's avatar
cleaner  
rusty1s committed
23
24
25
26
27
28
if torch.version.cuda is not None:  # pragma: no cover
    cuda_version = torch.ops.torch_sparse.cuda_version()

    if cuda_version == -1:
        major = minor = 0
    elif cuda_version < 10000:
rusty1s's avatar
rusty1s committed
29
30
31
32
33
34
35
36
37
38
39
40
41
        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('.')]

    if t_major != major or t_minor != minor:
        raise RuntimeError(
            f'Detected that PyTorch and torch_sparse were compiled with '
            f'different CUDA versions. PyTorch has CUDA version '
            f'{t_major}.{t_minor} and torch_sparse has CUDA version '
            f'{major}.{minor}. Please reinstall the torch_sparse that '
            f'matches your PyTorch install.')

rusty1s's avatar
rusty1s committed
42
43
44
45
46
47
48
49
50
51
52
53
54
from .storage import SparseStorage  # noqa: E4402
from .tensor import SparseTensor  # noqa: E4402
from .transpose import t  # noqa: E4402
from .narrow import narrow, __narrow_diag__  # noqa: E4402
from .select import select  # noqa: E4402
from .index_select import index_select, index_select_nnz  # noqa: E4402
from .masked_select import masked_select, masked_select_nnz  # noqa: E4402
from .diag import remove_diag, set_diag, fill_diag  # noqa: E4402
from .add import add, add_, add_nnz, add_nnz_  # noqa: E4402
from .mul import mul, mul_, mul_nnz, mul_nnz_  # noqa: E4402
from .reduce import sum, mean, min, max  # noqa: E4402
from .matmul import matmul  # noqa: E4402
from .cat import cat, cat_diag  # noqa: E4402
rusty1s's avatar
rusty1s committed
55

rusty1s's avatar
rusty1s committed
56
57
58
59
60
61
62
from .convert import to_torch_sparse, from_torch_sparse  # noqa: E4402
from .convert import to_scipy, from_scipy  # noqa: E4402
from .coalesce import coalesce  # noqa: E4402
from .transpose import transpose  # noqa: E4402
from .eye import eye  # noqa: E4402
from .spmm import spmm  # noqa: E4402
from .spspmm import spspmm  # noqa: E4402
rusty1s's avatar
rusty1s committed
63
64

__all__ = [
rusty1s's avatar
rusty1s committed
65
66
67
68
    'SparseStorage',
    'SparseTensor',
    't',
    'narrow',
rusty1s's avatar
rusty1s committed
69
    '__narrow_diag__',
rusty1s's avatar
rusty1s committed
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
    'select',
    'index_select',
    'index_select_nnz',
    'masked_select',
    'masked_select_nnz',
    'remove_diag',
    'set_diag',
    'fill_diag',
    'add',
    'add_',
    'add_nnz',
    'add_nnz_',
    'mul',
    'mul_',
    'mul_nnz',
    'mul_nnz_',
    'sum',
    'mean',
    'min',
    'max',
    'matmul',
    'cat',
    'cat_diag',
93
94
    'to_torch_sparse',
    'from_torch_sparse',
rusty1s's avatar
rusty1s committed
95
96
    'to_scipy',
    'from_scipy',
rusty1s's avatar
rusty1s committed
97
    'coalesce',
rusty1s's avatar
rusty1s committed
98
    'transpose',
rusty1s's avatar
rusty1s committed
99
    'eye',
rusty1s's avatar
rusty1s committed
100
    'spmm',
rusty1s's avatar
rusty1s committed
101
    'spspmm',
rusty1s's avatar
rusty1s committed
102
    '__version__',
rusty1s's avatar
rusty1s committed
103
]