mla_gui¶
- class mlaapi.mla_gui.ErrPanel(parent)¶
Class for having a panel around the error status field. This way we can set the background color and flash it.
- class mlaapi.mla_gui.IMPStatusBar(parent)¶
- class mlaapi.mla_gui.ImGUI(parent, settings, id=-1, title='', pos=wx.Point(-1, -1), size=wx.Size(-1, -1), style=675290688)¶
This class contains the menu bar and handles the panels.
- hide_all_panels(evt=None)¶
Note
The panels are not closed, only hidden. When a panel is shown again, it will look the same as before it was hidden.
Examples
>>> main.gui.hide_all_panels()
See also
mla_gui.ImGUI.show_panel()
- set_docksize(panel, size)¶
A dock can contain one or more docked panels. This function sets the size of the dock that contains a specified panel.
- Parameters:
panel – panel
size – integer size of the dock in pixels
Examples
>>> main.gui.set_docksize(main.message_log, 300) >>> main.gui.set_docksize(main.shell, main.gui.GetSize()[0]/2) #Use half the horizontal window size
- show_panel(panel, pos=None)¶
- Parameters:
panel – panel to show
pos – string or list of strings that specify the position. The string should represent a member function call of a AuiPaneInfo object. See the examples and the link under References.
Examples
>>> main.gui.show_panel(main.scopepanel) >>> main.gui.show_panel(main.shell) >>> main.gui.show_panel(main.scriptpanel) >>> main.gui.show_panel(main.shell, pos='Left()') >>> main.gui.show_panel(main.message_log, pos='Bottom().Dock()') >>> main.gui.show_panel(main.lockinpanel) >>> main.gui.show_panel(main.lockin_setup_panel) >>> main.gui.show_panel(main.frequency_count_panel) >>> main.gui.show_panel(main.fsweeppanel) >>> main.gui.show_panel(main.message_log, pos=('Dock()', 'Bottom()', 'Layer(1)'))
See also
mla_gui.ImGUI.hide_all_panels()
References
http://wxpython.org/Phoenix/docs/html/lib.agw.aui.framemanager.AuiPaneInfo.html
- class mlaapi.mla_gui.MyAuiManager(*args, **keys)¶
- ClosePane(pane_info)¶
Destroys or hides the pane depending on its flags.
- Parameters:
pane_info – a
AuiPaneInfo
instance.
Override because ClosePane will dock a floating pane for some reason, and we don’t want that. So we let ClosePane do its thing, and then we set the pane as floating again. Possibly there’s a better way… //Riccardo 2018-04-11
Script panel¶
- class mlaapi.scriptpanel.ScriptPanel(parent, mla, shell, scriptplot, id=-1, stdout=None, stderr=None)¶
The ScriptPanel contains a text editor and a toolbar to open, save and execute scripts.
- open_file(filename)¶
Open a file in the script editor. The file will not be executed.
- Parameters:
filename – Full path, or path relative to the system ‘mla_scripts’ folder.
Note
When a script runs, the path to the current script is stored in the variable __scriptfile__.
Note
If a file is already opened it will be closed without saving.
Examples
>>> main.scriptpanel.open_file('my_script.py') >>> main.scriptpanel.open_file('built-in emperature_test.py') >>> main.scriptpanel.open_file('c:\myscripts\myscript.py') >>> main.scriptpanel.open_file(__scriptfile__)
Scripting utilities¶
This module collects various utility functions that can be useful in the script editor in the MLA software.
- mlaapi.scriptutils.generate_filename(foldername_format='%Y-%m-%d', filename_format='%H_%M_%S')¶
Generate the complete path to a new file in the user data folder containing the data as folder name and time as filename. New subfolders are created if necessary.
- Parameters:
foldername_format – string, will be passed to time.strftime() to generate the folder name
filename_format – string, will be passed to time.strftime() to generate the file name
- Returns:
The full path to a new file.
- Return type:
string
Examples
>>> scriptutils.generate_filename() + '.png' 'C:\IMP Sessions and Settings\sessions\2015-09-04\08_45_30.png' >>> scriptutils.generate_filename(foldername_format='sample_1', filename_format=rig2_%Y-%m-%d__%H_%M_%S) + '.txt' 'C:\IMP Sessions and Settings\sessions\sample_1\rig2_2015-09-04__08_56_37.txt'
Shell panel¶
- class mlaapi.impgui.ShellPanel(parent, id=-1)¶
Panel that contains a python shell.
- add_text(txt)¶
Adds a text to the prompt of the python shell. The text command is not executed.
- Parameters:
txt – string
Examples
>>> main.shell.add_text('mla.run_calibration_sequence()')
- mlaapi.impgui.flash_color(widget, color='yes', time=0.8, reset_color='#FFFFFF')¶
Change background color of a wx widget for a certain amount of time
- Parameters:
widget (a wx window object (e.g. ex.TextCtrl)) –
color (string) – ‘yes’ (default) for a green color ‘no’ for red or any argument accepted by widget.SetBackgroundColour
time (float) – Time in seconds before resetting color
reset_color (color) – Color which will be set after time (default: “#FFFFFFF”)
Lockin setup panel¶
Oscilloscope panel¶
- class mlaapi.scopepanel.Marker(channel: int, x: float, value: float = nan, marker_style: matplotlib.markers.MarkerStyle = <matplotlib.markers.MarkerStyle object at 0x000000000FD7A3A0>, line: Union[matplotlib.lines.Line2D, NoneType] = None, unit_x: str = '', unit_value: str = '')¶
- class mlaapi.scopepanel.PlotPanel(parent, eh, name, position, layer, n_channels, n_lockin_ports, id=-1)¶
Class for the Oscilloscope plot panel with time and spectrim plots.
- set_limits(x1_min, x1_max, y1_min, y1_max, x2_min, x2_max, y2_min, y2_max)¶
Set the axes limits of the time and freqeuncy plots.
- Parameters:
x1_min – float [ms]
x1_max – float [ms]
y1_min – float [V]
y1_max – float [V]
x2_min – float [kHz]
x2_max – float [kHz]
y2_min – float [dBV]
y2_max – float [dBV]
Examples
>>> main.scopepanel.set_limits(0, 0.1, -1, 1, 0, 200, -140, 10)
Lockin plot panel¶
- class mlaapi.lockin_plotpanel.Frequency_counting_panel(parent, eh, name, position, layer, n_channels, id=-1)¶
- set_subplot_layout(nr, nc)¶
Set how many rows and columns of subplots the panel should have.
- Parameters:
nrows – integer number of rows
ncols – integer number of columns
Examples
>>> main.lockinpanel.set_subplot_layout(nrows=2, ncols=2)
- class mlaapi.lockin_plotpanel.LockinPlotPanel(parent, eh, name, position, layer, n_channels, id=-1)¶
- class mlaapi.lockin_plotpanel.PlotPanel(parent, eh, name, position, layer, n_channels, id=-1)¶
Class for handling lockin plots
- set_axis_properties(row, col, tone_indices=None, quantity='Amplitude', yscale_type='Linear', ymin=None, ymax=None, legend_pos=-1, history_length=30, title='')¶
Set the properies of one of the subplots in the plot panel.
- Parameters:
row – integer, identifies which subplot to configure
col – integer, identifies which subplot to configure
tone_indices – list of integers, set which tones to plot
quantity – “Amplitude”, “Phase”, “I” or “Q”, see table below
yscale_type – “Linear”, Log” or “Wrap”, see table below
ymin – float, minimum value of the y-axis
ymax – float, maximum value of the y-axis
legend_pos – integer -1-10, position of the legend, see table below
history_length – float [seconds], how long history to plot (i.e. the scale of the x-axis)
quantity
Description
Amplitude
amplitude
Phase
phase
I
In-phase component
Q
Quadrature-phase component
yscale_type
Description
Linear
Linear
Log
Logarithmic
Wrap
Wrap at limits
legend_pos
Description
-1
No legend
0
best
1
upper right
2
upper left
3
lower left
4
lower right
5
right
6
center left
7
center right
8
lower center
9
upper center
10
center
Examples
>>> main.lockinpanel.set_axis_properties(row=0, col=0, tone_indices = [1, 3, 7], quantity = "Amplitude", yscale_type = "Log", ymin = 1e-6, ymax = 10, legend_pos = 1)
- set_subplot_layout(nrows=None, ncols=None)¶
Set how many rows and columns of subplots the panel should have.
- Parameters:
nrows – integer number of rows
ncols – integer number of columns
Examples
>>> main.lockinpanel.set_subplot_layout(nrows=2, ncols=2)
- class mlaapi.lockin_plotpanel.PlotPanelBase(parent, eh, name, position, layer, id=-1)¶
- request_draw()¶
Queue new draw only if previous request is done. Safe to call from non-main thread.
- class mlaapi.lockin_plotpanel.UserPlotPanel(parent, eh, name, position, layer, id=-1)¶
Line colors¶
The colors in the “Lockin history” plot are selected from a predefined list to ensure maximal color contrast between each line. However, depending on the physical or logical topology of the measurement setup other color schemes may be desired. To edit the colors, set the mla_globals.lockin_colors variable from the shell or a script. Below are a few examples:
# Cycle the colors red, green, blue, cyan, magenta, yellow, white
mla_globals.lockin_colors = 'rgbcmyw'
# Cycle the colors red, green, blue
mla_globals.lockin_colors = ('#ff0000','#00ff00', '#0000ff')
# Cycle the colors cyan, magenta, yellow
mla_globals.lockin_colors = ((0, 1, 1), (1, 0, 1), (1, 1, 0))
# Get a unique color for each frequency from the jet colormap. See all available colormaps here:
# http://matplotlib.org/examples/color/colormaps_reference.html
mla_globals.lockin_colors = matplotlib.cm.jet(np.linspace(0,1,mla.lockin.nr_input_freq))