Mercurial > hg > ltpda
view m-toolbox/test/utils/test1_csd2tf.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 source
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % TEST csd2tf 1dim identification % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % HISTORY: 23-04-2009 L Ferraioli % Creation %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %% VERSION '$Id: test1_csd2tf.m,v 1.1 2009/04/23 10:11:26 luigi Exp $'; %% Clear clear all %% Loading spectra load ..\m-toolbox\test\mpsd.mat % load mpsd.mat first column is f then psd1, csd and psd2 f = mpsd(:,1); psd = mpsd(:,2); %% identification in z-domain % identification params params = struct('Nmaxiter',50, 'minorder',10,... 'maxorder',25, 'spolesopt',2, 'weightparam',2, 'plot',0,... 'ctp','chival','lrscond',3,'msevar',2,... 'fs',10,'dterm',0, 'spy',0, 'fullauto',1,... 'extweights', []); ostruct = utils.math.csd2tf(psd,f,params); %% Model response res = ostruct.res; poles = ostruct.poles; dterm = ostruct.dterm; pfparams.type = 'disc'; pfparams.freq = f; pfparams.fs = 10; pfparams.res = res; pfparams.pol = poles; pfparams.dterm = dterm; % response of the model filter pfr = utils.math.pfresp(pfparams); y = pfr.resp; %% Checking result figure() loglog(f,psd,'k') hold on loglog(f,y.*conj(y),'r') xlabel('Frequency [Hz]') ylabel('psd') legend('Original', 'Model') figure() loglog(f,abs(y),'k') hold on xlabel('Frequency [Hz]') ylabel('Amplitude') legend('TF Model') figure() semilogx(f,(180/pi).*unwrap(angle(y)),'k') hold on xlabel('Frequency [Hz]') ylabel('Phase Angle [Deg]') legend('TF Model') figure() semilogy(ostruct.mse) xlabel('Iteration') ylabel('MSE') legend('Mean Squared Error Progression')