diff m-toolbox/classes/@ssm/copy.m @ 0:f0afece42f48

Import.
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Wed, 23 Nov 2011 19:22:13 +0100
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/m-toolbox/classes/@ssm/copy.m	Wed Nov 23 19:22:13 2011 +0100
@@ -0,0 +1,46 @@
+% COPY Make copy of ssm objects depending of the second input
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%
+% DESCRIPTION: COPY Make copy of ssm objects depending of the second input
+%
+% CALL:        objs = copy(objs, [1,0]);
+%              objs = copy(objs); Second input is assumed to be 1
+%
+%  This is a transparent function and adds no history.
+% 
+% VERSION: $Id: copy.m,v 1.30 2010/08/18 19:40:52 adrien Exp $
+%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+% HISTORY:     07-08-2008 Grynagier - made second input facultative
+%              11-07-2008 Diepholz
+%                 Creation
+
+function varargout = copy(old, deepcopy)
+  
+  % begin function body
+  
+  if deepcopy
+    new = ssm.newarray(size(old));
+    new = copy@ltpda_uoh(new, old, 1);
+
+    for kk=1:numel(old)
+      new(kk).amats       = old(kk).amats;
+      new(kk).bmats       = old(kk).bmats;
+      new(kk).cmats       = old(kk).cmats;
+      new(kk).dmats       = old(kk).dmats;
+      new(kk).timestep    = old(kk).timestep;
+      new(kk).inputs      = copy(old(kk).inputs, 1);
+      new(kk).states      = copy(old(kk).states, 1);
+      new(kk).outputs     = copy(old(kk).outputs, 1);
+      new(kk).params      = copy(old(kk).params, 1);
+      new(kk).numparams   = copy(old(kk).numparams, 1);
+    end
+  else
+    new = old;
+  end
+  varargout{1} = new;
+  
+end
+
+