-
-
Notifications
You must be signed in to change notification settings - Fork 29
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
Package pillow-simd? #103
Comments
Is pillow-simd at PyPI? I could not find it. (Not important here, just curious.) I think that the approach here should be a different feedstock with a |
Different feedstock sounds like a good idea. Both of them could have a metapackage that provides, e.g. |
Would we need repopatches for the old pillow releases? Or just add a version constraint? 9.0.0 was recently released, so that'd be a decent opportunity. Do I understand you correctly that this would roughly be the structure?
|
Sidenote: pillow apparently has an 18 month cadence between major releases. The source code already contains the release date for Pillow 10. |
there's no need for a new meta package. |
OK cool; though that still means at least a modification of the build string, correct? |
Actually, on second thought, I'm not sure it's a great idea to use |
No. |
Pillow releases quarterly (Jan, Apr, Jul, Oct), and we're doing major releases to coincide with dropping Python versions. So the next major will coincide with dropping 3.7 in July 2023, and after that Python's annual release cadence will have filtered through to EOLs: 3.8 in October 2024, 3.9 in October 2025, 3.10 in October 2026... |
Is there is any functionality in torchvision that depends on pillow-simd? If not, I would be worried about pinning pillow-simd at the torchvision package level. |
OK, got it. I'll try to open a PR for a new feedstock
No, it just prefers pillow-simd if it's available (presumably for speed). Thanks for the context about the release cadence @hugovk! |
Well, I've just did look into this, and to be honest, I'm not sure we should be doing this. While pillow-simd seems to have some activity, it isn't up-to-date with pillow. Right now, pillow's at 11.0.0, and pillow-simd is at 9.5.0. There seems to be a v10.0.1.post0 tag from August, but this doesn't seem to have been followed through. On top of that, pillow-simd is vulnerable. I've just confirmed that at least CVE-2023-44271 applies, so I don't think they're backporting security fixes to their releases. There's a bug report asking for a 10.1.0 and pointing out even earlier vulnerabilities that doesn't seem to have seen any reply from the maintainers. |
Not sure how easy it would be to apply and rebase the patches from pillow-simd, but my plan would have been to just build both in one archspec-enabled feedstock, where we create a variant with the patches. If the patches aren't trivial, then I guess that idea is dead though. |
Well, it definitely isn't going to be trivial. From a dumb "merged patch" rebase attempt:
So looks like pretty much all C files changed since. What's really unfortunately is that "pillow-simd" seems to be treated as a full fork rather than a patchset — upstream doesn't seem to try to minimize changes and make rebasing easy. |
There also seems to be an upstreaming effort in progress: python-pillow/Pillow#8209 |
Hey @conda-forge/pillow
I'm co-maintaining the torchvision feedstock, and recently noticed that they are actually depending** on
pillow-simd
, a SIMD-optimized fork of pillow. Here is a performance comparison that - AFAICT - is even hosted on the main pillow website, where SSE4 already achieves substantial speedups, and AVX2 even more so, on the order of a factor of 5x.Given that the sources are very very similar, I'd be wary of having this in a separate feedstock (requiring a mutex etc.), and also pillow-simd formulates their policy:
The downside of building both outputs in this feedstock would be that new pillow releases would have to also wait on the corresponding pillow-simd release.
Any thoughts?
CC @conda-forge/torchvision @conda-forge/core
** conditional on availability, with fallback to pillow
The text was updated successfully, but these errors were encountered: