forked from mit-han-lab/torchsparse
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup.py
61 lines (54 loc) · 1.51 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
import glob
import os
import torch
import torch.cuda
from setuptools import find_packages, setup
from torch.utils.cpp_extension import (
CUDA_HOME,
BuildExtension,
CppExtension,
CUDAExtension,
)
# from torchsparse import __version__
version_file = open("./torchsparse/version.py")
version = version_file.read().split("'")[1]
print("torchsparse version:", version)
if (torch.cuda.is_available() and CUDA_HOME is not None) or (
os.getenv("FORCE_CUDA", "0") == "1"
):
device = "cuda"
pybind_fn = f"pybind_{device}.cu"
else:
device = "cpu"
pybind_fn = f"pybind_{device}.cpp"
sources = [os.path.join("torchsparse", "backend", pybind_fn)]
for fpath in glob.glob(os.path.join("torchsparse", "backend", "**", "*")):
if (fpath.endswith("_cpu.cpp") and device in ["cpu", "cuda"]) or (
fpath.endswith("_cuda.cu") and device == "cuda"
):
sources.append(fpath)
extension_type = CUDAExtension if device == "cuda" else CppExtension
extra_compile_args = {
"cxx": ["-g", "-O3", "-fopenmp", "-lgomp"],
"nvcc": ["-O3", "-std=c++17"],
}
setup(
name="torchsparse",
version=version,
packages=find_packages(),
ext_modules=[
extension_type(
"torchsparse.backend", sources, extra_compile_args=extra_compile_args
)
],
install_requires=[
"numpy",
"backports.cached_property",
"tqdm",
"typing-extensions",
"wheel",
"rootpath",
],
cmdclass={"build_ext": BuildExtension},
zip_safe=False,
)