-
Notifications
You must be signed in to change notification settings - Fork 75
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
Add masked subset support #2462
Add masked subset support #2462
Conversation
0856fcb
to
e5b3cfa
Compare
Codecov ReportPatch coverage is
📢 Thoughts on this report? Let us know!. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just a few small comments/suggestions, but this seems to work quite well and is a surprisingly-light weight solution, thanks!!
@@ -972,6 +972,8 @@ def get_subsets(self, subset_name=None, spectral_only=False, | |||
subset_region = self._get_range_subset_bounds(subset.subset_state, | |||
simplify_spectral, | |||
use_display_units) | |||
elif isinstance(subset.subset_state, MultiMaskSubsetState): | |||
subset_region = self._get_multi_mask_subset_definition(subset.subset_state) | |||
else: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What else might still fall under this else? Can it return any reasonable default in that case or raise an error instead? I just worry about future cases where nothing getting returned could result in unintentionally missing something.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you have a preference between reasonable default and raise error? I lean towards default but I can see the merits of either one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think default is probably fine for this case, even if it doesn't contain any information besides the class name or something, that is still more instructive than a missing entry.
Looks pretty good, one question from testing: after freezing my composite subset to a mask, when I use
Is there any case where this list would have multiple entries? It seems like there isn't, in which case it would be better to return just the dictionary without the list wrapper around it. |
@@ -1068,6 +1071,12 @@ def _get_range_subset_bounds(self, subset_state, | |||
"subset_state": subset_state}] | |||
return spec_region | |||
|
|||
def _get_multi_mask_subset_definition(self, subset_state): | |||
return [{"name": subset_state.__class__.__name__, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, you're explicitly wrapping the dict in a list here. What was the reason for this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The reason for this is that MultiMask could be one region of many in a composite subset. To return all that information, we use a list of dictionaries which contain information on those subregions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ahh, I missed (or forgot) that get_subsets()
always returns a list of dictionaries now, even the subset is a single region. As long as it's consistent, carry on nothing to see here 😄
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How is this kind of subset supposed to work when "reparenting" becomes a thing? Or when Brett's rotation work gets merged?
Or is this never going to be enabled for Imviz?
@pllim Good question, this use case is more for LCViz so it will not be enabled for Imviz, at least not this iteration. |
I did test this in Imviz and it worked, but I haven't thought through any implications/interactions due to the things @pllim brought up. I think adding this to the conversion through WCS links for reparenting should be easy, not sure about rotation. I think I'm comfortable merging given my current ongoing work. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM - feel free to add the change log and merge whenever ready!
fix event handling for choosing config from launcher filepath fallback when object from config-detection fails to load fix: support for notebook 7 (spacetelescope#2420) Notebook 7 requires a different way to detect if the app runs in a notebook context. Fix explanation in markdown cell. DOC: Footprints plugin API docs (spacetelescope#2426) * build footprints API docs * add code snippet in plugin docs * fix syntax in API docs --------- Co-authored-by: P. L. Lim <[email protected]> prevent overwriting user-API methods (spacetelescope#2425) fix default color for overlay when traitlet set by user * for the FIRST overlay, the user could have set the color traitlet before the internal overlay object is created (which occurs as soon as the plugin is first shown). In that case, we want to respect the user choice of color. similar fixes for any other traitlet when plugin inactive regression test change log entry fix API import of single region and overwriting existing entry * along with regression testing TST: Also pull in scikit-image dev to get rid of incompatibility with numpy Use new "true circle" tool from glue-jupyter (spacetelescope#2332) * Use truecircle tool from glue-viz/glue-jupyter#376 * MNT: Bump glue-jupyter minversion that can use this new tool * Add change log * Fix line too long * Fix change log verbiage Co-authored-by: Kyle Conroy <[email protected]> --------- Co-authored-by: Kyle Conroy <[email protected]> Enable multiselect in subset plugin for recentering (spacetelescope#2430) * Enable multiselect in subset plugin for recentering * Fix bug with default text * Remove unused import * Fix bug in aperature photometry * Address review comments * Remove commented out code * Add initial tests * Fix bug when exiting multiselect and switching subsets * Add documentation and update CHANGES file * Remove print statement * Add comment about recentering taking multiple iterations to docs * fix chip styling in subset dropdown * only set selected_has_subregions if exists * only show multiselect toggle in imviz * Apply suggestions from code review Co-authored-by: P. L. Lim <[email protected]> --------- Co-authored-by: Kyle Conroy <[email protected]> Co-authored-by: P. L. Lim <[email protected]> Debug standalone build (spacetelescope#2441) * Log jdaviz output for debugging * Run workflow on debugging branch * See if collecting data from jupyter-client will fix this, otherwise might need to downgrade * Remove debugging stuff MNT: Bump actions/checkout to v4 Enable workflow_dispatch for standalone because it cannot be enabled outside of main apparently [ci skip] [rtd skip] EXP: Update workflow versions Fix Mosviz slit overlay (spacetelescope#2434) * Fix Mosviz slit overlay by using polygon instead of forcing a rectangle without angle info. Co-authored-by: Camilla Pacifici <[email protected]> * Off by one error in predicted PR num --------- Co-authored-by: Camilla Pacifici <[email protected]> API access (hidden) to disable cubeviz movie UI (spacetelescope#2440) * (hidden) API access to disable cubeviz movie UI * default movie_enabled based on new app-setting server_is_remote * test coverage TST: Ignore ASDF warning about gwcs-1.0.0 schema because gwcs dev and/or asdf-wcs-schemas 0.2.0 triggers the warning because the schema is no longer supported.
93698c5
to
578c22d
Compare
Co-authored-by: Kyle Conroy <[email protected]>
* Integrate MultiMaskSubsetState into get_subsets and subset_plugin --------- Co-authored-by: Kyle Conroy <[email protected]>
Description
This pull request is a continuation of #2421, which enables freezing of subsets. This converts them to a
MultiMaskSubsetState
which in this PR can be returned throughapp.get_subsets()
and is visible in the Subset Plugin. Ifsimplify_subset
is set to True and there areMultiMaskSubsetState
objects in the Composite subset, they will be ignored so that the Range objects can be combined into a SpectralRegion object.To get the Freeze button to appear:
Change log entry
CHANGES.rst
? If you want to avoid merge conflicts,list the proposed change log here for review and add to
CHANGES.rst
before merge. If no, maintainershould add a
no-changelog-entry-needed
label.Checklist for package maintainer(s)
This checklist is meant to remind the package maintainer(s) who will review this pull request of some common things to look for. This list is not exhaustive.
trivial
label.