Mercurial > hg > ltpda
view m-toolbox/classes/@ao/ltf_plan.m @ 20:d58813ab1b92 database-connection-manager
Update ltpda_uo.submit
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
% LTF_PLAN computes all input values needed for the LPSD and LTFE algorithms. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % DESCRIPTION: LTF_PLAN computes all input values needed for the LPSD and LTFE % algorithms. % % CALL: [f, r, b, L, K] = ltf_plan(Ndata, fs, olap, bmin, Lmin, Jdes, Kdes) % % INPUTS: Ndata - the length of the time-series to be processed % fs - the sample rate of the time-series to be processed % olap - overlap percentage, usually taken from the window function % bmin - the minimum bin number to be used. This is usually taken % from the window function. % Lmin - The minimum segment length. % Jdes - the desired number of frequencies. % Kdes - The desired number of averages. % % OUTPUTS: Each output is a vector, one value per frequency: % f - the frequency % r - frequency resolution (Hz) % b - bin number % L - segment lengths % K - number of averages % % PARAMETER LIST: % % VERSION: $Id: ltf_plan.m,v 1.6 2009/08/31 17:09:43 ingo Exp $ % % HISTORY: 19-02-2008 M Hewitson % Creation % % REFERENCE: "lpsd revisited: ltf" / S2-AEI-TN-3052 % 2008/02/07 V1.1 % G Heinzel % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % q - a vector of start indices for the segments function varargout = ltf_plan(varargin) %% ------ Check inputs ------------------------------------------------ if nargin ~= 7 || nargout ~= 5 help(mfilename) error('### Incorrect usage'); end Ndata = varargin{1}; fs = varargin{2}; olap = varargin{3}; bmin = varargin{4}; Lmin = varargin{5}; Jdes = varargin{6}; Kdes = varargin{7}; %% ------ Set up some variables ------------------------------------------- xov = (1 - olap/100); fmin = fs / Ndata * bmin; fmax = fs/2; fresmin = fs / Ndata; freslim = fresmin * (1+xov*(Kdes-1)); logfact = (Ndata/2)^(1/Jdes) - 1; %% ------ Prepare outputs ------------------------------------------- f = []; r = []; b = []; L = []; K = []; % q = []; %% ------ Loop over frequency ------------------------------------------- fi = fmin; while fi < fmax fres = fi * logfact; if fres <= freslim fres = sqrt(fres*freslim); end if fres < fresmin fres = fresmin; end bin = fi/fres; if bin < bmin bin = bmin; fres = fi/bin; end dftlen = round(fs / fres); if dftlen > Ndata dftlen = Ndata; end if dftlen < Lmin dftlen = Lmin; end nseg = round((Ndata - dftlen) / (xov*dftlen) + 1); if nseg == 1 dftlen = Ndata; end fres = fs / dftlen; bin = fi / fres; % Store outputs f = [f fi]; r = [r fres]; b = [b bin]; L = [L dftlen]; K = [K nseg]; fi = fi + fres; end %% ------ Set outputs ------------------------------------------- varargout{1} = f.'; varargout{2} = r.'; varargout{3} = b.'; varargout{4} = L.'; varargout{5} = K.'; end