Mercurial > hg > ltpda
view m-toolbox/classes/@smodel/fromExpression.m @ 38:3aef676a1b20 database-connection-manager
Keep backtrace on error
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
% FROMEXPRESSION %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % FUNCTION: fromExpression % % DESCRIPTION: Construct an smodel from an expression % % CALL: mdl = fromExpression(a, pl) % % PARAMETER: pl - plist % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% function mdl = fromExpression(mdl, pli) VERSION = '$Id: fromExpression.m,v 1.11 2011/08/17 07:01:32 hewitson Exp $'; % get smodel info ii = smodel.getInfo('smodel', 'From Expression'); % Set the method version string in the minfo object ii.setMversion([VERSION '-->' ii.mversion]); % Combine input plist with default values pl = applyDefaults(ii.plists, pli); % Set fields expr = pl.find('expression'); params = pl.find('params'); vals = pl.find('values'); xvar = pl.find('xvar'); xvals = pl.find('xvals'); % Check the contents of vals if iscell(vals) for ll=1:numel(vals) if isa(vals{ll}, 'ao') vals{ll} = vals{ll}.y; end end else if isa(vals, 'ao') vals = {vals.y}; end end % Set params and default values if ~isempty(params) mdl.params = params; if ~isempty(vals) mdl.values = vals; end end % Set x-variable if ~isempty(xvar) mdl.xvar = xvar; end % Set x-values if ~isempty(xvals) if isa(xvals, 'ao') mdl.xvals = xvals.x; else mdl.xvals = xvals; end end % Set expression mdl.expr = msym(expr); % Add history mdl.addHistory(ii, pl, [], []); % Set object properties mdl.setObjectProperties(pl, {'params', 'values', 'xvals', 'xval'}); end