-
Notifications
You must be signed in to change notification settings - Fork 79
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
implement unit conversion in specviz2d #3253
Conversation
50e8194
to
b2d178d
Compare
22ca012
to
f2920e2
Compare
Codecov ReportAttention: Patch coverage is
❌ Your patch status has failed because the patch coverage (87.50%) is below the target coverage (90.00%). You can increase the patch coverage or adjust the target coverage. Additional details and impacted files@@ Coverage Diff @@
## main #3253 +/- ##
==========================================
+ Coverage 87.51% 87.53% +0.02%
==========================================
Files 128 128
Lines 19901 19957 +56
==========================================
+ Hits 17416 17469 +53
- Misses 2485 2488 +3 ☔ View full report in Codecov by Sentry. |
self.has_angle = False | ||
self.has_sb = False |
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.
jdaviz/configs/cubeviz/plugins/spectral_extraction/tests/test_spectral_extraction.py
Outdated
Show resolved
Hide resolved
spec = self.dataset.selected_spectrum | ||
# Needs Attention: | ||
# should conversion occur before or after call to _apply_subset_masks? | ||
if spec.flux.unit.to_string != self.app._get_display_unit('flux'): |
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.
Isn't this a method? Is it cheaper to compare units instead of casting to string?
if spec.flux.unit.to_string != self.app._get_display_unit('flux'): | |
if spec.flux.unit.to_string() != self.app._get_display_unit('flux'): |
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.
Good catch! Is it worth converting the display units to astropy.Unit or keep to string comparison?
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'm not sure, probably fine as is for now
self._dict['spectral_axis'] = wave.value | ||
self._dict['spectral_axis:unit'] = wave.unit.to_string() |
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.
where were these handled before (I don't see them in the 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.
X-axis conversions were not previously handled in Specviz2d, so they were previously always using the native units and value when mousing over
# Note: spectra2d Wave loaded in meters, but we respect one spectral unit, so the meters in | ||
# converted to Angstrom (the spectra1d spectral unit). |
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.
Can you explain this a little more? Is it that a previous data entry was in angstroms or just that that is the default spectral display unit?
# Note: spectra2d Wave loaded in meters, but we respect one spectral unit, so the meters in | |
# converted to Angstrom (the spectra1d spectral unit). | |
# Note: spectra2d Wave loaded in meters, but we respect one spectral unit, so the meters is | |
# converted to Angstrom (the spectra1d spectral unit). |
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.
So the loaded 1D and 2D spectra have different native spectral units, with one in meters and one in angstroms and app-wide we're respecting one choice for spectral unit.
jdaviz/configs/specviz/plugins/unit_conversion/unit_conversion.py
Outdated
Show resolved
Hide resolved
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.
When testing this with the specviz2d example notebook, the option to change flux unit disappears when you load the data. The screen shots below show an empty specviz instance, with the 'Flux' option appearing under the unit conversion plugin, and then after loading data when that dropdown disappears
What is included in the scope here for surface brightness logic, including coercing flux units to surface brightness, handling square pixel, and toggling the spectral axis? (Are images of 2d spectra even typically or commonly in surface brightness units?) |
|
663e158
to
15c3514
Compare
2745eef
to
9e031c9
Compare
Probably could be a follow-up - but do we want to invert the x-axis on the 2d spectrum to align with the 1d spectrum when switching between wavelength and frequency units? |
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.
Huge effort - just a few small comments and then I think this is good to go in and build on and hopefully didn't miss too many bugs that might slip through 🤞
@@ -18,12 +19,43 @@ def _is_matched_viewer(self, viewer): | |||
return isinstance(viewer, (MosvizProfile2DView, MosvizProfileView)) | |||
|
|||
def _map_limits(self, from_viewer, to_viewer, limits={}): |
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.
any (reasonable) way to increase test coverage in this method?
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'm not sure if codecov will be satisfied, but, I should be able to add to an existing test where the data_collection entry doesn't have the cid
s that were looking for.
A second addition could be to manually recreate the conversion with the pixel_to_world_limits
and vis versa in the test itself and assert whether the results are the same (but it will pretty much be identical to the logic in the method).
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 added a second test for when the data loaded doesn't have the Wave nor Wavelength component (I tried using data_collection[0].remove_component('Wave')
to no avail). I'm open to adding the pixel_to_world_limits test if coverage doesn't increase much from this recent test addition.
jdaviz/configs/specviz/plugins/line_analysis/tests/test_line_analysis.py
Outdated
Show resolved
Hide resolved
jdaviz/configs/specviz2d/plugins/spectral_extraction/spectral_extraction.py
Outdated
Show resolved
Hide resolved
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.
Great work! I tested this out as best as I could, and made follow up tickets for the existing issues on main that prevented me from testing some of the functionality. I think that it is OK to merge this with the expectation that things might come up once some of the blocking issues are fixed.
- The spectrum viewer and image viewer both pick up changes in flux units, and the mouseover displays the correct units in both viewers. Repeated translations of the spectral axis are buggy, but this is the case on main and I created a follow up ticket for this.
- Model fitting. Previews of fit models don't display in the spectrum viewer, which is a pre-existing issue. It looks like the test you wrote for this verifies the unit conversion functionality in the model fitting plugin, and I tested various cases, so I think that is sufficient and if something comes up with the previews after that's fixed we can follow up.
- Spectral extraction seems to work with unit conversions, I didn't test this super robustly but in the few cases I tested it with, it works.
- The markers table plugin accurately reflects the selected unit, and works between various conversions that I tried.
- Line Lists and Line Analysis would benefit from a follow up investigation to see if any unit conversion support is needed, in general.
- There is a blocking issue with creating subsets that prevented me from testing some of the plugin functionality on subsets. I am unable to create spectral subsets. If this is not fixed with your linking PR, i'll make a ticket
Approving, pending 3.13 test failure (is this unrelated?)
Description
This pull request is to address implementing the Unit Conversion plugin in Specviz2d.
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.