You're reading the documentation for a development version. For the latest released version, please have a look at v0.2.
trepr.plotting module¶
Plotting: Graphical representations of data extracted from datasets.
Graphical representations of tr-EPR data are an indispensable aspect of data analysis. To facilitate this, a series of different plotters are available. Additionally, savers (and stylers) are implemented.
Plotting relies on matplotlib, and mainly its object-oriented interface should be used for the actual plotting inside the actual plotter classes. Note that the user of the trepr package usually will not be exposed directly to the matplotlib interface.
Generally, two types of plotters can be distinguished:
Plotters for handling single datasets
Shall be derived from
aspecd.plotting.SinglePlotter
.Plotters for handling multiple datasets
Shall be derived from
aspecd.plotting.MultiPlotter
.
In the first case, the plot is usually handled using the plot()
method
of the respective trepr.dataset.Dataset
object. Additionally,
those plotters always only operate on the data of a single dataset, and the
plot can easily be attached as a representation to the respective dataset.
Plotters handling single datasets should always inherit from the
aspecd.plotting.SinglePlotter
class.
In the second case, the plot is handled using the plot()
method of the
aspecd.plotting.Plotter
object, and the datasets are stored as a list
within the plotter. As these plots span several datasets, there is no easy
connection between a single dataset and such a plot in sense of
representations stored in datasets. Plotters handling multiple datasets should
always inherit from the aspecd.plotting.MultiPlotter
class.
A note on array dimensions and axes¶
Something often quite confusing is the apparent inconsistency between the order of array dimensions and the order of axes. While we are used to assign axes in the order x, y, z, and assuming x to be horizontal, y vertical (and z sticking out of the paper plane), arrays are usually indexed row-first, column-second (at least in the widely followed C convention; with FORTRAN things are different). That means, however, that if you simply plot a 2D array in axes, your first dimension is along the y axis, the second dimension along the x axis.
Therefore, as the axes of your datasets will always correspond to the array dimensions of your data, in case of 2D plots you will need to either use the information contained in the second axis object for your x axis label, and the information from the first axis object for your y axis label, or to transpose the data array.
Another aspect to have in mind is the position of the origin. Usually, in a Cartesian coordinate system, convention is to have the origin (0, 0) in the lower left of the axes (for the positive quadrant). However, for images, convention is to have the corresponding (0, 0) pixel located in the upper left edge of your image. Therefore, those plotting methods dealing with images will usually revert the direction of your y axis. Most probably, eventually you will have to check with real data and ensure the plotters to plot data and axes in a consistent fashion.
Types of concrete plotters¶
The trepr package comes with a series of concrete plotters included ready to be used, thanks to inheriting from the underlying ASpecD framework. As stated above, plotters can generally be divided into two types: plotters operating on single datasets and plotters combining the data of multiple datasets into a single figure.
Additionally, plotters can be categorised with regard to creating figures
consisting of a single or multiple axes. The latter are plotters inheriting
from the aspecd.plotting.CompositePlotter
class. The latter can be
thought of as templates for the other plotters to operate on, i.e. they
provide the axes for other plotters to display their results.
Concrete plotters for single datasets¶
trepr.plotting.SinglePlotter1D
Basic line plots for single datasets, allowing to plot a series of line-type plots, including (semi)log plots
trepr.plotting.SinglePlotter2D
Basic 2D plots for single datasets, allowing to plot a series of 2D plots, including contour plots and image-type display
trepr.plotting.SingleCompositePlotter
Composite plotter for single datasets, allowing to plot different views of one and the same datasets by using existing plotters for single datasets.
Concrete plotters for multiple datasets¶
-
Basic line plots for multiple datasets, allowing to plot a series of line-type plots, including (semi)log plots
trepr.plotting.MultiPlotter1DStacked
Stacked line plots for multiple datasets, allowing to plot a series of line-type plots, including (semi)log plots
A note for developers¶
As each kind of spectroscopy comes with own needs for extensions, there is a
class PlotterExtensions
that can be used as a mixin class for other
plotters to provide additional functionality for all plotters.
Make sure when implementing functionality here that it really works with all
types of plotters, i.e. both SinglePlotters and MultiPlotters. This is
particularly relevant if you need to get information from dataset(s),
as a SinglePlotter will have an attribute dataset
, while a MultiPlotter
will have an attribute datasets
.
Module documentation¶
-
class
trepr.plotting.
ColormapAdjuster
(dataset=<trepr.dataset.ExperimentalDataset object>)¶ Bases:
object
General facilities to adjust the colormap.
This class makes sure that the zero point of the colormap is equal to the zero point of the dataset.
- Parameters
dataset (
trepr.dataset.Dataset
) – Dataset structure containing raw data as well as metadata.
-
dataset
¶ Dataset to work with.
-
normalised_colormap
¶ Colormap normalised to data of dataset.
- Type
matplotlib.colormap
Deprecated since version 0.1: Will be included in
aspecd.plotting.SinglePlotter2D
.-
adjust
()¶ Perform all methods to adjust the colormap.
-
class
trepr.plotting.
PlotterExtensions
¶ Bases:
object
Extensions for plots of tr-EPR data.
This class is meant as a mixin class for plotters of the trepr package and provides functionality specific for tr-EPR-spectroscopic data.
Hence it can only be used as mixin in addition to a plotter class.
-
parameters
¶ All parameters necessary for the plot, implicit and explicit
The following keys exist, in addition to those defined by the actual plotter:
- g-axis:
bool
Whether to show an additional g axis opposite of the magnetic field axis
This assumes the magnetic field axis to be the x axis and the magnetic field values to be in millitesla (mT), as it calls
trepr.utils.convert_mT2g()
.
- Type
- g-axis:
New in version 0.2.
-
-
class
trepr.plotting.
SinglePlotter1D
¶ Bases:
aspecd.plotting.SinglePlotter1D
,trepr.plotting.PlotterExtensions
1D plots of single datasets.
Convenience class taking care of 1D plots of single datasets.
As the class is fully inherited from ASpecD for simple usage, see the ASpecD documentation of the
aspecd.plotting.SinglePlotter1D
class for details.Furthermore, the class inherits all functionality from
PlotterExtensions
. See there for additional details.Examples
For convenience, a series of examples in recipe style (for details of the recipe-driven data analysis, see
aspecd.tasks
) is given below for how to make use of this class. Of course, all parameters settable for the superclasses can be set as well. The examples focus each on a single aspect.In the simplest case, just invoke the plotter with default values:
- kind: singleplot type: SinglePlotter1D properties: filename: output.pdf
In case you would like to have a g axis plotted as a second x axis on top (note that this only makes sense in case of a calibrated magnetic field axis):
- kind: singleplot type: SinglePlotter1D properties: parameters: g-axis: true filename: output.pdf
-
class
trepr.plotting.
SinglePlotter2D
¶ Bases:
aspecd.plotting.SinglePlotter2D
,trepr.plotting.PlotterExtensions
2D plots of single datasets.
Convenience class taking care of 2D plots of single datasets.
As the class is fully inherited from ASpecD for simple usage, see the ASpecD documentation of the
aspecd.plotting.SinglePlotter2D
class for details.Furthermore, the class inhertis all functionality from
PlotterExtensions
. See there for additional details.Examples
For convenience, a series of examples in recipe style (for details of the recipe-driven data analysis, see
aspecd.tasks
) is given below for how to make use of this class. Of course, all parameters settable for the superclasses can be set as well. The examples focus each on a single aspect.In the simplest case, just invoke the plotter with default values:
- kind: singleplot type: SinglePlotter2D properties: filename: output.pdf
To change the axes (flip x and y axis):
- kind: singleplot type: SinglePlotter2D properties: filename: output.pdf parameters: switch_axes: True
To use another type (here: contour):
- kind: singleplot type: SinglePlotter2D properties: filename: output.pdf type: contour
To set the number of levels of a contour plot to 10:
- kind: singleplot type: SinglePlotter2D properties: filename: output.pdf type: contour parameters: levels: 10
To change the colormap (cmap) used:
- kind: singleplot type: SinglePlotter2D properties: filename: output.pdf properties: drawing: cmap: RdGy
Make sure to check the documentation of the ASpecD
aspecd.plotting
module for further parameters that can be set.In case you would like to have a g axis plotted as a second x axis on top (note that this only makes sense in case of a calibrated magnetic field axis):
- kind: singleplot type: SinglePlotter2D properties: parameters: g-axis: true filename: output.pdf
-
class
trepr.plotting.
SinglePlotter2DStacked
¶ Bases:
aspecd.plotting.SinglePlotter2DStacked
,trepr.plotting.PlotterExtensions
Stacked plots of 2D data.
A stackplot creates a series of lines stacked on top of each other from a 2D dataset.
As the class is fully inherited from ASpecD for simple usage, see the ASpecD documentation of the
aspecd.plotting.SinglePlotter2DStacked
class for details.Furthermore, the class inherits all functionality from
PlotterExtensions
. See there for additional details.Examples
For convenience, a series of examples in recipe style (for details of the recipe-driven data analysis, see
aspecd.tasks
) is given below for how to make use of this class. Of course, all parameters settable for the superclasses can be set as well. The examples focus each on a single aspect.In the simplest case, just invoke the plotter with default values:
- kind: singleplot type: SinglePlotter2DStacked properties: filename: output.pdf
If you need to more precisely control the formatting of the y tick labels, particularly the number of decimals shown, you can set the formatting accordingly:
- kind: singleplot type: SinglePlotter2DStacked properties: filename: output.pdf parameters: yticklabelformat: '%.2f'
In this particular case, the y tick labels will appear with only two decimals. Note that currently, the “old style” formatting specifications are used due to their widespread use in other programming languages and hence the familiarity of many users with this particular notation.
Sometimes you want to have horizontal “zero lines” appear for each individual trace of the stacked plot. This can be achieved explicitly setting the “show_zero_lines” parameter to “True” that is set to “False” by default:
- kind: singleplot type: SinglePlotter2DStacked properties: filename: output.pdf parameters: show_zero_lines: True
In case you would like to have a g axis plotted as a second x axis on top (note that this only makes sense in case of a calibrated magnetic field axis):
- kind: singleplot type: SinglePlotter2DStacked properties: parameters: g-axis: true filename: output.pdf
-
class
trepr.plotting.
MultiPlotter1D
¶ Bases:
aspecd.plotting.MultiPlotter1D
,trepr.plotting.PlotterExtensions
1D plots of multiple datasets.
Convenience class taking care of 1D plots of multiple datasets.
As the class is inherited from ASpecD for simple usage, see the ASpecD documentation of the
aspecd.plotting.MultiPlotter1D
class for its general use.Furthermore, the class inherits all functionality from
PlotterExtensions
. See there for additional details.Examples
For convenience, a series of examples in recipe style (for details of the recipe-driven data analysis, see
aspecd.tasks
) is given below for how to make use of this class. Of course, all parameters settable for the superclasses can be set as well. The examples focus each on a single aspect.In the simplest case, just invoke the plotter with default values:
- kind: multiplot type: MultiPlotter1D properties: filename: output.pdf
To change the settings of each individual line (here the colour and label), supposing you have three lines, you need to specify the properties in a list for each of the drawings:
- kind: multiplot type: MultiPlotter1D properties: filename: output.pdf properties: drawings: - color: '#FF0000' label: foo - color: '#00FF00' label: bar - color: '#0000FF' label: foobar
Important
If you set colours using the hexadecimal RGB triple prefixed by
#
, you need to explicitly tell YAML that these are strings, surrounding the values by quotation marks.In case you would like to have a g axis plotted as a second x axis on top (note that this only makes sense in case of a calibrated magnetic field axis):
- kind: multiplot type: MultiPlotter1D properties: parameters: g-axis: true filename: output.pdf
-
class
trepr.plotting.
MultiPlotter1DStacked
¶ Bases:
aspecd.plotting.MultiPlotter1DStacked
,trepr.plotting.PlotterExtensions
Stacked 1D plots of multiple datasets.
Convenience class taking care of 1D plots of multiple datasets.
As the class is fully inherited from ASpecD for simple usage, see the ASpecD documentation of the
aspecd.plotting.MultiPlotter1DStacked
class for details.Furthermore, the class inherits all functionality from
PlotterExtensions
. See there for additional details.Examples
For convenience, a series of examples in recipe style (for details of the recipe-driven data analysis, see
aspecd.tasks
) is given below for how to make use of this class. Of course, all parameters settable for the superclasses can be set as well. The examples focus each on a single aspect.In the simplest case, just invoke the plotter with default values:
- kind: multiplot type: MultiPlotter1DStacked properties: filename: output.pdf
To change the settings of each individual line (here the colour and label), supposing you have three lines, you need to specify the properties in a list for each of the drawings:
- kind: multiplot type: MultiPlotter1DStacked properties: filename: output.pdf properties: drawings: - color: '#FF0000' label: foo - color: '#00FF00' label: bar - color: '#0000FF' label: foobar
Important
If you set colours using the hexadecimal RGB triple prefixed by
#
, you need to explicitly tell YAML that these are strings, surrounding the values by quotation marks.Sometimes you want to have horizontal “zero lines” appear for each individual trace of the stacked plot. This can be achieved explicitly setting the “show_zero_lines” parameter to “True” that is set to “False” by default:
- kind: multiplot type: MultiPlotter1DStacked properties: filename: output.pdf parameters: show_zero_lines: True
In case you would like to have a g axis plotted as a second x axis on top (note that this only makes sense in case of a calibrated magnetic field axis):
- kind: multiplot type: MultiPlotter1DStacked properties: parameters: g-axis: true filename: output.pdf