File MIES_Browser_Plotter.ipf¶
Functions for plotting DataBrowser/Sweepbrowser Graphs.
Functions
-
static std::tuple<string, variable> GetOodDAQFullRange(TiledGraphSettings *tgs, WaveText oodDAQRegions)¶
Get all selected oodDAQ regions and the total X range in ms.
-
variable CreateTiledChannelGraph(string graph, wave config, variable sweepNo, wave numericalValues, WaveText textualValues, TiledGraphSettings *tgs, dfref sweepDFR, WaveText axisLabelCache, variable *traceIndex, string experiment, wave channelSelWave, BufferedDrawInfo *bdi = defaultValue)¶
Create a vertically tiled graph for displaying AD and DA channels.
For preservering the axis scaling callers should do the following:
WAVE ranges = GetAxesRanges(graph) CreateTiledChannelGraph() SetAxesRanges(graph, ranges)
See also
- Parameters:
graph – window
config – DAQ config wave
sweepNo – number of the sweep
numericalValues – numerical labnotebook wave
textualValues – textual labnotebook wave
tgs – settings for tuning the display, see TiledGraphSettings
sweepDFR – top datafolder to splitted 1D sweep waves
axisLabelCache – store existing vertical axis labels
traceIndex – [internal use only] set to zero on the first call in a row of successive calls
experiment – name of the experiment the sweep stems from
channelSelWave – channel selection wave
bdi – [optional, default = n/a] initialized BufferedDrawInfo structure, when given draw calls are buffered instead for later execution
-
variable TiledGraphAccelerateDraw(BufferedDrawInfo *bdi)¶
Runs through all graph groups in the json and appends them to the graph.
-
static variable TiledGraphAccelerateAppendTracesImpl(string w, string v, string h, variable r, variable g, variable b, wave y, WaveText t, WaveRefWave d)¶
Appends a group of traces to a graph, properties w to b must be constant for the group.
- Parameters:
w – [in] name of graph window
v – [in] name of vertical axis
h – [in] name of horizontal axis
r – [in] red color component
g – [in] green color component
b – [in] blue color component
y – [in] 1D wave with indices into wave d for the actual plot data
t – [in] 1D wave with trace names, same size as y
d – [in] wave reference wave with plot data
-
variable PostPlotTransformations(string win, variable mode, WaveOrNull additionalData = defaultValue)¶
Perform common transformations on the graphs traces.
Keeps track of all internal details wrt. to the order of the operations, backups, etc.
Needs to be called after adding/removing/updating sweeps via AddSweepToGraph(), RemoveSweepFromGraph(), UpdateSweepInGraph().
- Parameters:
win – graph with sweep traces
mode – update mode, one of PostPlotUpdateModes
additionalData – [optional, defaults to invalid wave reference] additional data for subsequent users. Currently supported:
POST_PLOT_REMOVED_SWEEPS -> OVS indizes of the removed sweep
POST_PLOT_ADDED_SWEEPS -> OVS indizes of the added sweep Use OVS_GetSweepAndExperiment() to convert an index into a sweep/experiment pair.
-
static variable InitPostPlotSettings(string win, PostPlotSettings *pps)¶
-
static variable AverageWavesFromSameYAxisIfReq(string graph, variable averagingEnabled, dfref averageDataFolder, variable hideSweep)¶
Average traces in the graph from the same y-axis and append them to the graph.
- Parameters:
graph – graph with traces create by CreateTiledChannelGraph
averagingEnabled – switch if averaging is enabled or not
averageDataFolder – permanent datafolder where the average waves can be stored
hideSweep – are normal channel traces hidden or not
-
static variable ZeroTracesIfReq(string graph, WaveTextOrNull traces, variable zeroTraces)¶
Zero all given traces.
-
static variable LayoutGraph(string win, TiledGraphSettings *tgs)¶
Layout the DataBrowser/SweepBrowser graph.
Takes also care of adding free axis for the headstage display.
Concept:
Block [#]: One axis with surrounded GRAPH_DIV_SPACING space
Slot [#]: Unit of vertical space, a block can occupy multiple slots
We have 100% space for all axes
AD axes should occupy four times the space of DA/TTL channels
So DA/TTL occupy one slot, AD occupy four slots
Between each axes we want GRAPH_DIV_SPACING clear space
Count the number of vertical blocks and slots to be used
Derive the space per slot
For overlay channels we reserve only one slot times slot multiplier per channel
The display order from top to bottom:
Associated channels (above: DA, below: AD) with increasing headstage number
Unassociated channels (above: DA, below: AD)
TTL channels
For overlayed channels we have up to three blocks (DA, AD, TTL) in that order.
-
static variable TweakAxes(string graph, TiledGraphSettings *tgs, WaveText allVerticalAxes, WaveText allHorizontalAxes)¶
-
static variable EnableAxis(string graph, WaveText axes, variable spacePerSlot, variable *first, variable *last)¶
Helper function for LayoutGraph()
Enables the given axis between [last - spacePerSlot, last] and updates both on return. Expects
last
to be 1.0 on the first call.