setup.py 5.4 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
import glob
rusty1s's avatar
rusty1s committed
2
import os
rusty1s's avatar
rusty1s committed
3
import os.path as osp
Amit Aflalo's avatar
Amit Aflalo committed
4
import platform
rusty1s's avatar
rusty1s committed
5
6
import sys
from itertools import product
rusty1s's avatar
rusty1s committed
7

rusty1s's avatar
rusty1s committed
8
import torch
rusty1s's avatar
rusty1s committed
9
from setuptools import find_packages, setup
rusty1s's avatar
rusty1s committed
10
from torch.__config__ import parallel_info
Matthias Fey's avatar
Matthias Fey committed
11
12
13
14
15
16
from torch.utils.cpp_extension import (
    CUDA_HOME,
    BuildExtension,
    CppExtension,
    CUDAExtension,
)
rusty1s's avatar
rusty1s committed
17

Matthias Fey's avatar
Matthias Fey committed
18
__version__ = '0.6.16'
rusty1s's avatar
rusty1s committed
19
URL = 'https://github.com/rusty1s/pytorch_sparse'
rusty1s's avatar
rusty1s committed
20

dkbhaskaran's avatar
dkbhaskaran committed
21
22
23
WITH_CUDA = False
if torch.cuda.is_available():
    WITH_CUDA = CUDA_HOME is not None or torch.version.hip
rusty1s's avatar
rusty1s committed
24
suffices = ['cpu', 'cuda'] if WITH_CUDA else ['cpu']
rusty1s's avatar
rusty1s committed
25
if os.getenv('FORCE_CUDA', '0') == '1':
rusty1s's avatar
rusty1s committed
26
27
28
29
30
    suffices = ['cuda', 'cpu']
if os.getenv('FORCE_ONLY_CUDA', '0') == '1':
    suffices = ['cuda']
if os.getenv('FORCE_ONLY_CPU', '0') == '1':
    suffices = ['cpu']
rusty1s's avatar
rusty1s committed
31
32
33

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

rusty1s's avatar
rusty1s committed
34
35
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
36

37
38
WITH_SYMBOLS = True if os.getenv('WITH_SYMBOLS', '0') == '1' else False

rusty1s's avatar
rusty1s committed
39
40

def get_extensions():
rusty1s's avatar
rusty1s committed
41
    extensions = []
rusty1s's avatar
rusty1s committed
42

rusty1s's avatar
rusty1s committed
43
    extensions_dir = osp.join('csrc')
rusty1s's avatar
rusty1s committed
44
    main_files = glob.glob(osp.join(extensions_dir, '*.cpp'))
dkbhaskaran's avatar
dkbhaskaran committed
45
46
    # remove generated 'hip' files, in case of rebuilds
    main_files = [path for path in main_files if 'hip' not in path]
rusty1s's avatar
rusty1s committed
47

rusty1s's avatar
rusty1s committed
48
    for main, suffix in product(main_files, suffices):
49
        define_macros = [('WITH_PYTHON', None)]
dkbhaskaran's avatar
dkbhaskaran committed
50
        undef_macros = []
Daniel Falbel's avatar
Daniel Falbel committed
51
52
53
54

        if sys.platform == 'win32':
            define_macros += [('torchsparse_EXPORTS', None)]

rusty1s's avatar
rusty1s committed
55
56
57
58
59
60
61
62
63
64
65
        libraries = []
        if WITH_METIS:
            define_macros += [('WITH_METIS', None)]
            libraries += ['metis']
        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
66

Matthias Fey's avatar
Matthias Fey committed
67
        extra_compile_args = {'cxx': ['-O3']}
rusty1s's avatar
rusty1s committed
68
69
        if not os.name == 'nt':  # Not on Windows:
            extra_compile_args['cxx'] += ['-Wno-sign-compare']
70
        extra_link_args = [] if WITH_SYMBOLS else ['-s']
rusty1s's avatar
rusty1s committed
71
72

        info = parallel_info()
rusty1s's avatar
rusty1s committed
73
74
        if ('backend: OpenMP' in info and 'OpenMP not found' not in info
                and sys.platform != 'darwin'):
rusty1s's avatar
rusty1s committed
75
76
77
78
79
80
81
82
            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...')

Amit Aflalo's avatar
Amit Aflalo committed
83
84
85
86
87
        # Compile for mac arm64
        if (sys.platform == 'darwin' and platform.machine() == 'arm64'):
            extra_compile_args['cxx'] += ['-arch', 'arm64']
            extra_link_args += ['-arch', 'arm64']

rusty1s's avatar
rusty1s committed
88
89
90
91
        if suffix == 'cuda':
            define_macros += [('WITH_CUDA', None)]
            nvcc_flags = os.getenv('NVCC_FLAGS', '')
            nvcc_flags = [] if nvcc_flags == '' else nvcc_flags.split(' ')
Matthias Fey's avatar
Matthias Fey committed
92
            nvcc_flags += ['-O3']
dkbhaskaran's avatar
dkbhaskaran committed
93
94
95
96
97
98
99
            if torch.version.hip:
                # USE_ROCM was added to later versions of PyTorch
                # Define here to support older PyTorch versions as well:
                define_macros += [('USE_ROCM', None)]
                undef_macros += ['__HIP_NO_HALF_CONVERSIONS__']
            else:
                nvcc_flags += ['--expt-relaxed-constexpr']
Matthias Fey's avatar
Matthias Fey committed
100
            extra_compile_args['nvcc'] = nvcc_flags
rusty1s's avatar
rusty1s committed
101
102

        name = main.split(os.sep)[-1][:-4]
rusty1s's avatar
rusty1s committed
103
104
        sources = [main]

rusty1s's avatar
rusty1s committed
105
        path = osp.join(extensions_dir, 'cpu', f'{name}_cpu.cpp')
rusty1s's avatar
rusty1s committed
106
107
108
        if osp.exists(path):
            sources += [path]

rusty1s's avatar
rusty1s committed
109
        path = osp.join(extensions_dir, 'cuda', f'{name}_cuda.cu')
rusty1s's avatar
rusty1s committed
110
        if suffix == 'cuda' and osp.exists(path):
rusty1s's avatar
rusty1s committed
111
            sources += [path]
rusty1s's avatar
rusty1s committed
112

113
114
        phmap_dir = "third_party/parallel-hashmap"

rusty1s's avatar
rusty1s committed
115
        Extension = CppExtension if suffix == 'cpu' else CUDAExtension
rusty1s's avatar
rusty1s committed
116
        extension = Extension(
rusty1s's avatar
rusty1s committed
117
            f'torch_sparse._{name}_{suffix}',
rusty1s's avatar
rusty1s committed
118
            sources,
119
            include_dirs=[extensions_dir, phmap_dir],
rusty1s's avatar
rusty1s committed
120
            define_macros=define_macros,
dkbhaskaran's avatar
dkbhaskaran committed
121
            undef_macros=undef_macros,
rusty1s's avatar
rusty1s committed
122
            extra_compile_args=extra_compile_args,
123
            extra_link_args=extra_link_args,
rusty1s's avatar
rusty1s committed
124
            libraries=libraries,
rusty1s's avatar
rusty1s committed
125
126
127
128
129
        )
        extensions += [extension]

    return extensions

rusty1s's avatar
rusty1s committed
130

rusty1s's avatar
rusty1s committed
131
132
133
134
135
136
137
138
install_requires = [
    'scipy',
]

test_requires = [
    'pytest',
    'pytest-cov',
]
rusty1s's avatar
rusty1s committed
139

dkbhaskaran's avatar
dkbhaskaran committed
140
141
142
143
144
# work-around hipify abs paths
include_package_data = True
if torch.cuda.is_available() and torch.version.hip:
    include_package_data = False

rusty1s's avatar
rusty1s committed
145
146
setup(
    name='torch_sparse',
rusty1s's avatar
rusty1s committed
147
    version=__version__,
rusty1s's avatar
rusty1s committed
148
149
    description=('PyTorch Extension Library of Optimized Autograd Sparse '
                 'Matrix Operations'),
rusty1s's avatar
rusty1s committed
150
151
152
153
154
155
156
157
158
159
160
    author='Matthias Fey',
    author_email='matthias.fey@tu-dortmund.de',
    url=URL,
    download_url=f'{URL}/archive/{__version__}.tar.gz',
    keywords=[
        'pytorch',
        'sparse',
        'sparse-matrices',
        'autograd',
    ],
    python_requires='>=3.7',
rusty1s's avatar
rusty1s committed
161
    install_requires=install_requires,
rusty1s's avatar
rusty1s committed
162
163
164
    extras_require={
        'test': test_requires,
    },
rusty1s's avatar
rusty1s committed
165
166
    ext_modules=get_extensions() if not BUILD_DOCS else [],
    cmdclass={
rusty1s's avatar
rusty1s committed
167
168
        'build_ext':
        BuildExtension.with_options(no_python_abi_suffix=True, use_ninja=False)
rusty1s's avatar
rusty1s committed
169
    },
170
    packages=find_packages(),
dkbhaskaran's avatar
dkbhaskaran committed
171
    include_package_data=include_package_data,
172
)