setup.py 2.97 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
4
import sys
import glob
rusty1s's avatar
rusty1s committed
5
from setuptools import setup, find_packages
rusty1s's avatar
rusty1s committed
6

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

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

rusty1s's avatar
rusty1s committed
17
18
BUILD_DOCS = os.getenv('BUILD_DOCS', '0') == '1'

rusty1s's avatar
rusty1s committed
19

rusty1s's avatar
rusty1s committed
20
def get_extensions():
rusty1s's avatar
rusty1s committed
21
22
23
    Extension = CppExtension
    define_macros = []
    extra_compile_args = {'cxx': [], 'nvcc': []}
rusty1s's avatar
rusty1s committed
24

rusty1s's avatar
rusty1s committed
25
26
27
28
29
    # flags = os.getenv('EXTRA_COMPILE_ARGS', '')
    # extra_compile_args['cxx'] += [] if flags == '' else flags.split(' ')
    # extra_compile_args['nvcc'] += [] if flags == '' else flags.split(' ')

    libraries = []
rusty1s's avatar
include  
rusty1s committed
30
31

    # Windows users: Make sure that your VS path is included, i.e.:
rusty1s's avatar
rusty1s committed
32
33
34
    # extra_compile_args['cxx'] += ['-I{VISUAL_STUDIO_DIR}\\include']
    # extra_compile_args['nvcc'] += ['-I{VISUAL_STUDIO_DIR}\\include']

rusty1s's avatar
rusty1s committed
35
    if WITH_CUDA:
rusty1s's avatar
rusty1s committed
36
37
        Extension = CUDAExtension
        define_macros += [('WITH_CUDA', None)]
rusty1s's avatar
include  
rusty1s committed
38
        extra_compile_args['cxx'] += ['-O0']
rusty1s's avatar
rusty1s committed
39
40
41
42
43
44
        nvcc_flags = os.getenv('NVCC_FLAGS', '')
        nvcc_flags = [] if nvcc_flags == '' else nvcc_flags.split(' ')
        nvcc_flags += ['-arch=sm_35', '--expt-relaxed-constexpr']
        extra_compile_args['nvcc'] += nvcc_flags

    if sys.platform == 'win32':
rusty1s's avatar
rusty1s committed
45
        # extra_compile_args['cxx'] += ['/MP']
rusty1s's avatar
revert  
rusty1s committed
46
47
        # libraries = ['ATen', '_C']
        pass
rusty1s's avatar
rusty1s committed
48

rusty1s's avatar
rusty1s committed
49
50
51
52
53
54
55
56
57
58
59
60
    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]

        sources = [main, osp.join(extensions_dir, 'cpu', f'{name}_cpu.cpp')]
        if WITH_CUDA:
            sources += [osp.join(extensions_dir, 'cuda', f'{name}_cuda.cu')]

        extension = Extension(
            f'torch_scatter._{name}',
rusty1s's avatar
rusty1s committed
61
62
63
64
            sources,
            include_dirs=[extensions_dir],
            define_macros=define_macros,
            extra_compile_args=extra_compile_args,
rusty1s's avatar
rusty1s committed
65
            libraries=libraries,
rusty1s's avatar
rusty1s committed
66
        )
rusty1s's avatar
rusty1s committed
67
68
69
        extensions += [extension]

    return extensions
rusty1s's avatar
rusty1s committed
70

rusty1s's avatar
rusty1s committed
71

rusty1s's avatar
rusty1s committed
72
install_requires = []
rusty1s's avatar
rusty1s committed
73
setup_requires = ['pytest-runner']
rusty1s's avatar
rusty1s committed
74
tests_require = ['pytest', 'pytest-cov']
rusty1s's avatar
rusty1s committed
75

rusty1s's avatar
rusty1s committed
76
setup(
rusty1s's avatar
rusty1s committed
77
    name='torch_scatter',
rusty1s's avatar
rusty1s committed
78
    version='2.0.2',
rusty1s's avatar
rusty1s committed
79
80
    author='Matthias Fey',
    author_email='matthias.fey@tu-dortmund.de',
rusty1s's avatar
rusty1s committed
81
82
83
84
    url='https://github.com/rusty1s/pytorch_scatter',
    description='PyTorch Extension Library of Optimized Scatter Operations',
    keywords=['pytorch', 'scatter', 'segment', 'gather'],
    license='MIT',
rusty1s's avatar
rusty1s committed
85
    python_requires='>=3.6',
rusty1s's avatar
rusty1s committed
86
87
    install_requires=install_requires,
    setup_requires=setup_requires,
rusty1s's avatar
rusty1s committed
88
    tests_require=tests_require,
rusty1s's avatar
rusty1s committed
89
    ext_modules=get_extensions() if not BUILD_DOCS else [],
rusty1s's avatar
rusty1s committed
90
91
92
    cmdclass={
        'build_ext': BuildExtension.with_options(no_python_abi_suffix=True)
    },
rusty1s's avatar
rusty1s committed
93
94
    packages=find_packages(),
)