view m-toolbox/test/test_ao_linfit.m @ 50:7d2e2e065cf1 database-connection-manager

Update unit tests
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Wed, 07 Dec 2011 17:24:37 +0100
parents f0afece42f48
children
line wrap: on
line source

% TEST_AO_LINFIT tests the linfit method of the AO class.
%
% M Hueller 02-03-10
%
% $Id: test_ao_linfit.m,v 1.6 2011/05/15 22:52:57 mauro Exp $
%
% function test_ao_linfit()


%% Make fake AO from polyval
nsecs = 100;
fs    = 10;

unit_list = unit.supportedUnits;
u1 = unit(cell2mat(utils.math.randelement(unit_list,1)));
u2 = unit(cell2mat(utils.math.randelement(unit_list,1)));

pl1 = plist('nsecs', nsecs, 'fs', fs, ...
  'tsfcn', 'polyval([10 1], t) + randn(size(t))', ...
  'xunits', 's', 'yunits', u1);

pl2 = plist('nsecs', nsecs, 'fs', fs, ...
  'tsfcn', 'polyval([-5 0.2], t) + randn(size(t))', ...
  'xunits', 's', 'yunits', u2);

a1 = ao(pl1);
a2 = ao(pl2);
a = scatterData(a1, a2);

%% Fit with a straight line

p11 = linfit(a1, plist(...
  ));
p12 = linfit(a1, plist(...
  'dy', 0.1));
p22 = linfit(a1, plist(...
  'dx', 0.1, 'dy', 0.1, 'P0', [0 0]));
p13 = linfit(a1, plist(...
  'dy', 0.1*ones(size(a1.y))));
p23 = linfit(a1, plist(...
  'dx', 0.1*ones(size(a1.x)), 'dy', 0.1*ones(size(a1.y)), 'P0', [0 0]));
p14 = linfit(a1, plist(...
  'dy', ao(0.1, plist('yunits', a1.yunits))));
p24 = linfit(a1, plist(...
  'dx', ao(0.1, plist(...
  'yunits', a1.xunits)), 'dy', ao(0.1, plist('yunits', a1.yunits)), 'P0', [0 0]));
p15 = linfit(a1, plist(...
  'dy', ao(0.1*ones(size(a1.y)), plist('yunits', a1.yunits))));
p25 = linfit(a1, plist(...
  'dx', ao(0.1*ones(size(a1.x)), plist('yunits', a1.xunits)), 'dy', ao(0.1*ones(size(a1.y)), plist('yunits', a1.yunits)), 'P0', [0 0]));
p26 = linfit(a1, plist(...
  'dx', 0.1, 'dy', 0.1, 'P0', ao([0 0])));
p27 = linfit(a1, plist(...
  'dx', 0.1, 'dy', 0.1, 'P0', p11));

%% Compute fit: evaluating pest

b11 = p11.eval(plist('type', 'tsdata', 'XData', a1, 'xfield', 'x'));
b12 = p12.eval(plist('XData', a1, 'xfield', 'x'));
b22 = p22.eval(a1, plist('xfield', 'x'));
b13 = p13.eval(plist('XData', a1, 'xfield', 'x'));
b23 = p23.eval(a1, plist('type', 'tsdata', 'xfield', 'x'));
b14 = p14.eval(plist('XData', a1, 'xfield', 'x'));
b24 = p24.eval(a1, plist('type', 'tsdata', 'xfield', 'x'));
b15 = p15.eval(a1, plist('xfield', 'x'));
b25 = p25.eval(plist('XData', a1, 'xfield', 'x'));
b26 = p26.eval(plist('type', 'tsdata', 'XData', a1.x));
b27 = p27.eval(plist('type', 'tsdata', 'XData', a1.x));

%% Plot fit
iplot(a1, b11, b12, b13, b14, b15, b26, b27, ...
  b22, b23, b24, b25, ...
  plist('LineStyles', {'', '--'}));

%% Remove linear trend
c = a1-b11;
iplot(c)

plot(c.hist)

%% Reproduce from history
disp('Try rebuilding')
a_out = rebuild(c);
iplot(a_out)
plot(a_out.hist)

%% Fit with a straight line

p = linfit(a, plist(...
  ));

%% Compute fit: evaluating pest

b1 = p.eval(plist('XData', a, 'xfield', 'x'));
b2 = p.eval(a, plist('xfield', 'x'));
b3 = p.eval(plist('type', 'xydata', 'XData', a.x, 'xunits', a.xunits));
b4 = p.eval(plist('XData', a.x, 'xunits', a.xunits));

%% Plot fit
iplot(a, b1, b2, b3, b4,  ...
  plist('LineStyles', {'', '--'}));

%% Fit with a straight line

p11 = linfit(a1, a2, plist(...
  ));
p12 = linfit(a1, a2, plist(...
  'dy', 0.1));
p22 = linfit(a1, a2, plist(...
  'dx', 0.1, 'dy', 0.1, 'P0', [0 0]));
p13 = linfit(a1, a2, plist(...
  'dy', 0.1*ones(size(a1.x))));
p23 = linfit(a1, a2, plist(...
  'dx', 0.1*ones(size(a1.x)), 'dy', 0.1*ones(size(a1.x)), 'P0', [0 0]));
p14 = linfit(a1, a2, plist(...
  'dy', ao(0.1, plist('yunits', a2.yunits))));
p24 = linfit(a1, a2, plist(...
  'dx', ao(0.1, plist('yunits', a1.yunits)), 'dy', ao(0.1, plist('yunits', a2.yunits)), 'P0', [0 0]));
p15 = linfit(a1, a2, plist(...
  'dy', ao(0.1*ones(size(a2.y)), plist('yunits', a2.yunits))));
p25 = linfit(a1, a2, plist(...
  'dx', ao(0.1*ones(size(a1.y)), plist('yunits', a1.yunits)), 'dy', ao(0.1*ones(size(a2.y)), plist('yunits', a2.yunits)), 'P0', [0 0]));
p26 = linfit(a1, a2, plist(...
  'dx', 0.1, 'dy', 0.1, 'P0', ao([0 0])));
p27 = linfit(a1, a2, plist(...
  'dx', 0.1, 'dy', 0.1, 'P0', p11));

%% Compute fit: evaluating pest

b11 = p11.eval(plist('type', 'xydata', 'XData', a1.y, 'xunits', a1.yunits));
b12 = p12.eval(plist('type', 'xydata', 'XData', a1.y, 'xunits', a1.yunits));
b22 = p22.eval(a1, plist('type', 'xydata'));
b13 = p13.eval(plist('type', 'xydata', 'XData', a1.y, 'xunits', a1.yunits));
b23 = p23.eval(a1, plist('type', 'xydata'));
b14 = p14.eval(plist('type', 'xydata', 'XData', a1.y, 'xunits', a1.yunits));
b24 = p24.eval(a1, plist('type', 'xydata'));
b15 = p15.eval(a1, plist('type', 'xydata'));
b25 = p25.eval(plist('type', 'xydata', 'XData', a1.y));
b26 = p26.eval(plist('type', 'xydata', 'XData', a1.y));
b27 = p27.eval(plist('type', 'xydata', 'XData', a1.y));

% Build reference object
a12 = ao(plist('xvals', a1.y, 'yvals', a2.y, ...
  'xunits', a1.yunits, 'yunits', a2.yunits));
%% Plot fit
iplot(b22, b23, b24, b15, ...
  b12, b13, b14, b11, ...
  plist('LineStyles', {'', '--'}));

%% Plot fit
iplot(b25, b26, b27, ...
  plist('LineStyles', {'', '--'}));

%% Remove linear trend
c = a12-b27;
iplot(c)

plot(c.hist)

%% Reproduce from history
disp('Try rebuilding')
a_out = rebuild(c);
iplot(a_out)
plot(a_out.hist)

% end
% END