Source code for jdaviz.configs.default.plugins.collapse.collapse

from astropy import units as u
from glue.core.message import (DataCollectionAddMessage,
                               DataCollectionDeleteMessage)
from glue.core import Data
from glue.core.link_helpers import LinkSame
from spectral_cube import SpectralCube
from traitlets import List, Unicode, Int, observe

from jdaviz.core.events import SnackbarMessage
from jdaviz.core.registries import tray_registry
from jdaviz.core.template_mixin import TemplateMixin
from jdaviz.utils import load_template

__all__ = ['Collapse']


spaxel = u.def_unit('spaxel', 1 * u.Unit(""))
u.add_enabled_units([spaxel])


# Mapping of pixel axes before and after collapse, as a function of selected axis
AXES_MAPPING = [((1, 2), (0, 1)), ((0, 2), (0, 1)), ((0, 1), (0, 1))]


[docs]@tray_registry('g-collapse', label="Collapse") class Collapse(TemplateMixin): template = load_template("collapse.vue", __file__).tag(sync=True) data_items = List([]).tag(sync=True) selected_data_item = Unicode().tag(sync=True) axes = List([]).tag(sync=True) selected_axis = Int(0).tag(sync=True) funcs = List(['Mean', 'Median', 'Min', 'Max']).tag(sync=True) selected_func = Unicode('Mean').tag(sync=True) def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.hub.subscribe(self, DataCollectionAddMessage, handler=self._on_data_updated) self.hub.subscribe(self, DataCollectionDeleteMessage, handler=self._on_data_updated) self._selected_data = None def _on_data_updated(self, msg): self.data_items = [x.label for x in self.data_collection] @observe('selected_data_item') def _on_data_item_selected(self, event): self._selected_data = next((x for x in self.data_collection if x.label == event['new'])) self.axes = list(range(len(self._selected_data.shape)))
[docs] def vue_collapse(self, *args, **kwargs): try: spec = self._selected_data.get_object(cls=SpectralCube) except AttributeError: snackbar_message = SnackbarMessage( f"Unable to perform collapse over selected data.", color="error", sender=self) self.hub.broadcast(snackbar_message) return collapsed_spec = getattr(spec, self.selected_func.lower())( axis=self.selected_axis) data = Data(coords=collapsed_spec.wcs) data['flux'] = collapsed_spec.filled_data[...] data.get_component('flux').units = str(collapsed_spec.unit) data.meta.update(collapsed_spec.meta) label = f"Collapsed {self._selected_data.label}" self.data_collection[label] = data # Link the new dataset pixel-wise to the original dataset. In general # direct pixel to pixel links are the most efficient and should be # used in cases like this where we know there is a 1-to-1 mapping of # pixel coordinates. Here which axes are linked to which depends on # the selected axis. (i1, i2), (i1c, i2c) = AXES_MAPPING[self.selected_axis] self.data_collection.add_link(LinkSame(self._selected_data.pixel_component_ids[i1], self.data_collection[label].pixel_component_ids[i1c])) self.data_collection.add_link(LinkSame(self._selected_data.pixel_component_ids[i2], self.data_collection[label].pixel_component_ids[i2c])) snackbar_message = SnackbarMessage( f"Data set '{self._selected_data.label}' collapsed successfully.", color="success", sender=self) self.hub.broadcast(snackbar_message)