Download code

From LiteratePrograms

Jump to: navigation, search

Back to Matlab_regressions

Download for Windows: single file, zip

Download for UNIX: single file, zip, tar.gz, tar.bz2

test_trivial_estimation.m

 1 % Copyright (c) 2008 the authors listed at the following URL, and/or
 2 % the authors of referenced articles or incorporated external code:
 3 % http://en.literateprograms.org/Matlab_regressions?action=history&offset=20080704101939
 4 % 
 5 % Permission is hereby granted, free of charge, to any person obtaining
 6 % a copy of this software and associated documentation files (the
 7 % "Software"), to deal in the Software without restriction, including
 8 % without limitation the rights to use, copy, modify, merge, publish,
 9 % distribute, sublicense, and/or sell copies of the Software, and to
10 % permit persons to whom the Software is furnished to do so, subject to
11 % the following conditions:
12 % 
13 % The above copyright notice and this permission notice shall be
14 % included in all copies or substantial portions of the Software.
15 % 
16 % THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 % EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 % MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19 % IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20 % CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21 % TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22 % SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23 % 
24 % Retrieved from: http://en.literateprograms.org/Matlab_regressions?oldid=13869
25 
26 
27 f  = @(a,x)(a*x./(1+a*x))
28 a  = sqrt(2)
29 s  = .05;
30 x  = (0:.1:10)';
31 
32 y  = f(a,x);
33 ny = y + randn(size(y))*s;
34 
35 figure('Color',[0.9412 0.9412 0.9412 ]);
36 h1 = subplot(1,2,1);
37 plot(x,y,'-b',x,ny,'.k','linewidth',2);
38 
39 
40 g  = @(x,y)(y./(x-x.*y))
41 
42 ai = g(x,ny);
43 
44 h2 = subplot(1,2,2);
45 boxplot(ai);
46 
47 
48 ah = mean(ai(~isinf(ai)));
49 
50 title(sprintf('$\\hat a$ = %5.5f ; real a = %5.5f', ah, a), 'interpreter', 'latex');

51 
52 axes(h1);
53 hold on
54 plot(x, f(ah, x), ':r', 'linewidth', 2);
55 hold off
56 legend({'theoretical', 'observed', 'estimation'});
57 
58 


Views
Personal tools