-
Notifications
You must be signed in to change notification settings - Fork 32
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
Dask 2024.8.1 and later is very slow #1267
Comments
I've opened dask/dask#11416 |
Unfortunately, it looks like Dask 2024.10.0 doesn't fix this, see https://github.com/sgkit-dev/sgkit/actions/runs/11551276595 which is taking 19 minutes to run, rather than 6 (with Dask 2024.08.0). |
On further investigation what's happening is that locally defined functions that are passed to Dask Lines 598 to 600 in 9dd940e
The lambda function calls a Numba function that is recompiled each time. In most cases it's fairly easy to rewrite the code to avoid the use of locally defined functions. For PBS we can just do: - p = da.map_blocks(
- lambda t: _pbs_cohorts(t, ct), t, chunks=shape, new_axis=3, dtype=np.float64
- )
+ p = da.map_blocks(_pbs_cohorts, t, ct, chunks=shape, new_axis=3, dtype=np.float64) The distance metrics code is more dynamic though, so it's not a simple fix: Lines 111 to 143 in 9dd940e
|
I've fixed the non-distance functions in this commit: e83b52c I'm not sure what to do about the distance functions at this point. |
There's only two possible metrics right now ('euclidean' or 'correlation') so I vote we make the code less clever and just code in the function names directly for those two cases? |
That's what I thought too - but there is another wrinkle. In this diff previously I suppose we could have a map of (shared) empty arrays keyed by dtype - but that doesn't seem very thread safe. Or we could initialize in the function, and leave a comment about how this previously caused Dask slowdown. Another option would be to remove the code! |
Ah, I see. I'm reluctant to remove the code as we put quite a lot of effort in and it's our main usage of GPUs... Perhaps @aktech would like to comment here? Is there an easy way to avoid using lambdas? |
Apologies for late reply, I'll take a look at this soon. I think It might be possible. |
This was originally reported in #1247 and a temporary pin introduced in #1248. I've opened this to track the issue so we can remove the pin.
The text was updated successfully, but these errors were encountered: