-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathsetup.py
107 lines (100 loc) · 3.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
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
102
103
104
105
106
107
from distutils import util
from setuptools import find_namespace_packages, setup
import pathlib
HYDRA_VERSION = "1.3.2"
test_deps = [
"pytest",
]
core_deps = [
"Pillow>=9.3.0",
"PyYAML>=6.0.0",
"h5py>=3.11.0",
"mpi4py>=3.1.4",
"numpy>=1.23.5",
"omegaconf>=2.2.0",
"pandas>=1.5.1",
"psutil>=5.9.8",
"pydftracer==1.0.2",
]
x86_deps = [
f"hydra-core>={HYDRA_VERSION}",
"nvidia-dali-cuda110>=1.34.0",
"tensorflow>=2.11.0",
"torch>=2.2.0",
"torchaudio",
"torchvision",
]
ppc_deps = [
f"hydra-core @ git+https://github.com/facebookresearch/hydra.git@v{HYDRA_VERSION}#egg=hydra-core"
]
deps = core_deps
if "ppc" in util.get_platform():
deps.extend(ppc_deps)
else:
deps.extend(x86_deps)
extras = {
"test": test_deps,
}
here = pathlib.Path(__file__).parent.resolve()
long_description = (here / "README.md").read_text(encoding="utf-8")
setup(
name="dlio_benchmark",
version="2.0.0",
description="An I/O benchmark for deep learning applications",
long_description=long_description,
long_description_content_type="text/markdown",
url="https://github.com/argonne-lcf/dlio_benchmark",
author="Huihuo Zheng, Hariharan Devarajan (Hari)",
author_email="[email protected], [email protected]",
classifiers=[ # Optional
# How mature is this project? Common values are
# 3 - Alpha
# 4 - Beta
# 5 - Production/Stable
"Development Status :: 5 - Production/Stable",
# Indicate who your project is intended for
"Intended Audience :: Science/Research",
"Topic :: Software Development :: Build Tools",
# Pick your license as you wish
"License :: OSI Approved :: Apache Software License",
# Specify the Python versions you support here. In particular, ensure
# that you indicate you support Python 3. These classifiers are *not*
# checked by 'pip install'. See instead 'python_requires' below.
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python :: 3.12",
"Programming Language :: Python :: 3 :: Only",
],
keywords="deep learning, I/O, benchmark, NPZ, pytorch benchmark, tensorflow benchmark",
project_urls={ # Optional
"Documentation": "https://dlio-benchmark.readthedocs.io",
"Source": "https://github.com/argonne-lcf/dlio_benchmark",
"Release Notes": "https://github.com/argonne-lcf/dlio_benchmark/releases",
"Bug Reports": "https://github.com/argonne-lcf/dlio_benchmark/issues",
},
# Main package definition
packages=find_namespace_packages(where="."),
package_dir={"dlio_benchmark": "dlio_benchmark"},
package_data={
"dlio_benchmark.configs": ["*.yaml"],
"dlio_benchmark.configs.hydra.help": ["*.yaml"],
"dlio_benchmark.configs.hydra.job_logging": ["*.yaml"],
"dlio_benchmark.configs.workload": ["*.yaml"],
},
dependency_links=[
"https://download.pytorch.org/whl/cpu",
"https://developer.download.nvidia.com/compute/redist",
],
install_requires=deps,
tests_require=test_deps,
extras_require=extras,
entry_points={
"console_scripts": [
"dlio_benchmark = dlio_benchmark.main:main",
"dlio_postprocessor = dlio_benchmark.postprocessor:main",
]
},
)