forked from huggingface/optimum-nvidia
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
101 lines (94 loc) · 3.25 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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# coding=utf-8
# Copyright 2023 The HuggingFace Inc. team. All rights reserved.
# #
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# #
# http://www.apache.org/licenses/LICENSE-2.0
# #
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import re
from distutils.core import setup
from platform import system, machine, python_version
from setuptools import find_namespace_packages
from sys import version_info as pyversion
# Ensure we match the version set in optimum/nvidia/version.py
filepath = "src/optimum/nvidia/version.py"
try:
with open(filepath) as version_file:
(__version__,) = re.findall('__version__ = "(.*)"', version_file.read())
except Exception as error:
assert False, "Error: Could not open '%s' due %s\n" % (filepath, error)
INSTALL_REQUIRES = [
"accelerate == 0.25",
"datasets >= 2.14",
"huggingface-hub >= 0.22.0",
"hf-transfer",
"mpmath == 1.3.0",
"numpy >= 1.26.0",
"onnx >= 1.12.0",
"optimum >= 1.13.0",
"setuptools",
"tensorrt-llm == 0.10.0",
"torch>=2.2.0a,<=2.3.1",
"transformers >= 4.38.2",
"pynvml"
]
TESTS_REQUIRES = [
"mock",
"pytest",
"pytest-xdist",
"psutil",
"parameterized",
"datasets",
"safetensors",
"soundfile",
"librosa",
]
QUALITY_REQUIRES = [
"black",
"ruff",
"isort",
"hf_doc_builder @ git+https://github.com/huggingface/doc-builder.git",
]
EXTRAS_REQUIRE = {
"tests": TESTS_REQUIRES,
# "quality": QUALITY_REQUIRES,
}
setup(
name="optimum-nvidia",
version=__version__,
description=(
"Optimum Nvidia is the interface between the Hugging Face Transformers and NVIDIA GPUs. "
"It provides a set of tools enabling easy model loading, training and "
"inference on single and multiple GPU cards for different downstream tasks."
),
long_description=open("README.md", "r", encoding="utf-8").read(),
long_description_content_type="text/markdown",
classifiers=[
"Development Status :: 2 - Pre-Alpha",
"License :: OSI Approved :: Apache Software License",
"Intended Audience :: Developers",
"Intended Audience :: Education",
"Intended Audience :: Science/Research",
"Operating System :: OS Independent",
"Programming Language :: Python :: 3.10",
"Topic :: Scientific/Engineering :: Artificial Intelligence",
],
keywords="transformers, neural-network, fine-tuning, inference, nvidia, tensorrt, ampere, hopper",
url="https://huggingface.co/hardware/nvidia",
author="HuggingFace Inc. Machine Learning Optimization Team",
author_email="[email protected]",
license="Apache 2.0",
packages=find_namespace_packages(include=["optimum*"]),
install_requires=INSTALL_REQUIRES,
extras_require=EXTRAS_REQUIRE,
dependency_links=["https://pypi.nvidia.com"],
include_package_data=True,
zip_safe=False,
)