-
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
implement unit conversion in specviz2d #3253
base: main
Are you sure you want to change the base?
Conversation
50e8194
to
b2d178d
Compare
22ca012
to
f2920e2
Compare
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #3253 +/- ##
==========================================
+ Coverage 88.11% 88.17% +0.06%
==========================================
Files 127 127
Lines 19574 19734 +160
==========================================
+ Hits 17248 17401 +153
- Misses 2326 2333 +7 ☔ 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/conftest.py
Outdated
@@ -260,7 +260,7 @@ def _create_spectrum1d_cube_with_fluxunit(fluxunit=u.Jy, shape=(2, 2, 4), with_u | |||
wcs_dict = {"CTYPE1": "RA---TAN", "CTYPE2": "DEC--TAN", "CTYPE3": "WAVE-LOG", | |||
"CRVAL1": 205, "CRVAL2": 27, "CRVAL3": 4.622e-7, | |||
"CDELT1": -0.0001, "CDELT2": 0.0001, "CDELT3": 8e-11, | |||
"CRPIX1": 0, "CRPIX2": 0, "CRPIX3": 0, | |||
"CRPIX1": 0, "CRPIX2": 0, "CRPIX3": 0, "PIXAR_SR": 10, |
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.
With this update to the test fixture, in test_spectral_extraction_with_correct_sum_units
, the scale factor is no longer the default value of 1, so we need to update the expected values in the test.
expected_flux_values = [190., 590., 990., 1390., 1790., 2190., 2590., 2990., 3390., 3790.] | ||
# After collapsing, sr is removed via the scale factor and the extracted spectrum is in Jy | ||
expected_flux_values = [flux * collapsed.meta.get('_pixel_scale_factor') | ||
for flux in expected_flux_values] |
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 this be done with array math instead of a list comprehension?
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 have now made an update to make the expect_flux_values
is an array instead of a list, this will remove the list comprehension all together
if 'value' in row_info: | ||
# format and cast flux value for Table | ||
row_info['value'] = f"{row_info['value']:.5e}" | ||
else: | ||
row_info['value'] = '' |
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.
why is this necessary? Can/should we move it to as_dict
instead?
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.
There was an issue arising where the value column in the table couldn't be ready properly. This was happening when casting value when it was numpy.float32 to float in coords_info.py. I added a check to only cast if the value is not already float.
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?
# 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'): | ||
equivalencies = u.spectral_density(self.dataset.selected_spectrum.spectral_axis) | ||
spec = self.dataset.selected_spectrum.with_flux_unit(self.app._get_display_unit('flux'), | ||
equivalencies=equivalencies) |
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.
should this all be moved into the DatasetSelect.selected_spectrum
logic so its reusable and cached (and then the cache would need to be invalidated for a change in flux display 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.
I added some logic to handle_display_unit
, and with that, this block is removed and selected_spectrum(use_display_units=True) replaces it.
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.
# TODO [specviz2d, mosviz] x_display_unit is not implemented in glue for image viewer | ||
# used by spectrum-2d-viewer |
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.
is this still relevant?
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.
For the MosvizImageView, I will make sure to update the comment to reflect this!
# default to sr if input spectrum is not in surface brightness units | ||
# TODO: for cubeviz, should we check the cube itself? | ||
self.angle_unit.selected = 'sr' |
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.
why remove this? It doesn't seem to be replaced with any other logic to accomplish the same thing, except the else
below which is defaulting to pix2 instead.
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 logic just gets moved, not removed. So if the angle_unit
is None
and the config is not specviz nor specviz2d, then the angle_unit
will still be set to sr
. By updating the has_angle
and has_sb
if it is one of the 2 configs, it removes the sb_unit
and angle_unit
from the UI/API.
I can reintroduce the comments that previously exists about setting the angle_unit
to sr
.
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
@cshanahan1 I tested main with in Cubeviz and Specviz and I am seeing the same behavior where the 'Flux Unit' UI component disappears when a cube or spectrum is in counts. I checked this PR for all the traitlets that contribute to the plugin-select component when the native units are counts and all the variables have a value that should enable the component to be visible, so it's going to take some more investigation. Could you test main and see if you get the same result? If so I can create a ticket for it |
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.