import os import sys import glob import os.path as osp from itertools import product from setuptools import setup, find_packages import torch from torch.__config__ import parallel_info from torch.utils.cpp_extension import BuildExtension from torch.utils.cpp_extension import CppExtension, CUDAExtension, CUDA_HOME WITH_HIP = torch.cuda.is_available() and CUDA_HOME is not None suffices = ['cpu', 'cuda'] if WITH_HIP else ['cpu'] if os.getenv('FORCE_CUDA', '0') == '1': suffices = ['cuda', 'cpu'] if os.getenv('FORCE_ONLY_HIP', '0') == '1': suffices = ['hip'] if os.getenv('FORCE_ONLY_CPU', '0') == '1': suffices = ['cpu'] ROCM_PATH = os.getenv('ROCM_PATH') HIPLIB = osp.join(ROCM_PATH, 'hipsparse', 'include') BUILD_DOCS = os.getenv('BUILD_DOCS', '0') == '1' def get_extensions(): extensions = [] extensions_dir = osp.join('csrc') main_files = glob.glob(osp.join(extensions_dir, '*.cpp')) for main, suffix in product(main_files, suffices): define_macros = [] extra_compile_args = {'cxx': ['-O2']} extra_link_args = ['-s'] info = parallel_info() if ('backend: OpenMP' in info and 'OpenMP not found' not in info and sys.platform != 'darwin'): 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...') if suffix == 'hip': define_macros += [('WITH_HIP', None)] hipcc_flags = os.getenv('HIPCC_FLAGS', '') hipcc_flags = [] if hipcc_flags == '' else hipcc_flags.split(' ') hipcc_flags += ['--expt-relaxed-constexpr', '-O2'] extra_compile_args['hipcc'] = hipcc_flags name = main.split(os.sep)[-1][:-4] sources = [main] path = osp.join(extensions_dir, 'cpu', f'{name}_cpu.cpp') if osp.exists(path): sources += [path] path = osp.join(extensions_dir, 'hip', f'{name}_hip.hip') if suffix == 'hip' and osp.exists(path): sources += [path] Extension = CppExtension if suffix == 'cpu' else CUDAExtension define_macros += [('TORCH_HIP_VERSION', 10000), ('__HIP__', None), ('__HCC__', None)] extension = Extension( f'torch_scatter._{name}_{suffix}', sources, include_dirs=[extensions_dir, HIPLIB], define_macros=define_macros, extra_compile_args=extra_compile_args, extra_link_args=extra_link_args, ) extensions += [extension] return extensions install_requires = [] setup_requires = [] tests_require = ['pytest', 'pytest-runner', 'pytest-cov'] setup( name='torch_scatter', version='2.0.9', author='Matthias Fey', author_email='matthias.fey@tu-dortmund.de', url='https://github.com/rusty1s/pytorch_scatter', description='PyTorch Extension Library of Optimized Scatter Operations', keywords=['pytorch', 'scatter', 'segment', 'gather'], license='MIT', python_requires='>=3.6', install_requires=install_requires, setup_requires=setup_requires, tests_require=tests_require, extras_require={'test': tests_require}, ext_modules=get_extensions() if not BUILD_DOCS else [], cmdclass={ 'build_ext': BuildExtension.with_options(no_python_abi_suffix=True, use_ninja=False) }, packages=find_packages(), )