setup.py 2.96 KB
Newer Older
Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
1
2
3
#!/usr/bin/env python3

# Copyright (c) Facebook, Inc. and its affiliates. All rights reserved.
4
5
6
#
# This source code is licensed under the BSD license found in the
# LICENSE file in the root directory of this source tree.
Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
7

Jun Ru Anderson's avatar
Jun Ru Anderson committed
8
import os
9
import re
Jun Ru Anderson's avatar
Jun Ru Anderson committed
10

Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
11
12
import setuptools

13
14
this_dir = os.path.dirname(os.path.abspath(__file__))

Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
15
16
17
18
19
20
21

def fetch_requirements():
    with open("requirements.txt") as f:
        reqs = f.read().strip().split("\n")
    return reqs


22
# https://packaging.python.org/guides/single-sourcing-package-version/
Anupam Bhatnagar's avatar
Anupam Bhatnagar committed
23
def find_version(version_file_path) -> str:
24
    with open(version_file_path) as version_file:
Min Xu's avatar
Min Xu committed
25
        version_match = re.search(r"^__version_tuple__ = (.*)", version_file.read(), re.M)
26
        if version_match:
Min Xu's avatar
Min Xu committed
27
28
29
30
            ver_tup = eval(version_match.group(1))
            ver_str = ".".join([str(x) for x in ver_tup])
            return ver_str
        raise RuntimeError("Unable to find version tuple.")
31
32


Jun Ru Anderson's avatar
Jun Ru Anderson committed
33
34
35
extensions = []
cmdclass = {}

36
37
38
if os.getenv("BUILD_CUDA_EXTENSIONS", "0") == "1":
    from torch.utils.cpp_extension import BuildExtension, CUDAExtension

Jun Ru Anderson's avatar
Jun Ru Anderson committed
39
40
41
42
    extensions.extend(
        [
            CUDAExtension(
                name="fairscale.fused_adam_cuda",
43
                include_dirs=[os.path.join(this_dir, "fairscale/clib/fused_adam_cuda")],
Jun Ru Anderson's avatar
Jun Ru Anderson committed
44
45
46
47
48
49
50
51
52
53
54
55
                sources=[
                    "fairscale/clib/fused_adam_cuda/fused_adam_cuda.cpp",
                    "fairscale/clib/fused_adam_cuda/fused_adam_cuda_kernel.cu",
                ],
                extra_compile_args={"cxx": ["-O3"], "nvcc": ["-O3", "--use_fast_math"]},
            )
        ]
    )

    cmdclass["build_ext"] = BuildExtension


Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
56
57
58
if __name__ == "__main__":
    setuptools.setup(
        name="fairscale",
59
        description="FairScale: A PyTorch library for large-scale and high-performance training.",
Anupam Bhatnagar's avatar
Anupam Bhatnagar committed
60
        version=find_version("fairscale/version.py"),
Myle Ott's avatar
Myle Ott committed
61
        setup_requires=["ninja"],  # ninja is required to build extensions
Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
62
63
64
        install_requires=fetch_requirements(),
        include_package_data=True,
        packages=setuptools.find_packages(exclude=("tests", "tests.*")),
Jun Ru Anderson's avatar
Jun Ru Anderson committed
65
66
        ext_modules=extensions,
        cmdclass=cmdclass,
Min Xu's avatar
Min Xu committed
67
68
        python_requires=">=3.8",
        author="Foundational AI Research @ Meta AI",
Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
69
        author_email="todo@fb.com",
70
71
        long_description="FairScale is a PyTorch extension library for high performance and large scale training on one or multiple machines/nodes. This library extends basic PyTorch capabilities while adding new experimental ones.",
        long_description_content_type="text/markdown",
72
        entry_points={"console_scripts": ["wgit = experimental.wgit.__main__:main"]},
Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
73
74
        classifiers=[
            "Programming Language :: Python :: 3.8",
75
            "Programming Language :: Python :: 3.9",
Min Xu's avatar
Min Xu committed
76
            "Programming Language :: Python :: 3.10",
Mandeep Singh Baines's avatar
Mandeep Singh Baines committed
77
78
79
80
81
            "License :: OSI Approved :: BSD License",
            "Topic :: Scientific/Engineering :: Artificial Intelligence",
            "Operating System :: OS Independent",
        ],
    )