forked from thu-ml/tianshou
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
103 lines (93 loc) · 3.21 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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import os
import sys
from setuptools import find_packages, setup
def get_version() -> str:
# https://packaging.python.org/guides/single-sourcing-package-version/
init = open(os.path.join("tianshou", "__init__.py"), "r").read().split()
return init[init.index("__version__") + 2][1:-1]
def get_install_requires() -> str:
return [
"gymnasium>=0.29.0",
"tqdm",
"numpy>1.16.0", # https://github.com/numpy/numpy/issues/12793
"tensorboard>=2.5.0",
"torch>=2.0.1",
"numba>=0.51.0",
"h5py>=3.9.0", # to match tensorflow's minimal requirements
"packaging",
"pettingzoo>=1.22",
"jsonargparse[signatures]>=4.22.1",
]
def get_extras_require() -> str:
req = {
"dev": [
"sphinx",
"sphinx_rtd_theme",
"jinja2",
"sphinxcontrib-bibtex",
"flake8",
"flake8-bugbear",
"yapf",
"isort",
"pytest",
"pytest-cov",
"ray>=1.0.0",
"wandb>=0.12.0",
"networkx",
"mypy",
"pydocstyle",
"doc8",
"scipy",
"pillow",
"pygame>=2.1.0", # pettingzoo test cases pistonball
"pymunk>=6.2.1", # pettingzoo test cases pistonball
"nni>=2.3,<3.0", # expect breaking changes at next major version
"pytorch_lightning",
"gym>=0.22.0",
"shimmy",
],
"atari": ["atari_py", "opencv-python"],
"mujoco": ["mujoco_py"],
"pybullet": ["pybullet"],
}
if sys.platform == "linux":
req["dev"].append("envpool>=0.7.0")
return req
setup(
name="tianshou",
version=get_version(),
description="A Library for Deep Reinforcement Learning",
long_description=open("README.md", encoding="utf8").read(),
long_description_content_type="text/markdown",
url="https://github.com/thu-ml/tianshou",
author="TSAIL",
author_email="trinkle23897@gmail.com",
license="MIT",
python_requires=">=3.8",
classifiers=[
# How mature is this project? Common values are
# 3 - Alpha
# 4 - Beta
# 5 - Production/Stable
"Development Status :: 4 - Beta",
# Indicate who your project is intended for
"Intended Audience :: Science/Research",
"Topic :: Scientific/Engineering :: Artificial Intelligence",
"Topic :: Software Development :: Libraries :: Python Modules",
# Pick your license as you wish (should match "license" above)
"License :: OSI Approved :: MIT License",
# Specify the Python versions you support here. In particular, ensure
# that you indicate whether you support Python 2, Python 3 or both.
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
],
keywords="reinforcement learning platform pytorch",
packages=find_packages(
exclude=["test", "test.*", "examples", "examples.*", "docs", "docs.*"]
),
install_requires=get_install_requires(),
extras_require=get_extras_require(),
)