__init__.py 2.82 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
rusty1s committed
24
cuda_version = torch.ops.torch_sparse.cuda_version()
rusty1s's avatar
rusty1s committed
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
if cuda_version != -1 and torch.version.cuda is not None:  # pragma: no cover
    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('.')]
    cuda_version = str(major) + '.' + str(minor)

    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
41
42
43
from .storage import SparseStorage
from .tensor import SparseTensor
from .transpose import t
rusty1s's avatar
rusty1s committed
44
from .narrow import narrow, __narrow_diag__
rusty1s's avatar
rusty1s committed
45
46
47
48
49
50
51
52
53
54
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

55
from .convert import to_torch_sparse, from_torch_sparse, to_scipy, from_scipy
rusty1s's avatar
rusty1s committed
56
from .coalesce import coalesce
57
from .transpose import transpose
rusty1s's avatar
rusty1s committed
58
from .eye import eye
rusty1s's avatar
rusty1s committed
59
60
from .spmm import spmm
from .spspmm import spspmm
rusty1s's avatar
rusty1s committed
61
62

__all__ = [
rusty1s's avatar
rusty1s committed
63
64
65
66
    'SparseStorage',
    'SparseTensor',
    't',
    'narrow',
rusty1s's avatar
rusty1s committed
67
    '__narrow_diag__',
rusty1s's avatar
rusty1s committed
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
    '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',
91
92
    'to_torch_sparse',
    'from_torch_sparse',
rusty1s's avatar
rusty1s committed
93
94
    'to_scipy',
    'from_scipy',
rusty1s's avatar
rusty1s committed
95
    'coalesce',
rusty1s's avatar
rusty1s committed
96
    'transpose',
rusty1s's avatar
rusty1s committed
97
    'eye',
rusty1s's avatar
rusty1s committed
98
    'spmm',
rusty1s's avatar
rusty1s committed
99
    'spspmm',
rusty1s's avatar
rusty1s committed
100
    '__version__',
rusty1s's avatar
rusty1s committed
101
]