# Copyright (c) 2022-2024, NVIDIA CORPORATION & AFFILIATES. All rights reserved. # # See LICENSE for license information. """Installation script for TE pytorch extensions.""" # pylint: disable=wrong-import-position,wrong-import-order import sys import os import shutil from pathlib import Path import setuptools from torch.utils.cpp_extension import BuildExtension try: import torch # pylint: disable=unused-import except ImportError as e: raise RuntimeError("This package needs Torch to build.") from e current_file_path = Path(__file__).parent.resolve() build_tools_dir = current_file_path.parent.parent / "build_tools" if bool(int(os.getenv("NVTE_RELEASE_BUILD", "0"))) or os.path.isdir(build_tools_dir): build_tools_copy = current_file_path / "build_tools" if build_tools_copy.exists(): shutil.rmtree(build_tools_copy) shutil.copytree(build_tools_dir, build_tools_copy) from build_tools.build_ext import get_build_ext from build_tools.utils import package_files, copy_common_headers from build_tools.te_version import te_version from build_tools.pytorch import setup_pytorch_extension CMakeBuildExtension = get_build_ext(BuildExtension) if __name__ == "__main__": # Extensions common_headers_dir = "common_headers" copy_common_headers(current_file_path.parent, str(current_file_path / common_headers_dir)) ext_modules = [ setup_pytorch_extension( "csrc", current_file_path / "csrc", current_file_path / common_headers_dir ) ] # Configure package setuptools.setup( name="transformer_engine_torch", version=te_version(), packages=["csrc", common_headers_dir, "build_tools"], description="Transformer acceleration library - Torch Lib", ext_modules=ext_modules, cmdclass={"build_ext": CMakeBuildExtension}, install_requires=["torch", "flash-attn>=2.0.6,<=2.4.2,!=2.0.9,!=2.1.0"], tests_require=["numpy", "onnxruntime", "torchvision"], include_package_data=True, package_data={ "csrc": package_files("csrc"), common_headers_dir: package_files(common_headers_dir), "build_tools": package_files("build_tools"), }, ) if any(x in sys.argv for x in (".", "sdist", "bdist_wheel")): shutil.rmtree(common_headers_dir)