__init__.py 2.81 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# flake8: noqa

import importlib
import os.path as osp

import torch

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

try:
    torch.ops.load_library(importlib.machinery.PathFinder().find_spec(
        '_version', [osp.dirname(__file__)]).origin)
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
24
25
26
27
28
29
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
30
31
32
33
34
35
36
37
38
39
40
41
42
        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
43
44
45
from .storage import SparseStorage
from .tensor import SparseTensor
from .transpose import t
rusty1s's avatar
rusty1s committed
46
from .narrow import narrow, __narrow_diag__
rusty1s's avatar
rusty1s committed
47
48
49
50
51
52
53
54
55
56
from .select import select
from .index_select import index_select, index_select_nnz
from .masked_select import masked_select, masked_select_nnz
from .diag import remove_diag, set_diag, fill_diag
from .add import add, add_, add_nnz, add_nnz_
from .mul import mul, mul_, mul_nnz, mul_nnz_
from .reduce import sum, mean, min, max
from .matmul import matmul
from .cat import cat, cat_diag

57
from .convert import to_torch_sparse, from_torch_sparse, to_scipy, from_scipy
rusty1s's avatar
rusty1s committed
58
from .coalesce import coalesce
59
from .transpose import transpose
rusty1s's avatar
rusty1s committed
60
from .eye import eye
rusty1s's avatar
rusty1s committed
61
62
from .spmm import spmm
from .spspmm import spspmm
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
]