0
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 1 % PLOTHISTORY plot the history of the currently selected blocks.
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 2 %
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 3 % CALL: wb.plot
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 4 %
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 5 % M Hewitson 13-11-08
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 6 %
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 7 % $Id: plotHistory.m,v 1.9 2010/08/06 19:10:49 ingo Exp $
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 8 %
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 9 function plotHistory(varargin)
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 10
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 11 wb = varargin{1};
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 12
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 13 % Get all selected blocks
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 14 sbs = awtinvoke(wb.mp, 'getSelectedBlocks');
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 15
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 16 outvars = {};
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 17 for ii=0:sbs.size()-1
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 18 block = sbs.get(ii);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 19
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 20 % if this is a MElementWithPorts
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 21 if isa(block, 'mpipeline.canvas.MElementWithPorts')
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 22
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 23 % loop over all outputs
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 24 outports = block.getOutputs();
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 25 for kk=0:outports.size()-1
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 26 op = outports.get(kk);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 27 % get variable name
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 28 outvar = LTPDAworkbench.getWS_VarName(wb.UUID, block, op.getNumber);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 29 outvars = [outvars {outvar}];
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 30 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 31 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 32 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 33
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 34 % Check if each var exists in the workspace, and then launch in
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 35 % dotview
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 36
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 37 try
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 38 successes = 0;
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 39 for kk=1:numel(outvars)
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 40
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 41 if evalin('base', ['isa(' outvars{kk} ', ''ltpda_uoh'')'])
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 42
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 43 cmd = [outvars{kk} '.viewHistory()'];
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 44 try
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 45 evalin('base', cmd);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 46 catch err
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 47 utils.helper.err(err.message);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 48 cmd = ['plot(' outvars{kk} '.hist)'];
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 49 evalin('base', cmd);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 50 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 51 successes = successes + 1;
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 52 else
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 53 cl = evalin('base', ['class(' outvars{kk} ')']);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 54 warning('Skipping selected variable %s; it is not an LTPDA User Object with history. It is of class [%s].', outvars{kk}, cl);
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 55 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 56 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 57 catch
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 58 utils.helper.errorDlg('Unable to plot history of selected objects. Has the pipeline been executed or do you have more than one object?', 'Plot history error');
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 59 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 60
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 61 if successes ~= numel(outvars)
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 62 utils.helper.warnDlg('Not all outputs were processed. Check the MATLAB terminal for further warnings.', 'Plot history warning');
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 63 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 64 end
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
+ − 65