Mercurial > hg > ltpda
view m-toolbox/test/test_mdc1_conv2acc_utn.m @ 31:a26669b59d7e database-connection-manager
Update LTPDAworkbench
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
% MDC1 Conversion to acceleration %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Test script for the MDC1 conversion to acceleration of IFO data % % $Id: test_mdc1_conv2acc_utn.m,v 1.2 2009/03/02 15:53:46 luigi Exp $ %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %% Clear clear all %% Loading data currPath = cd; cd 'C:\Dati\mock_data\interferometer\'; j=1; fs = 10; disp(sprintf('*** Reading data %d', j)); in = load(sprintf('mockdata_16_48_17_11_2007_%d.dat', j)); d1 = in(:,2); d12 = in(:,3); % Build O1 eval('ts = tsdata(d1, fs);'); eval(sprintf('o1_%d = ao(ts);', j)); eval(sprintf('o1_%d = setName(o1_%d, ''o1'');', j, j)); eval(sprintf('o1_%d = setXunits(o1_%d, ''s'');', j, j)); eval(sprintf('o1_%d = setYunits(o1_%d, ''m'');', j, j)); % Build O12 eval('ts = tsdata(d12, fs);'); eval(sprintf('o12_%d = ao(ts);', j)); eval(sprintf('o12_%d = setName(o12_%d, ''o12'');', j, j)); eval(sprintf('o12_%d = setXunits(o12_%d, ''s'');', j, j)); eval(sprintf('o12_%d = setYunits(o12_%d, ''m'');', j, j)); global LTPDAinvar LTPDAinvar = { o1_1 , 1 , 'From file';... o12_1 , 1 , 'From file'}; cd(currPath) %% ============================================================= channel1 = LTPDAinvar{1,1}; channel2 = LTPDAinvar{2,1}; %% CH1 = channel1.lpsd; CH2 = channel2.lpsd; iplot(CH1) iplot(CH2) %% DRAG FREE rat1pl = plist('NUM', [0.0004659;0.1349;4.37;0.8304;0.07449;0.002978;4.403e-005], 'DEN', [1;5.046;9.609;11.05;0.01221;3.401e-006;0]); control1 = mdc1_ifo2cont_utn(channel1,rat1pl); %% retarded actuaction - thrusters: retard1pl = plist('TAU', 0.1, 'DELTAT', 0.315, 'FS', 10, 'TOL', 1e-007, 'AMP', 1); actuation1 = mdc1_cont2act_utn(control1,retard1pl); %% LOW FREQ SUSP rat2pl = plist('NUM', [-2.726e-007;1.665e-005;1.303e-007;8.381e-010], 'DEN', [1;0.2189;0.01922;0.0007803;0]); control2 = mdc1_ifo2cont_utn(channel2,rat2pl); %% retarded actuaction - electrical actuators: retard2pl = plist('TAU', 0.01, 'DELTAT', 0.305, 'FS', 10, 'TOL', 1e-007, 'AMP', 1); actuation2 = mdc1_cont2act_utn(control2,retard2pl); %% Free dynamics: plfd = plist('pstiff1', -1.3e-6,'pstiff2', -2e-6,'cross_talk', -1e-4,'METHOD', 'PARFIT'); freeDynamics = mdc1_ifo2acc_fd_utn(channel1,channel2,plfd); %% Output output1 = freeDynamics.index(1) + actuation1; output2 = freeDynamics.index(2) + actuation2; % output1 = freeDynamics(1) + control1; % output2 = freeDynamics(2) + control2; %% ****************************************** % plotting output psd psd1 = output1.lpsd; psd2 = output2.lpsd; iplot(psd1) iplot(psd2) %% ====================== More checks ===================================== %% Extracting filters miir1Obj = find(control1.procinfo,'CONT_FILTER'); retard1 = find(actuation1.procinfo,'ACT_FILTER'); miir2Obj = find(control2.procinfo,'CONT_FILTER'); retard2 = find(actuation2.procinfo,'ACT_FILTER'); %% Checking controllers % frequencies f = logspace(-6,log10(5),300); % f = logspace(-6,0,300); f = f.'; % response of continuous drag free Rcdf = resp(rat1Obj,f); Rcdf.setName('Continuous DF'); % response of discrete drag free tRddf = resp(miir1Obj,plist('f',f)); Rddf = tRddf(1); for ii = 2:numel(tRddf) Rddf = Rddf + tRddf(ii); end Rddf.setName('Discrete DF'); % response of continuous low freq susp Rclfs = resp(rat2Obj,f); Rclfs.setName('Continuous LFS'); % response of discrete low freq susp tRdlfs = resp(miir2Obj,plist('f',f)); Rdlfs = tRdlfs(1); for ii = 2:numel(tRdlfs) Rdlfs = Rdlfs + tRdlfs(ii); end Rdlfs.setName('Discrete LFS'); % response of actuation filter 1 Ract1 = resp(retard1,plist('f',f)); Ract1.setName('Thrusters'); % response of actuation filter 2 Ract2 = resp(retard2,plist('f',f)); Ract1.setName('Actuators'); %% Plotting reposnse % Continuous and discrete controllers pl = plist('Legends', {'cH_{df}','dH_{df}','cH_{lfs}','dH_{lfs}'},... 'LineStyles', {'', '--', '', '--'}); iplot(Rcdf,Rddf,Rclfs,Rdlfs,pl) % Ratio between discrete and continuous pl = plist('Legends', {'dH_{df}/cH_{df}','dH_{lfs}/cH_{lfs}'},... 'YScales',{'All','lin'}); iplot(Rddf./Rddf,Rdlfs./Rclfs,pl) % Actuators pl = plist('Legends', {'Thrusters','El. Act.'},... 'YScales',{'All','lin'}); iplot(Ract1,Ract2,pl) % discrete controllers + actuation pl = plist('Legends', {'dH_{df}','dH_{df} + Tht','dH_{lfs}','dH_{lfs} + Act'},... 'LineStyles', {'', '--', '', '--'}); iplot(Rddf,Rddf.*Ract1,Rdlfs,Rdlfs.*Ract2,pl) %% Calculating transfer functions % controller *** pl = plist('Nfft', fs*1000); tfdf = tfe(channel1,control1,pl); tflfs = tfe(channel2,control2,pl); plpl = plist('Legends', {'H_{df}','H_{df} data','H_{lfs}','H_{lfs} data'},... 'LineStyles', {'', '--', '', '--'}); iplot(Rddf,tfdf(1,2),Rdlfs,tflfs(1,2),plpl) % Actuation *** pl = plist('Nfft', fs*1000); tfact1 = tfe(control1,actuation1,pl); tfact2 = tfe(control2,actuation2,pl); plpl = plist('Legends', {'Tht','Tht data','El Act','El Act data'},... 'LineStyles', {'', '--', '', '--'}); iplot(Ract1,tfact1(1,2),Ract2,tfact2(1,2),plpl) % Free Dynamics TFs *** pl = plist('Nfft', fs*10000); tffd1 = tfe(channel1,freeDynamics(1),pl); tffd2 = tfe(channel2,freeDynamics(2),pl); % Theorethical % w1 = -1.3e-6; % w2 = -2e-6; % D1 = -1e-4; % s = 2.*pi.*1i.*f; % FD1 = s.^2 + w1; % FD2 = -D1.*s.^2 + w2 - w1 - D1*w2 + s.^2 + w2; FD1 = ao(plist('fsfcn', '(2.*pi.*1i.*f).^2 + -1.3e-6', 'f', f)); FD2 = ao(plist('fsfcn', '-(-1e-4).*(2.*pi.*1i.*f).^2 + (-2e-6) - (-1.3e-6) - (-1e-4)*(-2e-6) + (2.*pi.*1i.*f).^2 + (-2e-6)', 'f', f)); plpl = plist('Legends', {'FD1','FD1 data','FD2','FD2 data'},... 'LineStyles', {'', '--', '', '--'}); iplot(abs(FD1),abs(tffd1(1,2)),abs(FD2),abs(tffd2(1,2)),plpl)