setup.py 3.85 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
import os
rusty1s's avatar
rusty1s committed
2
import os.path as osp
rusty1s's avatar
rusty1s committed
3
import sys
rusty1s's avatar
rusty1s committed
4
import glob
rusty1s's avatar
rusty1s committed
5
from setuptools import setup, find_packages
rusty1s's avatar
rusty1s committed
6

rusty1s's avatar
rusty1s committed
7
import torch
rusty1s's avatar
rusty1s committed
8
from torch.__config__ import parallel_info
rusty1s's avatar
rusty1s committed
9
from torch.utils.cpp_extension import BuildExtension
rusty1s's avatar
rusty1s committed
10
from torch.utils.cpp_extension import CppExtension, CUDAExtension, CUDA_HOME
rusty1s's avatar
rusty1s committed
11

rusty1s's avatar
rusty1s committed
12
13
14
WITH_CUDA = torch.cuda.is_available() and CUDA_HOME is not None
if os.getenv('FORCE_CUDA', '0') == '1':
    WITH_CUDA = True
rusty1s's avatar
rusty1s committed
15
if os.getenv('FORCE_CPU', '0') == '1':
rusty1s's avatar
rusty1s committed
16
17
18
19
    WITH_CUDA = False

BUILD_DOCS = os.getenv('BUILD_DOCS', '0') == '1'

rusty1s's avatar
rusty1s committed
20
21
WITH_METIS = True if os.getenv('WITH_METIS', '0') == '1' else False
WITH_MTMETIS = True if os.getenv('WITH_MTMETIS', '0') == '1' else False
rusty1s's avatar
rusty1s committed
22

rusty1s's avatar
rusty1s committed
23
24
25
26

def get_extensions():
    Extension = CppExtension
    define_macros = []
rusty1s's avatar
rusty1s committed
27
28
29
30
    libraries = []
    if WITH_METIS:
        define_macros += [('WITH_METIS', None)]
        libraries += ['metis']
rusty1s's avatar
rusty1s committed
31
32
33
34
35
36
37
    if WITH_MTMETIS:
        define_macros += [('WITH_MTMETIS', None)]
        define_macros += [('MTMETIS_64BIT_VERTICES', None)]
        define_macros += [('MTMETIS_64BIT_EDGES', None)]
        define_macros += [('MTMETIS_64BIT_WEIGHTS', None)]
        define_macros += [('MTMETIS_64BIT_PARTITIONS', None)]
        libraries += ['mtmetis', 'wildriver']
rusty1s's avatar
rusty1s committed
38
39
    extra_compile_args = {'cxx': ['-O2']}
    extra_link_args = ['-s']
rusty1s's avatar
rusty1s committed
40

rusty1s's avatar
rusty1s committed
41
42
43
44
45
46
47
48
49
50
    info = parallel_info()
    if 'parallel backend: OpenMP' in info and 'OpenMP not found' not in info:
        extra_compile_args['cxx'] += ['-DAT_PARALLEL_OPENMP']
        if sys.platform == 'win32':
            extra_compile_args['cxx'] += ['/openmp']
        else:
            extra_compile_args['cxx'] += ['-fopenmp']
    else:
        print('Compiling without OpenMP...')

rusty1s's avatar
rusty1s committed
51
52
53
54
55
    if WITH_CUDA:
        Extension = CUDAExtension
        define_macros += [('WITH_CUDA', None)]
        nvcc_flags = os.getenv('NVCC_FLAGS', '')
        nvcc_flags = [] if nvcc_flags == '' else nvcc_flags.split(' ')
rusty1s's avatar
rusty1s committed
56
        nvcc_flags += ['-arch=sm_35', '--expt-relaxed-constexpr', '-O2']
rusty1s's avatar
rusty1s committed
57
        extra_compile_args['nvcc'] = nvcc_flags
rusty1s's avatar
rusty1s committed
58

rusty1s's avatar
rusty1s committed
59
        if sys.platform == 'win32':
rusty1s's avatar
fix  
rusty1s committed
60
            extra_link_args += ['cusparse.lib']
rusty1s's avatar
rusty1s committed
61
        else:
rusty1s's avatar
retry  
rusty1s committed
62
            extra_link_args += ['-lcusparse', '-l', 'cusparse']
rusty1s's avatar
rusty1s committed
63

rusty1s's avatar
rusty1s committed
64
65
66
67
68
69
    extensions_dir = osp.join(osp.dirname(osp.abspath(__file__)), 'csrc')
    main_files = glob.glob(osp.join(extensions_dir, '*.cpp'))
    extensions = []
    for main in main_files:
        name = main.split(os.sep)[-1][:-4]

rusty1s's avatar
rusty1s committed
70
71
        sources = [main]

rusty1s's avatar
rusty1s committed
72
        path = osp.join(extensions_dir, 'cpu', f'{name}_cpu.cpp')
rusty1s's avatar
rusty1s committed
73
74
75
        if osp.exists(path):
            sources += [path]

rusty1s's avatar
rusty1s committed
76
        path = osp.join(extensions_dir, 'cuda', f'{name}_cuda.cu')
rusty1s's avatar
rusty1s committed
77
78
        if WITH_CUDA and osp.exists(path):
            sources += [path]
rusty1s's avatar
rusty1s committed
79
80

        extension = Extension(
rusty1s's avatar
rusty1s committed
81
            'torch_sparse._' + name,
rusty1s's avatar
rusty1s committed
82
83
84
85
            sources,
            include_dirs=[extensions_dir],
            define_macros=define_macros,
            extra_compile_args=extra_compile_args,
86
            extra_link_args=extra_link_args,
rusty1s's avatar
rusty1s committed
87
            libraries=libraries,
rusty1s's avatar
rusty1s committed
88
89
90
91
92
        )
        extensions += [extension]

    return extensions

rusty1s's avatar
rusty1s committed
93
94
95
96

install_requires = ['scipy']
setup_requires = ['pytest-runner']
tests_require = ['pytest', 'pytest-cov']
rusty1s's avatar
rusty1s committed
97
98
99

setup(
    name='torch_sparse',
rusty1s's avatar
rusty1s committed
100
    version='0.6.8',
rusty1s's avatar
rusty1s committed
101
102
    author='Matthias Fey',
    author_email='matthias.fey@tu-dortmund.de',
rusty1s's avatar
rusty1s committed
103
104
105
    url='https://github.com/rusty1s/pytorch_sparse',
    description=('PyTorch Extension Library of Optimized Autograd Sparse '
                 'Matrix Operations'),
rusty1s's avatar
rusty1s committed
106
    keywords=['pytorch', 'sparse', 'sparse-matrices', 'autograd'],
rusty1s's avatar
rusty1s committed
107
    license='MIT',
rusty1s's avatar
rusty1s committed
108
    python_requires='>=3.6',
rusty1s's avatar
rusty1s committed
109
110
111
    install_requires=install_requires,
    setup_requires=setup_requires,
    tests_require=tests_require,
rusty1s's avatar
rusty1s committed
112
    extras_require={'test': tests_require},
rusty1s's avatar
rusty1s committed
113
114
    ext_modules=get_extensions() if not BUILD_DOCS else [],
    cmdclass={
rusty1s's avatar
rusty1s committed
115
116
        'build_ext':
        BuildExtension.with_options(no_python_abi_suffix=True, use_ninja=False)
rusty1s's avatar
rusty1s committed
117
    },
118
119
    packages=find_packages(),
)