-
Notifications
You must be signed in to change notification settings - Fork 2.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Please provide PEP 503 compliant indices for CUDA versions of packages #5410
Comments
Are you able to say more about what's not compliant about it, or what kind of error you're getting? I can believe we messed something up here, but it's a little hard to pinpoint exactly what, especially since the index works with pip. |
We didn't necessarily intend that our repository be PEP 503 compliant, just that To be PEP 503 compliant this I think we'd need to serve our wheels a different way. e.g. "Within a repository, the root URL (/ for this PEP which represents the base URL) MUST be a valid HTML5 page with a single anchor element per project in the repository." is something that cannot be satisfied by a raw GCS bucket. This is certainly possible, just a bit of work to move our web hosting around. |
To be able to use gpu versions with package managers in a reasonable way, I think using a format that is compatible with pypi would be greatly appreciated. Here is an example where a third party provided something that is compatible for pytorch: https://vxlabs.com/pypi/ Having a simple page with this structure that refers to the already existing wheels should be enough, no? I guess being pypi compatible is not necessarily the same as being PEP 503 compliant. |
@hawkinsp do you have any ideas as to where we could (easily) host such a page? I'm gonna mark this contributions welcome for now, since it sounds like anyone can set up such a page and link to the wheels in our GCS bucket. |
You could just host a GitHub pages with the corresponding PEP 503 structure. I just wrote a script to generate a index.html for this purpose: #!/usr/bin/env python3
import re
import requests
import textwrap
TEMPLATE = """<!DOCTYPE html>
<html>
<head>
<meta name="pypi:repository-version" content="1.0">
<title>Links for jaxlib</title>
</head>
<body>
<h1>Links for jaxlib</h1>
{links}
</body>
</html>
"""
TEMPLATE_HREF = '<a href="{url}">{name}</a>'
re_a_href = re.compile('<a[^>]*?href="(?P<url>[^"]*?)"[^>]*?>(?P<name>[^<]*?)</a>')
def main():
r = requests.get("https://storage.googleapis.com/jax-releases/jax_releases.html")
result = []
for m in re_a_href.finditer(r.text):
name = m.group("name").split("/")[-1]
result.append(TEMPLATE_HREF.format(name=name, url=m.group("url")))
links = textwrap.indent("\n".join(result), " ")
index = TEMPLATE.format(links=links)
with open("index.html", "w") as f:
f.write(index)
if __name__ == "__main__":
main() This can be used to update a simple pip index interface, I just tested it here: https://janluca.github.io/pypi/ Would it be possible to just create some jax GitHub page in the organization for this purpose? |
@skye Would it be possible to have such a GitHub page hosted along the jax repository? |
I thought GitHub pages were only per-user/organization, but it looks like you can have per-project pages as well. So yes, this does seem like it should be possible. I can look into this, thanks for providing the example script! |
I have created a daily-rebuilding repository for this, see https://github.com/jorenham/jax_pep503. With Poetry, you can use it like: [tool.poetry.dependencies]
...
jax = {extras = ["cuda"], version = "^0.3.13"}
[[tool.poetry.source]]
name = "jorenham/jax_pep503"
url = "https://jorenham.github.io/jax_pep503/"
secondary = true |
With pypa/pip#10825, the lack of a |
Just a drive by comment on this coming from python-poetry/poetry#5516. We have implmented single page support in python-poetry/poetry#5517. However, for tools like Poetry, since metadata is important when resolving a project's universal dependencies, having package checksums (described in PEP 503) and PEP 658 support enabled would considerably help the dependency resolution and lockfile generation. |
Closing this issue as stale. We have for some time now shipped CUDA wheels of JAX on pypi. So... use the pypi wheels! |
And with that, I have archived https://github.com/jorenham/jax_pep503. |
At https://storage.googleapis.com/jax-releases/jax_releases.html, we can find cuda versions of jaxlib. This index is not PEP 503-compliant, and can therefore not be used in a package manager such as poetry.
Can you please provide an index that respects the requirements of PEP 503?
The text was updated successfully, but these errors were encountered: