setup.py 4.18 KB
Newer Older
1
import torch
2
from setuptools import setup, find_packages
3

jjsjann123's avatar
jjsjann123 committed
4
5
import sys

6
7
8
9
if not torch.cuda.is_available():
    print("Warning: Torch did not find available GPUs on this system.\n",
          "If your intention is to cross-compile, this is not an error.")

10
11
12
13
14
print("torch.__version__  = ", torch.__version__)
TORCH_MAJOR = int(torch.__version__.split('.')[0])
TORCH_MINOR = int(torch.__version__.split('.')[1])

if TORCH_MAJOR == 0 and TORCH_MINOR < 4:
Michael Carilli's avatar
Michael Carilli committed
15
      raise RuntimeError("Apex requires Pytorch 0.4 or newer.\n" +
16
17
                         "The latest stable release can be obtained from https://pytorch.org/")

jjsjann123's avatar
jjsjann123 committed
18
19
20
cmdclass = {}
ext_modules = []

21
if "--cpp_ext" in sys.argv or "--cuda_ext" in sys.argv:
Michael Carilli's avatar
Michael Carilli committed
22
23
24
    if TORCH_MAJOR == 0:
        raise RuntimeError("--cpp_ext requires Pytorch 1.0 or later, "
                           "found torch.__version__ = {}".format(torch.__version))
25
26
27
28
29
30
31
32
33
34
    from torch.utils.cpp_extension import BuildExtension
    cmdclass['build_ext'] = BuildExtension

if "--cpp_ext" in sys.argv:
    from torch.utils.cpp_extension import CppExtension
    sys.argv.remove("--cpp_ext")
    ext_modules.append(
        CppExtension('apex_C',
                     ['csrc/flatten_unflatten.cpp',]))

jjsjann123's avatar
jjsjann123 committed
35
if "--cuda_ext" in sys.argv:
36
    from torch.utils.cpp_extension import CUDAExtension
jjsjann123's avatar
jjsjann123 committed
37
    sys.argv.remove("--cuda_ext")
38
39

    if torch.utils.cpp_extension.CUDA_HOME is None:
Michael Carilli's avatar
Michael Carilli committed
40
        raise RuntimeError("--cuda_ext was requested, but nvcc was not found.  Are you sure your environment has nvcc available?  If you're installing within a container from https://hub.docker.com/r/pytorch/pytorch, only images whose names contain 'devel' will provide nvcc.")
41
    else:
Michael Carilli's avatar
Michael Carilli committed
42
43
44
45
46
47
        # Set up macros for forward/backward compatibility hack around
        # https://github.com/pytorch/pytorch/commit/4404762d7dd955383acee92e6f06b48144a0742e
        version_ge_1_1 = []
        if (TORCH_MAJOR > 1) or (TORCH_MAJOR == 1 and TORCH_MINOR > 0):
            version_ge_1_1 = ['-DVERSION_GE_1_1']

48
49
        ext_modules.append(
            CUDAExtension(name='amp_C',
50
                          sources=['csrc/amp_C_frontend.cpp',
Michael Carilli's avatar
Michael Carilli committed
51
                                   'csrc/scale_check_overflow_kernel.cu',
52
53
                                   'csrc/multi_tensor_scale_kernel.cu'],
                          extra_compile_args={'cxx': ['-O3'],
Michael Carilli's avatar
Michael Carilli committed
54
                                              'nvcc':['-lineinfo',
55
                                                      '-O3',
Michael Carilli's avatar
Michael Carilli committed
56
                                                      '--use_fast_math']}))
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
        ext_modules.append(
            CUDAExtension(name='fused_adam_cuda',
                          sources=['apex/optimizers/csrc/fused_adam_cuda.cpp',
                                   'apex/optimizers/csrc/fused_adam_cuda_kernel.cu'],
                          extra_compile_args={'cxx': ['-O3',],
                                              'nvcc':['-O3', 
                                                      '--use_fast_math']}))
        ext_modules.append(
            CUDAExtension(name='syncbn',
                          sources=['csrc/syncbn.cpp',
                                   'csrc/welford.cu']))
        ext_modules.append(
            CUDAExtension(name='fused_layer_norm_cuda',
                          sources=['apex/normalization/csrc/layer_norm_cuda.cpp',
                                   'apex/normalization/csrc/layer_norm_cuda_kernel.cu'],
Michael Carilli's avatar
Michael Carilli committed
72
                          extra_compile_args={'cxx': ['-O3'] + version_ge_1_1,
73
74
                                              'nvcc':['-maxrregcount=50',
                                                      '-O3', 
Michael Carilli's avatar
Michael Carilli committed
75
                                                      '--use_fast_math'] + version_ge_1_1}))
jjsjann123's avatar
jjsjann123 committed
76

Christian Sarofeen's avatar
Christian Sarofeen committed
77
setup(
78
79
    name='apex',
    version='0.1',
80
81
82
83
    packages=find_packages(exclude=('build',
                                    'csrc',
                                    'include',
                                    'tests',
84
85
86
87
88
                                    'dist',
                                    'docs',
                                    'tests',
                                    'examples',
                                    'apex.egg-info',)),
Christian Sarofeen's avatar
Christian Sarofeen committed
89
    description='PyTorch Extensions written by NVIDIA',
jjsjann123's avatar
jjsjann123 committed
90
91
    ext_modules=ext_modules,
    cmdclass=cmdclass,
Christian Sarofeen's avatar
Christian Sarofeen committed
92
)