Skip to content
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

[bug from Hell] Serious issue with: concatenated cubes with masks and dask=2024.8.0 #6109

Open
valeriupredoi opened this issue Aug 8, 2024 · 11 comments

Comments

@valeriupredoi
Copy link

Hi folks,

  • MRE/MRC code:
import iris
import numpy as np


c1 = iris.load_cube("cubb-1.nc")
c2 = iris.load_cube("cubb-2.nc")

# apply slice to concatenated cube
slicer = (
    np.random.choice(a=[False, True], size=(730,)),
    slice(None, None, None),
    slice(None, None, None),
    slice(None, None, None)
)

# can use this to slice each of cubes c1 and/or c2
slicer1 = (
    np.random.choice(a=[False, True], size=(365,)),
    slice(None, None, None),
    slice(None, None, None),
    slice(None, None, None)
)

cube = iris.cube.CubeList([c1, c2]).concatenate_cube()
cubes = cube[slicer]
print("After slicing", cubes.data)
  • environment:
iris                      3.9.0              pyha770c72_0    conda-forge
numpy                     1.26.4          py312heda63a1_0    conda-forge

dask                      2024.8.0           pyhd8ed1ab_0    conda-forge
dask-core                 2024.8.0           pyhd8ed1ab_0    conda-forge

or

dask                      2024.7.1           pyhd8ed1ab_0    conda-forge
dask-core                 2024.7.1           pyhd8ed1ab_0    conda-forge
  • problem: use the MRE code to reproduce this:
    • you have two cubes, one or both with masked data
    • concatenate them
    • apply a (time-like) slice
    • resulting cube will randomly (depending on slice) have fill values explicitly used as numerical data values (ie not as masked elements) when using dask==2024.8.0, so one gets cray values of 1.e+36 etc
    • this behaviour never happens with previous dask==2024.7.1
    • example above uses fairly hefty cubes (attached here for testing, just change the extension), but am sure this can be scaled-down to smaller cubes, with the same behaviour

Good luck fixing this folks, it took me two days to isolate it from ESMValCore, am sure it's not a very straightforward fix 😁 But it's an ugly bug that can bite badly!
cubb-1.nc.txt
cubb-2.nc.txt

@trexfeathers
Copy link
Contributor

trexfeathers commented Aug 9, 2024

Status: Decision Required

Historically when we have raised mask-related issues with Dask, they have asked us to propose the fix. Historically we have found that you need to be highly experienced in Dask before you can work on it. None of us are highly experienced in Dask.

Options:

  • Record this operation as impossible in our documentation.
  • Remove some proposed features from Iris 3.11 so that one/two of us have time to work on fixing this (perhaps involving a Dask PR?)
  • Recognise that neither Dask nor NumPy really care about masks and come up with alternative way of providing this functionality that we have control over. E.g. flatten array, filter out 'masked' points, perform whatever operation, ravel array back to the correct shape?

@valeriupredoi
Copy link
Author

@trexfeathers very many thanks for looking into this! 🍺

I know you guys' masked pain - masked arrays are a lot more important than what Numpy/Dask folk consider them to be 😁
Let me know if I can help with testing the fix etc

@rcomer
Copy link
Member

rcomer commented Aug 10, 2024

I believe I have narrowed this down: dask/dask#11296

@valeriupredoi
Copy link
Author

@rcomer that's the one indeed, excellent detective work!

@rcomer
Copy link
Member

rcomer commented Aug 12, 2024

@valeriupredoi there is now a fix on dask main branch. Are you able to test your case(s) with that?

@valeriupredoi
Copy link
Author

@rcomer let me try test with that, cheers 🍺

@valeriupredoi
Copy link
Author

@rcomer dask 2024.8.0+13.g67b2852 installed from source does the trick perfectly - excellent work on this 🍺

@trexfeathers
Copy link
Contributor

From @scitools/peloton: cross-chunk slicing has come up before. Before this can be closed we should write a test to catch cases like this.

@pp-mo
Copy link
Member

pp-mo commented Aug 28, 2024

From @SciTools/peloton we can maybe add a negative pin for the problem.
This would go in 3.11

@valeriupredoi
Copy link
Author

From @SciTools/peloton we can maybe add a negative pin for the problem. This would go in 3.11

a very positive take on it 😁 (sorry, I was on holidays until a few days ago)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: No status
Development

No branches or pull requests

5 participants