Mercurial > hg > ltpda
view m-toolbox/classes/@pzmodel/fromStruct.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
% FROMSTRUCT creates from a structure a PZMODEL object. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % FUNCTION: fromStruct % % DESCRIPTION: Creates from a structure a PZMODEL object. % % CALL: obj = fromStruct(obj, struct) % % VERSION: $Id: fromStruct.m,v 1.6 2011/03/28 17:02:28 ingo Exp $ % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% function objs = fromStruct(objs, obj_struct) % Get the class name of the object. cn = class(objs); % Define function name for updating the structure fcnName = ([cn '.update_struct']); % Initialize output objects objs = feval([cn '.initObjectWithSize'], size(obj_struct, 1), size(obj_struct, 2)); % Update structure (if necessary) for kk = 1:numel(obj_struct) % Get structure version if isfield(obj_struct, 'tbxver') tbxVer = obj_struct(kk).tbxver; else tbxVer = '1.0'; end % Update structure up_struct = feval(fcnName, obj_struct(kk), tbxVer); % Call super-class objs(kk) = fromStruct@ltpda_tf(objs(kk), up_struct); % Set 'poles' if isfield(up_struct, 'poles') objs(kk).poles = utils.helper.getObjectFromStruct(up_struct.poles); end % Set 'zeros' if isfield(up_struct, 'zeros') objs(kk).zeros = utils.helper.getObjectFromStruct(up_struct.zeros); end % Set 'gain' if isfield(up_struct, 'gain') objs(kk).gain = up_struct.gain; end % Set 'delay' if isfield(up_struct, 'delay') objs(kk).delay = up_struct.delay; end end end