Module audian.panels

Manage plot panels.

class Panel: a single plot panel class Panels: manage all plot panels

Classes

class Panel (name, ax_spec, row)
Expand source code
class Panel(object):


    times = 't'
    amplitudes = 'xyu'
    frequencies = 'fw'
    powers = 'pq'
    spacer = 'spacer'
    
    
    def __init__(self, name, ax_spec, row):
        self.name = name
        self.ax_spec = ax_spec
        self.row = row
        self.axs = []
        self.axcs = []   # associated color bars


    def __str__(self):
        return f'{self.name:20}: {self.ax_spec:6} @ {self.row:2} with {len(self.axs):2} plots'


    def __len__(self):
        return len(self.axs)


    def __eq__(self, ax_spec):
        return self.ax_spec == ax_spec


    def x(self):
        return self.ax_spec[0]


    def y(self):
        return self.ax_spec[1]


    def z(self):
        return self.ax_spec[2] if len(self.ax_spec) > 2 else ''


    def is_time(self):
        return self.x() in self.times


    def is_xamplitude(self):
        return self.x() in self.amplitudes


    def is_yamplitude(self):
        return self.y() in self.amplitudes


    def is_xfrequency(self):
        return self.x() in self.frequencies


    def is_yfrequency(self):
        return self.y() in self.frequencies


    def is_xpower(self):
        return self.x() in self.powers


    def is_ypower(self):
        return self.y() in self.powers


    def is_zpower(self):
        z = self.z()
        return z and z in self.powers


    def is_trace(self):
        return self.is_time() and self.is_yamplitude()


    def is_spectrogram(self):
        return self.is_time() and self.is_yfrequency()


    def is_power(self):
        return self.is_xpower() and self.is_yfrequency()


    def is_spacer(self):
        return self.ax_spec == self.spacer

    
    def add_ax(self, row, ax, axc=None):
        self.row = row
        self.axs.append(ax)
        if axc is not None:
            self.axcs.append(axc)


    def is_used(self):
        return len(self.axs) > 0


    def is_visible(self, channel):
        return self.axs[channel].isVisible()


    def set_visible(self, visible):
        changed = False
        for ax in self.axs:
            if ax.isVisible() != visible:
                changed = True
            ax.setVisible(visible)
        return changed


    def has_visible_traces(self, channel):
        if self.is_spacer():
            return False
        for di in self.axs[channel].data_items:
            if di.isVisible():
                return True
        return False


    def has_viewbox(self, viewbox):
        for ax in self.axs:
            if ax.getViewBox() is viewbox:
                return True
        return False


    def show_grid(self, grids):
        if self.is_spacer():
            return False
        for ax in self.axs:
            ax.showGrid(x=(grids & 1) > 0, y=(grids & 2) > 0,
                        alpha=0.8)
            """
            # fix grid bug:
            ax.getAxis('bottom').setGrid(False)
            ax.getAxis('left').setGrid(False)
            for axis in ['right', 'top']:
                ax.showAxis(axis)
                ax.getAxis(axis).setStyle(showValues=False)
            """

    def is_cbar_visible(self, channel):
        return self.axcs[channel].isVisible()


    def set_cbar_visible(self, visible):
        changed = False
        for ax in self.axcs:
            if ax.isVisible() != visible:
                changed = True
            ax.setVisible(visible)
        return changed


    def set_colormap(self, color_map):
        for ax in self.axcs:
            ax.setColorMap(color_map)

            
    def add_item(self, plot_item, channel=-1, is_data=False):
        if channel >= 0:
            self.axs[channel].add_item(plot_item, is_data)
        else:
            for ax in self.axs:
                ax.add_item(plot_item, is_data)


    def add_traces(self, channel, data): 
        for trace in data.traces:
            if trace.panel != self.name:
                continue
            if self.is_trace():
                item = TraceItem(trace, channel)
            if self.is_spectrogram():
                item = SpecItem(trace, channel)
            self.add_item(item, channel, True)


    def get_amplitude(self, channel, t, x, t1=None):
        if not self.is_yamplitude() or len(self.axs[channel].data_items) == 0:
            return t, None
        trace = self.axs[channel].data_items[-1]
        return trace.get_amplitude(t, x, t1)


    def get_power(self, channel, t, f):
        if not self.is_yfrequency() or len(self.axs[channel].data_items) == 0:
            return None
        trace = self.axs[channel].data_items[0]
        return trace.get_power(t, f)


    def update_plots(self):
        for ax in self.axs:
            if ax.isVisible() and not self.is_spacer():
                ax.update_plot()

Class variables

var times
var amplitudes
var frequencies
var powers
var spacer

Methods

def x(self)
Expand source code
def x(self):
    return self.ax_spec[0]
def y(self)
Expand source code
def y(self):
    return self.ax_spec[1]
def z(self)
Expand source code
def z(self):
    return self.ax_spec[2] if len(self.ax_spec) > 2 else ''
def is_time(self)
Expand source code
def is_time(self):
    return self.x() in self.times
def is_xamplitude(self)
Expand source code
def is_xamplitude(self):
    return self.x() in self.amplitudes
def is_yamplitude(self)
Expand source code
def is_yamplitude(self):
    return self.y() in self.amplitudes
def is_xfrequency(self)
Expand source code
def is_xfrequency(self):
    return self.x() in self.frequencies
def is_yfrequency(self)
Expand source code
def is_yfrequency(self):
    return self.y() in self.frequencies
def is_xpower(self)
Expand source code
def is_xpower(self):
    return self.x() in self.powers
def is_ypower(self)
Expand source code
def is_ypower(self):
    return self.y() in self.powers
def is_zpower(self)
Expand source code
def is_zpower(self):
    z = self.z()
    return z and z in self.powers
def is_trace(self)
Expand source code
def is_trace(self):
    return self.is_time() and self.is_yamplitude()
def is_spectrogram(self)
Expand source code
def is_spectrogram(self):
    return self.is_time() and self.is_yfrequency()
def is_power(self)
Expand source code
def is_power(self):
    return self.is_xpower() and self.is_yfrequency()
def is_spacer(self)
Expand source code
def is_spacer(self):
    return self.ax_spec == self.spacer
def add_ax(self, row, ax, axc=None)
Expand source code
def add_ax(self, row, ax, axc=None):
    self.row = row
    self.axs.append(ax)
    if axc is not None:
        self.axcs.append(axc)
def is_used(self)
Expand source code
def is_used(self):
    return len(self.axs) > 0
def is_visible(self, channel)
Expand source code
def is_visible(self, channel):
    return self.axs[channel].isVisible()
def set_visible(self, visible)
Expand source code
def set_visible(self, visible):
    changed = False
    for ax in self.axs:
        if ax.isVisible() != visible:
            changed = True
        ax.setVisible(visible)
    return changed
def has_visible_traces(self, channel)
Expand source code
def has_visible_traces(self, channel):
    if self.is_spacer():
        return False
    for di in self.axs[channel].data_items:
        if di.isVisible():
            return True
    return False
def has_viewbox(self, viewbox)
Expand source code
def has_viewbox(self, viewbox):
    for ax in self.axs:
        if ax.getViewBox() is viewbox:
            return True
    return False
def show_grid(self, grids)
Expand source code
def show_grid(self, grids):
    if self.is_spacer():
        return False
    for ax in self.axs:
        ax.showGrid(x=(grids & 1) > 0, y=(grids & 2) > 0,
                    alpha=0.8)
        """
        # fix grid bug:
        ax.getAxis('bottom').setGrid(False)
        ax.getAxis('left').setGrid(False)
        for axis in ['right', 'top']:
            ax.showAxis(axis)
            ax.getAxis(axis).setStyle(showValues=False)
        """
def is_cbar_visible(self, channel)
Expand source code
def is_cbar_visible(self, channel):
    return self.axcs[channel].isVisible()
def set_cbar_visible(self, visible)
Expand source code
def set_cbar_visible(self, visible):
    changed = False
    for ax in self.axcs:
        if ax.isVisible() != visible:
            changed = True
        ax.setVisible(visible)
    return changed
def set_colormap(self, color_map)
Expand source code
def set_colormap(self, color_map):
    for ax in self.axcs:
        ax.setColorMap(color_map)
def add_item(self, plot_item, channel=-1, is_data=False)
Expand source code
def add_item(self, plot_item, channel=-1, is_data=False):
    if channel >= 0:
        self.axs[channel].add_item(plot_item, is_data)
    else:
        for ax in self.axs:
            ax.add_item(plot_item, is_data)
def add_traces(self, channel, data)
Expand source code
def add_traces(self, channel, data): 
    for trace in data.traces:
        if trace.panel != self.name:
            continue
        if self.is_trace():
            item = TraceItem(trace, channel)
        if self.is_spectrogram():
            item = SpecItem(trace, channel)
        self.add_item(item, channel, True)
def get_amplitude(self, channel, t, x, t1=None)
Expand source code
def get_amplitude(self, channel, t, x, t1=None):
    if not self.is_yamplitude() or len(self.axs[channel].data_items) == 0:
        return t, None
    trace = self.axs[channel].data_items[-1]
    return trace.get_amplitude(t, x, t1)
def get_power(self, channel, t, f)
Expand source code
def get_power(self, channel, t, f):
    if not self.is_yfrequency() or len(self.axs[channel].data_items) == 0:
        return None
    trace = self.axs[channel].data_items[0]
    return trace.get_power(t, f)
def update_plots(self)
Expand source code
def update_plots(self):
    for ax in self.axs:
        if ax.isVisible() and not self.is_spacer():
            ax.update_plot()
class Panels
Expand source code
class Panels(dict):

    def __init__(self):
        super().__init__(self)


    def __str__(self):
        s = []
        for panel in self.values():
            s.append(str(panel))
        return '\n'.join(s)


    def add(self, name, axes, row=None, adjust_rows=True):
        if row is None:
            row = self.max_row() + 1
        if adjust_rows:
            for panel in self.values():
                if panel.row >= row:
                    panel.row += 1
        self[name] = Panel(name, axes, row)
        if len(self) > 1:
            names = np.array(list(self.keys()))
            rows = [self[name].row for name in names]
            inx = np.argsort(rows)
            panels = dict(self)
            self.clear()
            for name in names[inx]:
                self[name] = panels[name]


    def add_trace(self, name='trace', row=None):
        # find amplitude that is not used yet:
        amps = [False]*len(Panel.amplitudes)
        for panel in self.values():
            if panel.is_trace():
                amps[Panel.amplitudes.index(panel.y())] = True
        axspec = Panel.times[0] + Panel.amplitudes[0]
        for k in range(len(amps)):
            if not amps[k]:
                axspec = axspec[0] + Panel.amplitudes[k]
                break
        self.add(name, axspec, row)

        
    def add_spectrogram(self, name='spectrogram', row=None):
        # find frequencies and powers that are not used yet:
        freqs = [False]*len(Panel.frequencies)
        pwrs = [False]*len(Panel.powers)
        for panel in self.values():
            if panel.is_spectrogram():
                freqs[Panel.frequencies.index(panel.y())] = True
                pwrs[Panel.powers.index(panel.z())] = True
        axspec = Panel.times[0] + Panel.frequencies[0] + Panel.powers[0]
        for k in range(len(freqs)):
            if not freqs[k]:
                axspec = axspec[0] + Panel.frequencies[k] + axspec[2]
                break
        for k in range(len(pwrs)):
            if not pwrs[k]:
                axspec = axspec[:2] + Panel.powers[k]
                break
        self.add(name, axspec, row)
        self.add(name + '-power', axspec[2] + axspec[1], self[name].row, False)


    def fill(self, data):
        for trace in data.traces:
            if trace.panel not in self:
                if trace.panel_type == 'trace':
                    self.add_trace(trace.panel)
                elif trace.panel_type == 'spectrogram':
                    self.add_spectrogram(trace.panel)
        

    def remove(self, name):
        del self[name]

        
    def max_row(self):
        if len(self) > 0:
            return  np.max([panel.row for panel in self.values()])
        else:
            return -1

        
    def add_power_ax(self, name, row, ax):
        name = name + '-power'
        if name in self:
            self[name].add_ax(row, ax)
            

    def get_panel(self, viewbox):
        for panel in self.values():
            if panel.has_viewbox(viewbox):
                return panel
        return None

    
    def show_grid(self, grids):
        for panel in self.values():
            panel.show_grid(grids)

            
    def update_plots(self):
        for panel in self.values():
            panel.update_plots()


    def insert_spacers(self):
        panels = {}
        row = 0
        spacer = 0
        for name in self:
            if row > 0 and not self[name].is_power():
                panels[f'spacer{spacer}'] = Panel(f'spacer{spacer}',
                                                  Panel.spacer, 0)
                spacer += 1
            panels[name] = self[name]
            row += 1
        self.clear()
        for name, value in panels.items():
            self[name] = value
        
            
    def show_spacers(self, channel):
        prev_panel = None
        prev_spacer = None
        for panel in self.values():
            if panel.is_spacer():
                if prev_panel:
                    prev_visible = prev_panel.is_visible(channel)
                    panel.set_visible(prev_visible)
                    if prev_visible:
                        prev_spacer = panel
            elif not panel.is_power():
                prev_panel = panel
                if panel.is_visible(channel):
                    prev_spacer = None
        if prev_spacer:
            panel.set_visible(False)

dict() -> new empty dictionary dict(mapping) -> new dictionary initialized from a mapping object's (key, value) pairs dict(iterable) -> new dictionary initialized as if via: d = {} for k, v in iterable: d[k] = v dict(**kwargs) -> new dictionary initialized with the name=value pairs in the keyword argument list. For example: dict(one=1, two=2)

Ancestors

  • builtins.dict

Methods

def add(self, name, axes, row=None, adjust_rows=True)
Expand source code
def add(self, name, axes, row=None, adjust_rows=True):
    if row is None:
        row = self.max_row() + 1
    if adjust_rows:
        for panel in self.values():
            if panel.row >= row:
                panel.row += 1
    self[name] = Panel(name, axes, row)
    if len(self) > 1:
        names = np.array(list(self.keys()))
        rows = [self[name].row for name in names]
        inx = np.argsort(rows)
        panels = dict(self)
        self.clear()
        for name in names[inx]:
            self[name] = panels[name]
def add_trace(self, name='trace', row=None)
Expand source code
def add_trace(self, name='trace', row=None):
    # find amplitude that is not used yet:
    amps = [False]*len(Panel.amplitudes)
    for panel in self.values():
        if panel.is_trace():
            amps[Panel.amplitudes.index(panel.y())] = True
    axspec = Panel.times[0] + Panel.amplitudes[0]
    for k in range(len(amps)):
        if not amps[k]:
            axspec = axspec[0] + Panel.amplitudes[k]
            break
    self.add(name, axspec, row)
def add_spectrogram(self, name='spectrogram', row=None)
Expand source code
def add_spectrogram(self, name='spectrogram', row=None):
    # find frequencies and powers that are not used yet:
    freqs = [False]*len(Panel.frequencies)
    pwrs = [False]*len(Panel.powers)
    for panel in self.values():
        if panel.is_spectrogram():
            freqs[Panel.frequencies.index(panel.y())] = True
            pwrs[Panel.powers.index(panel.z())] = True
    axspec = Panel.times[0] + Panel.frequencies[0] + Panel.powers[0]
    for k in range(len(freqs)):
        if not freqs[k]:
            axspec = axspec[0] + Panel.frequencies[k] + axspec[2]
            break
    for k in range(len(pwrs)):
        if not pwrs[k]:
            axspec = axspec[:2] + Panel.powers[k]
            break
    self.add(name, axspec, row)
    self.add(name + '-power', axspec[2] + axspec[1], self[name].row, False)
def fill(self, data)
Expand source code
def fill(self, data):
    for trace in data.traces:
        if trace.panel not in self:
            if trace.panel_type == 'trace':
                self.add_trace(trace.panel)
            elif trace.panel_type == 'spectrogram':
                self.add_spectrogram(trace.panel)
def remove(self, name)
Expand source code
def remove(self, name):
    del self[name]
def max_row(self)
Expand source code
def max_row(self):
    if len(self) > 0:
        return  np.max([panel.row for panel in self.values()])
    else:
        return -1
def add_power_ax(self, name, row, ax)
Expand source code
def add_power_ax(self, name, row, ax):
    name = name + '-power'
    if name in self:
        self[name].add_ax(row, ax)
def get_panel(self, viewbox)
Expand source code
def get_panel(self, viewbox):
    for panel in self.values():
        if panel.has_viewbox(viewbox):
            return panel
    return None
def show_grid(self, grids)
Expand source code
def show_grid(self, grids):
    for panel in self.values():
        panel.show_grid(grids)
def update_plots(self)
Expand source code
def update_plots(self):
    for panel in self.values():
        panel.update_plots()
def insert_spacers(self)
Expand source code
def insert_spacers(self):
    panels = {}
    row = 0
    spacer = 0
    for name in self:
        if row > 0 and not self[name].is_power():
            panels[f'spacer{spacer}'] = Panel(f'spacer{spacer}',
                                              Panel.spacer, 0)
            spacer += 1
        panels[name] = self[name]
        row += 1
    self.clear()
    for name, value in panels.items():
        self[name] = value
def show_spacers(self, channel)
Expand source code
def show_spacers(self, channel):
    prev_panel = None
    prev_spacer = None
    for panel in self.values():
        if panel.is_spacer():
            if prev_panel:
                prev_visible = prev_panel.is_visible(channel)
                panel.set_visible(prev_visible)
                if prev_visible:
                    prev_spacer = panel
        elif not panel.is_power():
            prev_panel = panel
            if panel.is_visible(channel):
                prev_spacer = None
    if prev_spacer:
        panel.set_visible(False)