Home > m > noisegenerator > ltpda_noisegen.m

ltpda_noisegen

PURPOSE ^

LTPDA_NOISEGEN uses pzm2ab and franklin to generate a time-series

SYNOPSIS ^

function varargout = ltpda_noisegen(varargin)

DESCRIPTION ^

 LTPDA_NOISEGEN uses pzm2ab and franklin to generate a time-series
 from a given pzmodel

 calls:
 >> [b, pl1, pl2] = ltpda_noisegen(pl)
 >> [b, pl1] = ltpda_noisegen(pl)
 >>  b = ltpda_noisegen(pl1, pl2)

 Inputs:
      for the first function call the parameter list has to contain:
        - nsecs
        - fs
        - pzmodel with gain

 b   - analysis object containing the resulting timeseries
 pl1 - parameter list containing the last state vector y.
 pl2 - parameter list containing the following parameters:

            - Tinit - matrix to calculate initial state vector
            - Tprop - matrix to calculate propagation vector
            - E     - matrix to calculate propagation vector
            - num   - numerator coefficients
            - den   - denominator coefficients
            - gain
            - fs    - sampling frequency
            - nsecs - number of seconds

 The following call returns a parameter list object that contains the
 default parameter values:
 >> pl = ltpda_noisegen('Params')

 A Monsky 24-07-07

 $Id: ltpda_noisegen.m,v 1.10 2007/11/09 14:07:39 ingo Exp $

CROSS-REFERENCE INFORMATION ^

This function calls: This function is called by:

SUBFUNCTIONS ^

SOURCE CODE ^

0001 function varargout = ltpda_noisegen(varargin)
0002 
0003 % LTPDA_NOISEGEN uses pzm2ab and franklin to generate a time-series
0004 % from a given pzmodel
0005 %
0006 % calls:
0007 % >> [b, pl1, pl2] = ltpda_noisegen(pl)
0008 % >> [b, pl1] = ltpda_noisegen(pl)
0009 % >>  b = ltpda_noisegen(pl1, pl2)
0010 %
0011 % Inputs:
0012 %      for the first function call the parameter list has to contain:
0013 %        - nsecs
0014 %        - fs
0015 %        - pzmodel with gain
0016 %
0017 % b   - analysis object containing the resulting timeseries
0018 % pl1 - parameter list containing the last state vector y.
0019 % pl2 - parameter list containing the following parameters:
0020 %
0021 %            - Tinit - matrix to calculate initial state vector
0022 %            - Tprop - matrix to calculate propagation vector
0023 %            - E     - matrix to calculate propagation vector
0024 %            - num   - numerator coefficients
0025 %            - den   - denominator coefficients
0026 %            - gain
0027 %            - fs    - sampling frequency
0028 %            - nsecs - number of seconds
0029 %
0030 % The following call returns a parameter list object that contains the
0031 % default parameter values:
0032 % >> pl = ltpda_noisegen('Params')
0033 %
0034 % A Monsky 24-07-07
0035 %
0036 % $Id: ltpda_noisegen.m,v 1.10 2007/11/09 14:07:39 ingo Exp $
0037 %
0038 
0039 ALGONAME = mfilename;
0040 VERSION  = '$Id: ltpda_noisegen.m,v 1.10 2007/11/09 14:07:39 ingo Exp $';
0041 
0042 % Check if this is a call for parameters
0043 if nargin == 1
0044   in = char(varargin{1});
0045   if strcmp(in, 'Params')
0046     varargout{1} = getDefaultPL();
0047     return
0048   end
0049 end
0050 
0051 % capture input variable names
0052 invars = {};
0053 ps   = [];
0054 for j=1:nargin
0055   invars = [invars cellstr(inputname(j))];
0056   if isa(varargin{j}, 'plist')
0057     ps = [ps varargin{j}];
0058   end
0059 end
0060 
0061 pl = combine(ps);
0062 
0063 % look for all parameters
0064 pzmodel = find(pl, 'pzmodel');
0065 gain    = get(pzmodel, 'gain');
0066 fs      = find(pl, 'fs');
0067 nsecs   = find(pl, 'nsecs');
0068 state   = find(pl, 'state');
0069 Tinit   = find(pl, 'Tinit');
0070 Tprop   = find(pl, 'Tprop');
0071 E       = find(pl, 'E');
0072 num     = find(pl, 'num');
0073 den     = find(pl, 'den');
0074 
0075 % get data out of aos
0076 if ~isempty(state)
0077     d     = state.data;
0078     state = d.y;
0079 end
0080 if ~isempty(Tinit)
0081     d     = Tinit.data;
0082     Tinit = d.y;
0083 end
0084 if ~isempty(Tprop)
0085     d     = Tprop.data;
0086     Tprop = d.y;
0087 end
0088 if ~isempty(E)
0089     d     = E.data;
0090     E = d.y;
0091 end
0092 if ~isempty(num)
0093     d     = num.data;
0094     num = d.y;
0095 end
0096 if ~isempty(den)
0097     d     = den.data;
0098     den = d.y;
0099 end
0100 lengden = length(den);
0101 % check calling state
0102 if isempty(pzmodel)
0103    if isempty(Tinit)
0104         error('### There is no Tinit matrix defined plist.');
0105     end
0106    gain = find(pl, 'gain');
0107   % set state vector
0108   if isempty(state)
0109     disp('There is no pzmodel and no initial state vector given, so the initial state vector will be calculated by using the given matrices.\\');
0110     % make initial state vector
0111     y = nginit(Tinit);
0112   else
0113     disp('State vector from input parameter list is used as input state.');
0114     % use input state
0115     y = state;
0116   end
0117 
0118   % propogate to make noise vector
0119   [x, yo] = ngprop(Tprop, E, num, y, fs*nsecs);
0120   state = yo;
0121 else
0122   % conversion
0123   disp('Filter coefficients are calculated from input pzmodel.');
0124   [num, den] = ngconv(pzmodel);
0125   % create matrices
0126   disp('Matrices are calculated from evaluated denominator coefficients.');
0127   [Tinit, Tprop, E] = ngsetup(den, fs);
0128 
0129   % set state vector
0130   if isempty(state)
0131     disp('Since there is no given state vector it will be calculated.');
0132     % make initial state vector
0133     y = nginit(Tinit);
0134   else
0135     disp('Since there is a state vector given it is used for further calculations.');
0136     % use input state
0137     y = state;
0138   end
0139   % propogate to make noise vector
0140   [x, yo] = ngprop(Tprop, E, num, y, fs*nsecs);
0141   state = yo;
0142 end
0143 
0144 %------------------ Build outputs
0145 % make a new history object
0146 h = history(ALGONAME, VERSION, pl);
0147 h = set(h, 'invars', invars);
0148 % build variables into data object
0149 t = x*gain;
0150 b = ao(tsdata(t,fs),h);
0151 b = setnh(b, 'name', sprintf('noisegen(%s)', b.name));
0152 
0153 state  = ao(cdata(state),h);
0154 Tinit  = ao(cdata(Tinit),h);
0155 Tprop  = ao(cdata(Tprop),h);
0156 E      = ao(cdata(E),h);
0157 num    = ao(cdata(num),h);
0158 den    = ao(cdata(den),h);
0159 if nargout == 2
0160   % build pl with 'state'
0161   pl1 = plist('state', state);
0162 end
0163 
0164 if nargout == 3
0165   % build another pl with 'Tinit', 'Tprop', 'E', 'num', 'den'
0166   pl1 = plist('state',state);
0167   pl2 = plist('Tinit',Tinit,'Tprop',Tprop,'E',E,'num',num,'den',den,'gain',gain,'fs',fs,'nsecs',nsecs);
0168 end
0169 
0170 %------------------ Pass outputs
0171 
0172 if nargout == 1
0173   varargout{1} = b;
0174 end
0175 
0176 if nargout == 2
0177   varargout{1} = b;
0178   varargout{2} = pl1;
0179 end
0180 
0181 if nargout == 3
0182   varargout{1} = b;
0183   varargout{2} = pl1;
0184   varargout{3} = pl2;
0185 end
0186 
0187 
0188 % END
0189 
0190 %--------------------------------------------------------------------------
0191 % Get default params
0192 function plo = getDefaultPL()
0193 
0194 disp('* creating default plist...');
0195 plo = plist();
0196 plo = append(plo,param('nsecs',1000));
0197 disp('* done.');
0198 
0199 
0200 % END
0201 
0202 
0203

Generated on Tue 26-Feb-2008 10:52:52 by m2html © 2003