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

FEAT: Annulus draw tool for Imviz #2240

Merged
merged 8 commits into from
Jun 29, 2023

Conversation

pllim
Copy link
Contributor

@pllim pllim commented Jun 6, 2023

Description

This pull request is to build on glue-viz/glue-jupyter#356 and glue-viz/glue-astronomy#93 to add an annulus draw tool in Imviz. All the features available for other shapes should also be applicable here (e.g., recentering, editing, drag to move).

Light mode Dark mode
Screenshot 2023-06-21 131737 Screenshot 2023-06-21 130843

Ignore the icon below (see new icons above):

Screenshot 2023-06-06 135858

>>> imviz.get_interactive_regions()
{'Subset 1': <CircleAnnulusPixelRegion(
    center=PixCoord(x=1132.8839679560447, y=1882.707397411802),
    inner_radius=75.0, outer_radius=97.3707275390625)>}

TODO

Change log entry

  • Is a change log needed? If yes, is it added to 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, maintainer
    should 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.

  • Are two approvals required? Branch protection rule does not check for the second approval. If a second approval is not necessary, please apply the trivial label.
  • Do the proposed changes actually accomplish desired goals? Also manually run the affected example notebooks, if necessary.
  • Do the proposed changes follow the STScI Style Guides?
  • Are tests added/updated as required? If so, do they follow the STScI Style Guides?
  • Are docs added/updated as required? If so, do they follow the STScI Style Guides?
  • Did the CI pass? If not, are the failures related?
  • Is a milestone set? Set this to bugfix milestone if this is a bug fix and needs to be released ASAP; otherwise, set this to the next major release milestone.
  • After merge, any internal documentations need updating (e.g., JIRA, Innerspace)?

@pllim pllim added the feature Feature request label Jun 6, 2023
@pllim pllim added this to the 3.6 milestone Jun 6, 2023
@github-actions github-actions bot added the imviz label Jun 6, 2023
@pllim pllim changed the title FEAT: Annulus draw tool for Imviz FEAT: Annulus draw tool for Imviz, BUG: Fix ellipse translation in app.get_subsets() Jun 6, 2023
@pllim pllim added the bug Something isn't working label Jun 6, 2023
@pllim pllim mentioned this pull request Jun 13, 2023
@pllim pllim force-pushed the happy-little-annulus branch 2 times, most recently from 94f0973 to 8cd0c3c Compare June 19, 2023 19:31
@pllim pllim mentioned this pull request Jun 19, 2023
9 tasks
@codecov
Copy link

codecov bot commented Jun 19, 2023

Codecov Report

Patch coverage: 80.00% and project coverage change: -0.03 ⚠️

Comparison is base (0fdb3bd) 91.37% compared to head (55d8b51) 91.34%.

Additional details and impacted files
@@            Coverage Diff             @@
##             main    #2240      +/-   ##
==========================================
- Coverage   91.37%   91.34%   -0.03%     
==========================================
  Files         150      150              
  Lines       16862    16848      -14     
==========================================
- Hits        15407    15390      -17     
- Misses       1455     1458       +3     
Impacted Files Coverage Δ
jdaviz/configs/imviz/plugins/viewers.py 94.93% <ø> (ø)
...igs/default/plugins/subset_plugin/subset_plugin.py 92.85% <77.27%> (-0.96%) ⬇️
jdaviz/app.py 85.79% <100.00%> (-0.28%) ⬇️
jdaviz/core/tools.py 86.19% <100.00%> (+0.05%) ⬆️

☔ View full report in Codecov by Sentry.
📢 Do you have feedback about the report comment? Let us know in this issue.

pllim and others added 4 commits June 21, 2023 12:29
TODO: Need to fix icon.

TST: Add tests.

[ci skip] [rtd skip]
and bump upstream pins
upstream in glue-astronomy during review process
@pllim pllim force-pushed the happy-little-annulus branch from 5b1cdc4 to 3f62da8 Compare June 21, 2023 17:18
@pllim pllim marked this pull request as ready for review June 21, 2023 17:26
@rosteen
Copy link
Collaborator

rosteen commented Jun 22, 2023

Drawing the annulus works great, and I'm happy that it's possible to edit the inner/outer radius in the Subset Tools plugin. However, it's possible to get an error and into a nasty state by inputting an inner radius greater than the outer radius and hitting "update" - I'm trying to channel @kecnry and figure out an elegant way to disable the button in this case before I approve.

@rosteen
Copy link
Collaborator

rosteen commented Jun 22, 2023

I just opened pllim#11 to fix the issue mentioned above.

@camipacifici
Copy link
Contributor

Found a couple of probably unrelated bugs that I will report elsewhere.
The annulus works great! The recenter in plot option is kind of useless though. It uses the center of mass in the annulus (as expected), but it is not the behavior a user would need here. Maybe better to disable recenter for annulus?

@camipacifici
Copy link
Contributor

An upgrade could be the ability to recenter based on the center of another subset ;)

@pllim
Copy link
Contributor Author

pllim commented Jun 22, 2023

@camipacifici , I disabled recentering for annulus now. I'd rather not do any significant upgrades until we figure out #2238 .

Thanks for the reviews, everyone! If this looks good now, please approve.

because not sure why spectral region is using Imviz centering method
but okay.
Copy link
Collaborator

@rosteen rosteen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me now! Thanks.

Copy link
Contributor

@javerbukh javerbukh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good!

@pllim pllim changed the title FEAT: Annulus draw tool for Imviz, BUG: Fix ellipse translation in app.get_subsets() FEAT: Annulus draw tool for Imviz Jun 29, 2023
@pllim pllim merged commit bc6cdee into spacetelescope:main Jun 29, 2023
@pllim pllim deleted the happy-little-annulus branch June 29, 2023 15:11
rosteen added a commit that referenced this pull request Jul 5, 2023
* feat: pyinstaller

* codesign osx

* debug: try without codesign

* does not need arguments

* use hooks

* also download the app

* use branch of pyinstaller

* better hooks

* pin to 5.11

Otherwise we need to do at least:
+        rm -rf standalone/dist/jdaviz.app/Contents/MacOS/jedi/third_party/typeshed/stdlib/
+        rm -rf standalone/dist/jdaviz.app/Contents/MacOS/**/*.dist-info

* fix: maintain symlinks by zipping, upload-artifact does not support it

* GHA logic?

* code sign on gha

* run notary tool on gha

* fix: redo codesign after modifications

* fix: reorder zipping and notary step

* remove invalid symlink

* make sure the program executes

* fix path of entitlements file

* add comment for hint with the osx fix

* gpt assisted way of running the log tool on failure

* fix syntax error

* fix path

* comments for the future

* fix uuid parsing and re-zip the app after notary step

* fix: use ditto instead of zip

from https://developer.apple.com/forums/thread/116831

zip might cause issues with utf8 or metadata.

* comments for the future

* fix uuid for notary step

* upload different artifact for osx

* cleanup spec file and hooks, no more __pycache__ files should be included

* ci: do not cancel on failure

* fix: mistune 3.0 needs this

* make dmg instead of zip for osx

* BUG: Fix mouseover behavior in Cubeviz
spectrum viewer when spatial subset is present.

Co-authored-by: Duy Nguyen <[email protected]>

* Remove change log from #2258

because the bug only affects unreleased code

[ci skip] [rtd skip]

* Deprecate get_subsets_from_viewer

* Missing region index

* Fix subset args

* Remove get_data_from_viewer from imviz viewer tests

* Remove get_data_from_viewer from mosviz data loading test and sub hardcoded viewer ref names

* Mosviz test update image truth class

* Fix incorrect viewer ref

* Set Mos2Dviewer data statistic to None by default

* Non-existent data check

* Properly deprecate getters

* Properly check for valueError on non-existent label

* Update Specviz get_data_from_viewer test

* Rename "subset_to_apply" to "spectral_subset

* Codestyle

* Fix docs wording

Co-authored-by: Jesse Averbukh <[email protected]>

* Catch missed code, fix bug

* Retain Mosviz get_data behavior
and fix change log

* Undo bad diff

* MNT: Add .mailmap
so git shortlog -es gives sane listing.

* DOC: Add warning about surface brightness in Simple Aperture Photometry plugin (#2261)

* DOC: Add warning about surface brightness
in Simple Aperture Photometry plugin.

I am beginning to think the Simple in plugin name no longer applies.

* DOC: Improve verbiage.

Co-authored-by: Camilla Pacifici <[email protected]>

---------

Co-authored-by: Camilla Pacifici <[email protected]>

* FEAT: Annulus draw tool for Imviz (#2240)

* FEAT: Annulus draw tool for Imviz.

TODO: Need to fix icon.

TST: Add tests.

[ci skip] [rtd skip]

* Pull in #2204 into this PR
and bump upstream pins

* Changed function name
upstream in glue-astronomy during review process

* Proper annulus icon from J. Kotler

Co-authored-by: Jennifer Kotler <[email protected]>

* Avoid error traceback with bad annulus radii

* Disable recentering for annulus

* Fix test failure
because not sure why spectral region is using Imviz centering method
but okay.

---------

Co-authored-by: Jennifer Kotler <[email protected]>
Co-authored-by: Ricky O'Steen <[email protected]>

* MNT: Temporarily pin voila<0.5 (#2269)

* MNT: Temp pin voila<0.5
because voila-template is incompatible, see #2268

* TST: Disable voila dev in test matrix

* TST: Ignore DeprecationWarning from asteval (#2274)

* TST: Ignore DeprecationWarning from asteval.
For example https://github.com/newville/asteval/issues/120

* Also ignore FutureWarning from asteval

* Add doc for windows latency issue

* Deprecate load_spectrum

* Update tests and docs from load_spectrum

* Docstring suggestions

Co-authored-by: P. L. Lim <[email protected]>

* Changelog

* Changelog

* Button to export Cubeviz movie (#2264)

* WIP: Backend API to write movie file
but got stuck with bqplot not cooperating after first frame.

[ci skip] [rtd skip]

* fix: bqplot stuck after the first frame of the movie

We have to run the loop outside the main thread; otherwise, the
processing of messages from the frontend is blocked, causing the
message with the first image to never be received. The "save_image"
method can only save the next image after the previous image is
received.

* Fix typo, this works now from the API.

[ci skip] [rtd skip]

* Add frontend and tests

* Add user doc

* DOC: Add note about standalone app
saving file into weird places.

* Address some review comments

* Expose FPS and fix test

* DOC: Baby Shark roundtrip
as promised.

* DOC: Ellie said more shark!

* Vue.js style improvements

[ci skip] [rtd skip]

Co-authored-by: Kyle Conroy <[email protected]>

* Display pls install msg in plugin

* Address review comments

* Fix test

* Fix path resolution in standalone app

* Improve frontend validation and access.

Co-authored-by: Kyle Conroy <[email protected]>

* Disable video for spectrum-viewer in GUI
and add comment to Slice.

* Add tooltip to kill switch
but it only shows when activated

* Rename kill with something less scary

* Hide stop button
since disabling is not obvious enough, also moar tooltip

* Disable the whole movie menu for spectrum

viewer in Cubeviz [ci skip] [rtd skip]

Co-authored-by: Ricky O'Steen <[email protected]>

* Fix RTD warnings about invalid prop
and remove unnecessary frontend check now that Ricky's suggestion is accepted.

---------

Co-authored-by: Mario Buikhuizen <[email protected]>
Co-authored-by: Kyle Conroy <[email protected]>
Co-authored-by: Ricky O'Steen <[email protected]>

* Add functional but ugly launcher

* Use launcher notebook if neither config nor filepath is specified

* Codestyle

* Add margins on left and right to avoid cutoff in notebook

* Support launcher from cli

* Codestyle

* Remove URI from path text until implemented

* Fix standalone bug

* Specify --layout= as new required cli syntax

* Remove unused import

Co-authored-by: P. L. Lim <[email protected]>

* Update readme to show required layout flag

* Changelog

* Changelog

Co-authored-by: P. L. Lim <[email protected]>

* Changelog

* Update .github/workflows/standalone.yml

Co-authored-by: P. L. Lim <[email protected]>

* Update .github/workflows/standalone.yml

* Update to use config launcher

* Moved changelog entry to new section

---------

Co-authored-by: Duy Nguyen <[email protected]>
Co-authored-by: Pey Lian Lim <[email protected]>
Co-authored-by: Duy Tuong Nguyen <[email protected]>
Co-authored-by: Jesse Averbukh <[email protected]>
Co-authored-by: Camilla Pacifici <[email protected]>
Co-authored-by: Jennifer Kotler <[email protected]>
Co-authored-by: Ricky O'Steen <[email protected]>
Co-authored-by: Mario Buikhuizen <[email protected]>
Co-authored-by: Kyle Conroy <[email protected]>
Co-authored-by: Ricky O'Steen <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working feature Feature request imviz Ready for final review
Projects
None yet
Development

Successfully merging this pull request may close these issues.

BUG: Ellipse translation in app.get_subsets() is wrong Drag and draw annulus with hardcoded width
4 participants