Mercurial > hg > ltpda
view m-toolbox/classes/@matrix/matrix.m @ 24:056f8e1e995e database-connection-manager
Properly record history in fromRepository constructors
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | a71a40911c27 |
children |
line wrap: on
line source
% MATRIX constructor for matrix class. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % DESCRIPTION: MATRIX constructor for matrix class. % % CONSTRUCTOR: % % fb = matrix() - creates an empty matrix object % fb = matrix(objs) - construct from an array of objects % fb = matrix(pl) - create a matrix object from a parameter list % % <a href="matlab:utils.helper.displayMethodInfo('matrix', 'matrix')">Parameters Description</a> % % VERSION: $Id: matrix.m,v 1.49 2011/08/23 13:50:46 hewitson Exp $ % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% classdef matrix < ltpda_uoh %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Property definition % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %---------- Public (read/write) Properties ---------- properties objs = []; % objects in matrix end %---------- Protected read-only Properties ---------- properties (SetAccess = protected) end %---------- Private Properties ---------- properties (GetAccess = protected, SetAccess = protected) end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Check property setting % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Constructor % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods function obj = matrix(varargin) callerIsMethod = utils.helper.callerIsMethod; import utils.const.* utils.helper.msg(msg.OMNAME, 'running %s/%s', mfilename('class'), mfilename); % Collect all matrix objects [mats, invars, rest] = utils.helper.collect_objects(varargin(:), 'matrix'); if isempty(rest) && ~isempty(mats) % Do copy constructor and return utils.helper.msg(msg.OPROC1, 'copy constructor'); obj = copy(mats, 1); for kk=1:numel(obj) obj(kk).addHistory(matrix.getInfo('matrix', 'None'), [], [], obj(kk).hist); end return end switch nargin case 0 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%% no input %%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% utils.helper.msg(msg.OPROC1, 'empty constructor'); obj.addHistory(matrix.getInfo('matrix', 'None'), plist(), [], []); case 1 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%% one input %%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% if ischar(varargin{1}) %%%%%%%%%% pzm = matrix('foo.mat') %%%%%%%%%% %%%%%%%%%% pzm = matrix('foo.xml') %%%%%%%%%% utils.helper.msg(msg.OPROC1, 'constructing from file %s', varargin{1}); obj = fromFile(obj, varargin{1}); elseif isstruct(varargin{1}) %%%%%%%%%% r = matrix(struct) %%%%%%%%%% utils.helper.msg(msg.OPROC1, 'constructing from struct'); obj = fromStruct(obj, varargin{1}); elseif isa(varargin{1}, 'ltpda_uoh') %%%%%%%%%% r = matrix(<ltpda_uoh-objects>) %%%%%%%%%% obj = obj.fromInput(plist('objs', varargin), callerIsMethod); elseif isnumeric(varargin{1}) %%%%%%%%%% r = matrix(doubleArray) %%%%%%%%%% obj = obj.fromValues(plist('values', varargin{1}), callerIsMethod); elseif isa(varargin{1}, 'plist') %%%%%%%%%% r = matrix(plist) %%%%%%%%%% pl = varargin{1}; if pl.isparam('filename') utils.helper.msg(msg.PROC2, 'constructing from file %s', pl.find('filename')); obj = obj.fromFile(pl); elseif pl.isparam('hostname') || pl.isparam('conn') utils.helper.msg(msg.PROC2, 'constructing from repository %s', pl.find('hostname')); obj = obj.fromRepository(pl); elseif pl.isparam('objs') obj = obj.fromInput(pl, callerIsMethod); elseif pl.isparam('plist') obj = matrix(pl.find('plist')); elseif pl.isparam('built-in') utils.helper.msg(msg.OPROC1, 'constructing from built-in model'); obj = fromModel(obj, pl); elseif pl.isparam('csd') utils.helper.msg(msg.PROC2, 'constructing from csd %s', char(pl.find('csd'))); obj = obj.fromCSD(pl); elseif pl.isparam('model') utils.helper.msg(msg.PROC2, 'constructing Multichannel Zero Mean Gaussian Noise %s', char(pl.find('model'))); obj = obj.MultiChannelNoise(pl); elseif pl.isparam('values') obj = obj.fromValues(pl, callerIsMethod); else obj.setProperties(pl); obj.addHistory(matrix.getInfo('matrix', 'None'), pl, [], []); end else error('### Unknown single argument constructor.'); end case 2 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%% two inputs %%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% if isa(varargin{1}, 'ltpda_uoh') && isa(varargin{2}, 'ltpda_uoh') %%%%%%%%%% f = matrix(a1, a2) %%%%%%%%%% utils.helper.msg(msg.OPROC1, 'retrieve from repository'); obj = obj.fromInput(plist('objs', varargin), callerIsMethod); elseif (isa(varargin{1}, 'database') || isa(varargin{1}, 'java.sql.Connection')) ... && isnumeric(varargin{2}) %%%%%%%%%% f = matrix(<database-object>, [IDs]) %%%%%%%%%% utils.helper.msg(msg.OPROC1, 'retrieve from repository'); obj = obj.fromRepository(plist('conn', varargin{1}, 'id', varargin{2})); elseif isa(varargin{1}, 'matrix') && isa(varargin{2}, 'plist') && isempty(varargin{2}.params) %%%%%%%%%% f = matrix(matrix-object, <empty plist>) %%%%%%%%%% obj = matrix(varargin{1}); elseif isa(varargin{1}, 'org.apache.xerces.dom.DeferredElementImpl') && ... isa(varargin{2}, 'history') %%%%%%%%%% obj = matrix(DOM node, history-objects) %%%%%%%%%% obj = fromDom(obj, varargin{1}, varargin{2}); elseif isnumeric(varargin{1}) && iscell(varargin{2}) %%%%%%%%%% r = matrix(doubleArray, cellArray) %%%%%%%%%% obj = matrix(plist('values', varargin{1}, 'yunits', varargin{2})); elseif isa(varargin{1}, 'ltpda_uoh') && isa(varargin{2}, 'plist') %%%%%%%%%%% matrix(<ltpda_uoh>-object, plist-object) %%%%%%%%%% % always recreate from plist if it contains 'objs' key % If we are trying to load from file, and the file exists, do % that. Otherwise, copy the input object. if varargin{2}.isparam('filename') if exist(fullfile('.', find(varargin{2}, 'filename')), 'file')==2 obj = matrix(varargin{2}); else obj = matrix(varargin{1}); end else if isparam(varargin{2}, 'objs') obj = matrix(varargin{2}); else obj = obj.fromInput(combine(plist('objs', varargin{1}), varargin{2}), callerIsMethod); end end else error('### Unknown 2 argument constructor.'); end otherwise %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%% any input %%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% [pls, mat_invars, rest] = utils.helper.collect_objects(varargin, 'plist'); pl = combine(plist('objs', rest), pls); obj = obj.fromInput(pl, callerIsMethod); end end % End constructor end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Methods (static) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods (Static) function mdls = getBuiltInModels(varargin) mdls = ltpda_uo.getBuiltInModels('matrix'); end function out = VEROUT() out = '$Id: matrix.m,v 1.49 2011/08/23 13:50:46 hewitson Exp $'; end function ii = getInfo(varargin) ii = utils.helper.generic_getInfo(varargin{:}, 'matrix'); end function out = SETS() out = [SETS@ltpda_uoh, ... {'From Input'}, ... {'MultiChannel Noise'}, ... {'From CSD'}, ... {'From Values'}]; end function plout = getDefaultPlist(set) persistent pl; persistent lastset; if exist('pl', 'var')==0 || isempty(pl) || ~strcmp(lastset, set) pl = matrix.buildplist(set); lastset = set; end plout = pl; end function out = buildplist(set) if ~utils.helper.ismember(lower(matrix.SETS), lower(set)) error('### Unknown set [%s]', set); end out = plist(); out = matrix.addGlobalKeys(out); out = buildplist@ltpda_uoh(out, set); switch lower(set) case 'default' p = param({'shape', 'Specify the shape of the resulting matrix.'}, paramValue.EMPTY_DOUBLE); out.append(p); p = param({'objs', 'Matrix of user objects.'}, paramValue.EMPTY_DOUBLE); out.append(p); case 'from input' p = param({'shape', 'Specify the shape of the resulting matrix.'}, paramValue.EMPTY_DOUBLE); out.append(p); p = param({'objs', 'Matrix of user objects.'}, paramValue.EMPTY_DOUBLE); out.append(p); case 'from csd' % CSD p = param({'csd','A matrix of fsdata AOs containing the cross spectral density matrix elements.'}, paramValue.EMPTY_DOUBLE); out.append(p); % Target Objects p = param({'targetobj', ['Choose the type of output objects:<ul>',... '<li>''miir'' output a matrix containing filterbanks of parallel miir filters</li>',... '<li>''parfrac'' output a matrix containing parafracs objects</li>']}, ... {1, {'miir','parfrac'}, paramValue.OPTIONAL}); out.append(p); % Fs p = param({'fs', 'The sampling frequency of the discrete filters.'}, {1, {1}, paramValue.OPTIONAL}); out.append(p); % Max Iter p = param({'MaxIter', 'Maximum number of fit iterations.'}, {1, {50}, paramValue.OPTIONAL}); out.append(p); % Pole type p = param({'PoleType',['Choose the pole type for fitting initialization:<ul>',... '<li>1 == use real starting poles</li>',... '<li>2 == generates complex conjugate poles of the type <tt>a.*exp(theta*pi*j)</tt> with <tt>theta = linspace(0,pi,N/2+1)</tt></li>',... '<li>3 == generates complex conjugate poles of the type <tt>a.*exp(theta*pi*j)</tt> with <tt>theta = linspace(0,pi,N/2+2)</tt></li></ul>']}, ... {1, {1, 2, 3}, paramValue.SINGLE}); out.append(p); % Min order p = param({'MinOrder','Minimum order to fit with.'}, {1, {7}, paramValue.OPTIONAL}); out.append(p); % Max Order p = param({'MaxOrder','Maximum order to fit with.'}, {1, {35}, paramValue.OPTIONAL}); out.append(p); % Weights p = param({'Weights',['Choose weighting for the fit:<ul>',... '<li> 1 == equal weights for each point</li>',... '<li> 2 == weight with <tt>1/abs(model)</tt></li>',... '<li> 3 == weight with <tt>1/abs(model).^2</tt></li>',... '<li> 4 == weight with inverse of the square mean spread of the model</li></ul>']}, {2, {1 2 3 4}, paramValue.SINGLE}); out.append(p); % Plot p = param({'Plot', 'Plot results of each fitting step.'}, paramValue.TRUE_FALSE); p.val.setValIndex(2); out.append(p); % MSE Vartol p = param({'MSEVARTOL', ['Mean Squared Error Variation - Check if the realtive variation of the mean squared error is<br>',... 'smaller than the value specified. This option is useful for finding the minimum of Chi squared.']}, ... {1, {1e-2}, paramValue.OPTIONAL}); out.append(p); % FIT TOL p = param({'FITTOL',['Mean Squared Error Value - Check if the mean squared error value <br>',... ' is lower than the value specified.']}, {1, {1e-2}, paramValue.OPTIONAL}); out.append(p); % UseSym p = param({'UseSym', ['Use symbolic calculation in eigen-decomposition.<ul>'... '<li>''on'' - uses symbolic math toolbox calculation<br>'... 'for poles stabilization</li>'... '<li>''off'' - perform double-precision calculation<br>'... 'for poles stabilization</li>']}, {1, {'on','off'}, paramValue.SINGLE}); out.append(p); % Iunits p = param({'iunits', 'The unit to set as input unit for the output filters'}, paramValue.EMPTY_STRING); out.append(p); % Ounits p = param({'ounits', 'The unit to set as output unit for the output filters'}, paramValue.EMPTY_STRING); out.append(p); case 'multichannel noise' % Model p = param({'model','A matrix of filterbanks or parfarcs objects, modeling multichannel system response.'}, paramValue.EMPTY_DOUBLE); out.append(p); % Nsecs p = param({'nsecs', 'Number of seconds in the desired noise data series.'}, {1, {1}, paramValue.OPTIONAL}); out.append(p); % Fs p = param({'fs', 'The sampling frequency of the noise data series.'}, {1, {1}, paramValue.OPTIONAL}); out.append(p); % Yunits p = param({'yunits','Unit on Y axis.'}, paramValue.STRING_VALUE('m')); out.append(p); case 'from values' % Values p = param({'values', 'Each value will create a single AO.'}, paramValue.EMPTY_DOUBLE); out.append(p); % Yunits p = param({'yunits', 'Y-unit for the AOs which are built from the values'}, paramValue.EMPTY_CELL); out.append(p); % Names p = param({'names', 'Names for the AOs which are built from the values'}, paramValue.EMPTY_CELL); out.append(p); end end % function out = getDefaultPlist(varargin) function obj = initObjectWithSize(n,m) obj = matrix.newarray([n m]); end end % End static methods %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Methods (static, private) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods (Static, Access=private) varargout = elementOp(varargin) end % End static, private methods %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Methods (static, hidden) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods (Static = true, Hidden = true) varargout = loadobj(varargin) varargout = update_struct(varargin); end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Methods (public) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods varargout = char(varargin) varargout = display(varargin) varargout = copy(varargin) out = det(varargin) out = inv(varargin) varargout = minus(varargin) varargout = plus(varargin) varargout = rdivide(varargin) varargout = times(varargin) varargout = mtimes(varargin) varargout = transpose(varargin) varargout = ctranspose(varargin) varargout = filter(varargin) varargout = conj(varargin) varargout = nrows(varargin) varargout = ncols(varargin) varargout = osize(varargin) varargout = setObjs(varargin) varargout = getObjectAtIndex(varargin) end methods (Hidden = true) varargout = attachToDom(varargin) end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Methods (protected) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods (Access = protected) varargout = fromInput(varargin) varargout = fromStruct(varargin) varargout = fromDom(varargin) end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Methods (private) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% methods (Access = private) % Constructors varargout = wrapper(varargin) a = fromCSD(a, pli) a = MultiChannelNoise(a, pli) end end % End classdef