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

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

rusty1s's avatar
rusty1s committed
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
WITH_CUDA = torch.cuda.is_available() and CUDA_HOME is not None
if os.getenv('FORCE_CUDA', '0') == '1':
    WITH_CUDA = True
if os.getenv('FORCE_CPU', '0') == '1':
    WITH_CUDA = False

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


def get_extensions():
    Extension = CppExtension
    define_macros = []
    extra_compile_args = {'cxx': []}

    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
29
        nvcc_flags += ['-arch=sm_35', '--expt-relaxed-constexpr']
rusty1s's avatar
rusty1s committed
30
31
32
33
34
35
36
        extra_compile_args['nvcc'] = nvcc_flags

    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
37

rusty1s's avatar
rusty1s committed
38
        sources = [main]
rusty1s's avatar
rusty1s committed
39

rusty1s's avatar
rusty1s committed
40
41
42
        path = osp.join(extensions_dir, 'cpu', f'{name}_cpu.cpp')
        if osp.exists(path):
            sources += [path]
rusty1s's avatar
rusty1s committed
43

rusty1s's avatar
rusty1s committed
44
45
46
        path = osp.join(extensions_dir, 'cuda', f'{name}_cuda.cu')
        if WITH_CUDA and osp.exists(path):
            sources += [path]
Dmitry Leonov's avatar
Dmitry Leonov committed
47

rusty1s's avatar
rusty1s committed
48
49
50
51
52
53
54
55
56
57
        extension = Extension(
            'torch_cluster._' + name,
            sources,
            include_dirs=[extensions_dir],
            define_macros=define_macros,
            extra_compile_args=extra_compile_args,
        )
        extensions += [extension]

    return extensions
rusty1s's avatar
rusty1s committed
58
59


rusty1s's avatar
rusty1s committed
60
install_requires = ['scipy']
rusty1s's avatar
rusty1s committed
61
setup_requires = ['pytest-runner']
rusty1s's avatar
rusty1s committed
62
63
64
tests_require = ['pytest', 'pytest-cov']

setup(
rusty1s's avatar
rusty1s committed
65
    name='torch_cluster',
rusty1s's avatar
rusty1s committed
66
    version='1.5.3',
rusty1s's avatar
rusty1s committed
67
68
    author='Matthias Fey',
    author_email='matthias.fey@tu-dortmund.de',
rusty1s's avatar
rusty1s committed
69
70
71
    url='https://github.com/rusty1s/pytorch_cluster',
    description=('PyTorch Extension Library of Optimized Graph Cluster '
                 'Algorithms'),
rusty1s's avatar
rusty1s committed
72
73
74
75
76
77
    keywords=[
        'pytorch',
        'geometric-deep-learning',
        'graph-neural-networks',
        'cluster-algorithms',
    ],
rusty1s's avatar
rusty1s committed
78
    license='MIT',
rusty1s's avatar
update  
rusty1s committed
79
    python_requires='>=3.6',
rusty1s's avatar
rusty1s committed
80
81
82
    install_requires=install_requires,
    setup_requires=setup_requires,
    tests_require=tests_require,
rusty1s's avatar
rusty1s committed
83
84
85
86
    ext_modules=get_extensions() if not BUILD_DOCS else [],
    cmdclass={
        'build_ext': BuildExtension.with_options(no_python_abi_suffix=True)
    },
87
88
    packages=find_packages(),
)