forked from cleanlab/cleanlab
-
Notifications
You must be signed in to change notification settings - Fork 1
/
setup.py
115 lines (101 loc) · 4.31 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
108
109
110
111
112
113
114
115
from setuptools import setup, find_packages
from setuptools.command.egg_info import egg_info
# To use a consistent encoding
from codecs import open
from os import path
class egg_info_ex(egg_info):
"""Includes license file into `.egg-info` folder."""
def run(self):
# don't duplicate license into `.egg-info` when building a distribution
if not self.distribution.have_run.get("install", True):
# `install` command is in progress, copy license
self.mkpath(self.egg_info)
self.copy_file("LICENSE", self.egg_info)
egg_info.run(self)
here = path.abspath(path.dirname(__file__))
# Get the long description from the README file
with open(path.join(here, "README.md"), encoding="utf-8") as f:
long_description = f.read()
# Get version number and store it in __version__
exec(open("cleanlab/version.py").read())
setup(
name="cleanlab",
version=__version__,
license="AGPLv3+",
long_description=long_description,
long_description_content_type="text/markdown",
description="The standard package for data-centric AI, machine learning with label errors, "
"and automatically finding and fixing dataset issues in Python.",
url="https://cleanlab.ai",
project_urls={
"Documentation": "https://docs.cleanlab.ai",
"Bug Tracker": "https://github.com/cleanlab/cleanlab/issues",
"Source Code": "https://github.com/cleanlab/cleanlab",
},
author="Cleanlab Inc.",
author_email="[email protected]",
# See https://pypi.python.org/pypi?%3Aaction=list_classifiers
classifiers=[
"Development Status :: 4 - Beta",
"Intended Audience :: Developers",
"Intended Audience :: Education",
"Intended Audience :: Science/Research",
"Intended Audience :: Information Technology",
"License :: OSI Approved :: GNU Affero General Public License v3 or later (AGPLv3+)",
"Natural Language :: English",
# We believe this package works will these versions, but we do not guarantee it!
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3.6",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python",
"Topic :: Software Development",
"Topic :: Scientific/Engineering",
"Topic :: Scientific/Engineering",
"Topic :: Scientific/Engineering :: Mathematics",
"Topic :: Scientific/Engineering :: Artificial Intelligence",
"Topic :: Software Development",
"Topic :: Software Development :: Libraries",
"Topic :: Software Development :: Libraries :: Python Modules",
],
python_requires=">=3.6",
# What does your project relate to?
keywords="machine_learning data_cleaning confident_learning classification weak_supervision "
"learning_with_noisy_labels unsupervised_learning datacentric_ai, datacentric",
# You can just specify the packages manually here if your project is
# simple. Or you can use find_packages().
packages=find_packages(exclude=[]),
# Include cleanlab license file.
include_package_data=True,
package_data={
"": ["LICENSE"],
},
license_files=("LICENSE",),
cmdclass={"egg_info": egg_info_ex},
# List run-time dependencies here. These will be installed by pip when
# your project is installed. For an analysis of "install_requires" vs pip's
# requirements files see:
# https://packaging.python.org/en/latest/requirements.html
install_requires=[
"numpy>=1.11.3",
"scikit-learn>=0.18",
"tqdm>=4.53.0",
"pandas>=1.0.0",
],
)
"""
Curtis G. Northcutt notes on how to perform pypi upload:
1. python setup.py check -m -s
2. rm -rf dist build
3. python setup.py sdist bdist_wheel
4. twine check dist/*
5. python3 -m twine upload dist/*
For conda upload (after pypi upload)
# if this fails, try conda update --force conda; conda update conda
1. cd ~; conda skeleton pypi cleanlab --noarch-python --python-version 3.6
2. conda-build cleanlab
3. anaconda upload --user cleanlab LOCATION/cleanlab-x.x.x_0.tar.bz2 # location printed by previous command
4. cd ~; rm -r cleanlab # clean-up meta data created by anaconda for upload
"""