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

GridPatch transform support for max num_patches while filtering #6049

Closed
kenza-bouzid opened this issue Feb 22, 2023 · 5 comments · Fixed by #6055
Closed

GridPatch transform support for max num_patches while filtering #6049

kenza-bouzid opened this issue Feb 22, 2023 · 5 comments · Fixed by #6055

Comments

@kenza-bouzid
Copy link

kenza-bouzid commented Feb 22, 2023

Is your feature request related to a problem? Please describe.

GridPatch is very useful to tile on the fly for a fixed number of patches. One usually uses an estimate of the average of number of tiles per slide. For slide with fewer tissue patches than the requested num_patches, we might end up with some background tiles, which might be desirable in some cases to ensure an even number of tiles. For other cases, where we try to limit any background tiles, we would like to have a way of filtering out background tiles for a fixed number of patches (this might result in fewer tiles than the requested num_patches).

Describe the solution you'd like
In monai.tranforms.spatial.array.GridPatch, filtering is done as follow in lines 3279-3283

#Filter patches
        if self.num_patches:
            patched_image, locations = self.filter_count(patched_image, locations)
        elif self.threshold:
            patched_image, locations = self.filter_threshold(patched_image, locations)

It would be great to add a flag for filtering background when num_patches > 0, maybe filter_bkgd_for_fixed_num_patches set to False by default

#Filter patches
        if self.num_patches:
            patched_image, locations = self.filter_count(patched_image, locations)
        elif self.threshold or self.filter_bkgd_for_fixed_num_patches:
            assert self.threshold, "threshold must be set when filter_bkgd_for_fixed_num_patches is True"
            patched_image, locations = self.filter_threshold(patched_image, locations)

Describe alternatives you've considered
One alternative would be to change elif by if, but it might not be desirable for all use cases.

Additional context
Add any other context or screenshots about the feature request here.

@kenza-bouzid kenza-bouzid changed the title GridPatch tranform does'nt filter background tiles if num_patches is set: GridPatch tranform doesn't filter background tiles if num_patches is set: Feb 22, 2023
@kenza-bouzid kenza-bouzid changed the title GridPatch tranform doesn't filter background tiles if num_patches is set: GridPatch tranform doesn't filter background tiles if num_patches is set Feb 22, 2023
@kenza-bouzid kenza-bouzid changed the title GridPatch tranform doesn't filter background tiles if num_patches is set GridPatch transform doesn't filter background tiles if num_patches is set Feb 22, 2023
@drbeh
Copy link
Member

drbeh commented Feb 23, 2023

Hi @kenza-bouzid,
Thank you very much for reporting this. you are right, it either gives specific number of patches or filter patches, and this is by design. I see your point about having max_num_patches while filtering the background. I will set it as a feature request and will evaluate it if we can prioritize its implementation. Will keep you posted.

@drbeh drbeh changed the title GridPatch transform doesn't filter background tiles if num_patches is set GridPatch transform support for max num_patches while filtering Feb 23, 2023
@drbeh drbeh self-assigned this Feb 23, 2023
@kenza-bouzid
Copy link
Author

kenza-bouzid commented Feb 23, 2023

Thanks @drbeh!
Actually if you only change the elif by an if, it should work! If the user doesn't want filtering then threshold shouldn't be set? Maybe precise this in the docs?

@drbeh
Copy link
Member

drbeh commented Feb 23, 2023

@kenza-bouzid you are right but then it will be padded with zero tensors to have the same number of patches, which I don't think is desirable for use case. Right?

padding = self.num_patches - len(patched_image)

@drbeh drbeh moved this to 🌱 Todo in AI in Pathology🔬 Feb 23, 2023
@drbeh drbeh added this to the Pathology Misc Improvements milestone Feb 23, 2023
@drbeh drbeh moved this from 🌱 Todo to 🌋 In Progress in AI in Pathology🔬 Feb 23, 2023
@drbeh drbeh moved this from 🌋 In Progress to 🧐 Under Review in AI in Pathology🔬 Feb 23, 2023
@kenza-bouzid
Copy link
Author

kenza-bouzid commented Feb 23, 2023

@drbeh good point, then maybe only pad if self.num_patches and not self.threshold ? I see you are already working on that in #6055, thank you very much!

@drbeh
Copy link
Member

drbeh commented Feb 23, 2023

Yes, it is done! Feel free to review it. Thanks

@wyli wyli closed this as completed in #6055 Mar 1, 2023
wyli pushed a commit that referenced this issue Mar 1, 2023
Fixes #6049 

### Description
This PR add support to `GridPatch` for both filtering by count and
threshold. When filtering by threshold, the `num_patches` will be
treated as maximum number of patches.

UPDATE: It also removes the deprecated argument of
`skimage.measure.regionprops`, 'coordinates', which was causing some
test to fail.

### Types of changes
<!--- Put an `x` in all the boxes that apply, and remove the not
applicable items -->
- [x] Non-breaking change (fix or new feature that would not break
existing functionality).
- [x] New tests added to cover the changes.
- [x] Integration tests passed locally by running `./runtests.sh -f -u
--net --coverage`.
- [x] Quick tests passed locally by running `./runtests.sh --quick
--unittests --disttests`.
- [x] In-line docstrings updated.

---------

Signed-off-by: Behrooz <3968947+drbeh@users.noreply.github.com>
@github-project-automation github-project-automation bot moved this from 🧐 Under Review to 💯 Complete in AI in Pathology🔬 Mar 1, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: 💯 Complete
Development

Successfully merging a pull request may close this issue.

2 participants