-
Notifications
You must be signed in to change notification settings - Fork 14
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
Masked array for large detectors #146
Comments
Thanks, I think that's a reasonable request. In the meantime, I think it should be possible to load the mask data and apply it something like this: img_data = agipd.get_dask_array('image.data')
mask_data = agipd.get_dask_array('image.mask')
mask = mask_data & 391 # 391 = bits 0, 1, 2, 7, 8 set
img_data = da.where(mask, np.nan, img_data) I haven't tried this, though. If you do try it, let me know how it goes, because the implementation in EXtra-data would probably look similar to that. |
Thanks. I can confirm that this works for example:
This obviously only takes into account the first three bits only. Plus, an additional mask is applied as well, which for example masks shadowed regions on the detector. Idk if this can be added as well or goes too far. |
Any decisions/progress no this one? |
I think that applying the mask data from the file while loading the data is a feature we can add, but I'm afraid I haven't made a start on incorporating it yet. Do you know if the example you shared before performs well? I'm trying to work out what Dask does with in-place modification ( I'm inclined to leave out applying an external mask, because it should be simple to do that outside EXtra-data after getting the data, and that avoids having to specify precisely what format(s) of masks it accepts (how many dimensions, 0 good or 0 bad, etc.). But that's open for discussion if there's some use case I'm overlooking. |
I looked into the dask.array code, and it appears that |
I didn't run in any obvious performance issues with the example code. But to be honest, I also didn't investigated it thoroughly. I think that da.where is a bit easier if there is a dimension missing. Leaving out the "mask from file" is also OK, this would be more an extra good to have. More important would be to have an easy way to select certain mask bits that should be masked in the array. |
Hey, |
This is on my todo-list, but I haven't quite found the time for it yet :\ |
This came up again as #308. We're keeping this issue, but wanted to record from there:
I'd imagine this would look like an agipd.get_array('image.data', mask_out=(
BadPixels.OFFSET_OUT_OF_THRESHOLD | BadPixels.VALUE_IS_NAN
)) And probably a shortcut like |
The calibration pipeline provides masks, where different criteria for masking a pixle/storage cell are encoded like this:
Could the get_dask_array function (for example for AGIPD) be extended, so that it returns the image data with bad pixels already masked ( = np.nan)? For example with an extra parameter mask_bit = [0,1,2,7,8], as normally not for all experiments we need to apply all mask criteria.
The text was updated successfully, but these errors were encountered: