view m-toolbox/classes/@ssm/modelHelper_introScript.m @ 44:409a22968d5e default

Add unit tests
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Tue, 06 Dec 2011 18:42:11 +0100
parents f0afece42f48
children
line wrap: on
line source

% header script for all ssm models
%% minfo call
if utils.helper.isinfocall(varargin{:})
  varargout{1} = getInfo(varargin{3});
  doNothing = true;
else
  doNothing = false;
  
  if nargin==2
    if isa(varargin{1}, 'plist') && isa(varargin{2}, 'minfo')
      %% constructor call
      minfo_in = varargin{2};
      pl = varargin{1};
      if pl.isparam('set')
        plDefault = getDefaultPlist(pl.find('set'));
      else
        plDefault = getDefaultPlist;
      end
      if ~pl.isparam('param names')
        setNames = {};
        setValues = [];
        removePlParam = {};
        for k=1:pl.nparams
          loc_key = pl.params(k).key;
          if ~plDefault.isparam( loc_key )
            if ~strcmpi(loc_key, 'set')
              loc_value = pl.params(k).getVal;
              if ~isa(loc_value, 'double') || numel(loc_value)~=1
                warning(['### the ssm constructor tried to set the parameter ' loc_key ' as a numerical (double) physical parameter '...
                  ' because it is not in the default plist of this model. ' ...
                  'However it could not be done for the class "' class(loc_value) '" and the size [' num2str(size(loc_value)) ']. '...
                  'Please remove this parameter from your user plist, if you do not use it.'])
              else
                setNames  = [setNames  loc_key]; %#ok<AGROW>
                setValues = [setValues loc_value]; %#ok<AGROW>
                removePlParam = [removePlParam loc_key ]; %#ok<AGROW>
              end
            end
          end
        end
        pl.removeKeys(removePlParam);
        pl.combine(plist('param names', setNames, 'symbolic params', setNames, 'param values', setValues));
      end
      pl = combine(varargin{1}, minfo_in.plists, plDefault);
      varargout{2} = pl;
    elseif isa(varargin{1}, 'char') && isa(varargin{2}, 'plist')
      %% description only request
      error('description call is deprecated')
    else
       error([mfilename ' needs one input argument of class plist and one minfo, but instead input argument was : ' class(varargin{1}) ' and ' class(varargin{2})])
    end
  else
    error([mfilename ' needs two input arguments instead of ' num2str(numel(varargin))])
  end
end