root/doc/html/arx_ui.html @ 352

Revision 323, 8.2 kB (checked in by smidl, 16 years ago)

doc

Line 
1<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
2<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
3<title>mixpp: Running experiment \c estimator with ARX data fields</title>
4<link href="tabs.css" rel="stylesheet" type="text/css">
5<link href="doxygen.css" rel="stylesheet" type="text/css">
6</head><body>
7<!-- Generated by Doxygen 1.5.8 -->
8<script type="text/javascript">
9<!--
10function changeDisplayState (e){
11  var num=this.id.replace(/[^[0-9]/g,'');
12  var button=this.firstChild;
13  var sectionDiv=document.getElementById('dynsection'+num);
14  if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){
15    sectionDiv.style.display='block';
16    button.src='open.gif';
17  }else{
18    sectionDiv.style.display='none';
19    button.src='closed.gif';
20  }
21}
22function initDynSections(){
23  var divs=document.getElementsByTagName('div');
24  var sectionCounter=1;
25  for(var i=0;i<divs.length-1;i++){
26    if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){
27      var header=divs[i];
28      var section=divs[i+1];
29      var button=header.firstChild;
30      if (button!='IMG'){
31        divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild);
32        button=document.createElement('img');
33        divs[i].insertBefore(button,divs[i].firstChild);
34      }
35      header.style.cursor='pointer';
36      header.onclick=changeDisplayState;
37      header.id='dynheader'+sectionCounter;
38      button.src='closed.gif';
39      section.id='dynsection'+sectionCounter;
40      section.style.display='none';
41      section.style.marginLeft='14px';
42      sectionCounter++;
43    }
44  }
45}
46window.onload = initDynSections;
47-->
48</script>
49<div class="navigation" id="top">
50  <div class="tabs">
51    <ul>
52      <li><a href="main.html"><span>Main&nbsp;Page</span></a></li>
53      <li class="current"><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
54      <li><a href="modules.html"><span>Modules</span></a></li>
55      <li><a href="annotated.html"><span>Classes</span></a></li>
56      <li><a href="files.html"><span>Files</span></a></li>
57    </ul>
58  </div>
59  <div class="navpath"><a class="el" href="manual.html">User Manual</a>
60  </div>
61</div>
62<div class="contents">
63<h1><a class="anchor" name="arx_ui">Running experiment <code>estimator</code> with ARX data fields </a></h1>The experiment estimator::cpp can be run either on command line, or as a mex file in Matlab.<h2><a class="anchor" name="cmd">
64Command-line usage</a></h2>
65In order to use it for estimation of an ARX model, we can define the following <a class="el" href="ui.html">User Infos and their use</a> structure: <div class="fragment"><pre class="fragment"><span class="comment">//Data generating system</span>
66system = {
67        type = <span class="stringliteral">"ArxDS"</span>;
68        y = {type=<span class="stringliteral">"rv"</span>; names=[<span class="stringliteral">"y"</span>, <span class="stringliteral">"u"</span>];};
69        u = {type=<span class="stringliteral">"rv"</span>; names=[]; };
70        rgr = {type=<span class="stringliteral">"rv"</span>;
71                names = [<span class="stringliteral">"y"</span>,<span class="stringliteral">"y"</span>,<span class="stringliteral">"y"</span>,<span class="stringliteral">"u"</span>];
72                times = [-1, -2, -3, -1];
73        };
74        <span class="comment">//AR parameters</span>
75        theta = [0.8, -0.3, 0.4, 1.0,
76                 0.0, 0.0, 0.0, 0.0];
77        <span class="comment">// offset</span>
78        offset = [0.0, 0.0];
79        <span class="comment">//variance</span>
80        r = [0.1, 0.0,
81             0.0, 1.0];
82        <span class="comment">// log also theta</span>
83        opt=<span class="stringliteral">"L_theta"</span>;
84};
85
86<span class="comment">//store results</span>
87logger = {
88        type= <span class="stringliteral">"dirfilelog"</span>;
89        dirname = <span class="stringliteral">"exp/arx_ui"</span>;
90        maxlen = 1000; <span class="comment">//</span>
91};
92
93<span class="comment">//estimation</span>
94estimator = {
95        type = <span class="stringliteral">"ARXest"</span>;
96        y = {type=<span class="stringliteral">"rv"</span>; names=[<span class="stringliteral">"y"</span>]; };
97        rgr = {type=<span class="stringliteral">"rv"</span>;
98                names = [<span class="stringliteral">"y"</span>,<span class="stringliteral">"y"</span>,<span class="stringliteral">"y"</span>,<span class="stringliteral">"u"</span>];
99                times = [-1, -2, -3, -1];
100        };
101
102        <span class="comment">//optional fields</span>
103        dV0 = [1e-3, 1e-5, 1e-5, 1e-5, 1e-5]; <span class="comment">//default: 1e-3 for y, 1e-5 for rgr</span>
104        nu0 = 8.;      <span class="comment">//default: rgrlen + 2</span>
105        frg = 1.0;    <span class="comment">// forgetting, default frg=1.0</span>
106};
107
108<span class="comment">//experiment description</span>
109experiment:{
110        ndat = 9000;
111};
112</pre></div><p>
113The structure is interpreted by application <code>estimator</code>, which looks for fields: <dl>
114<dt>system</dt>
115<dd>description of a Data Source generating Data. The structure must by UI with <code>type="DS_offspring"</code>. In our example, it is of type "ArxDS" which is parsed by bdm::UIArxDS UIbuilder generating a Data Source simulating ARX process. </dd>
116<dt>estimator </dt>
117<dd>description of a Baysian model used to estimate parameters of the data model. In this case, it is of type "ARXest" which is parsed by bdm::UIARX UIbuilder generating Bayesian estimator of autoregressive processess. </dd>
118<dt>logger</dt>
119<dd>description of a way how to store results. UI is of <code>type="logger_offspring"</code>. In this case, it is of class "dirfilelog" which is parsed by bdm::UIdirfilelog which generates object storing data in directory specified by dirname="" field in fileformat understood by program kst. </dd>
120</dl>
121When the application estimator is run with the above code, it produces a directory of data files, which can be displayed by program kst. Expected results are: <div align="center">
122<img src="arx_ui_kst.png" alt="arx_ui_kst.png">
123</div>
124 <h2><a class="anchor" name="mex">
125Matlab mex file</a></h2>
126The matlab mex file can be run with exactly the same configuration as above. However, when we wish to see the results in Matlab, we may wish to change the logger object to <code>type="mexlog"</code> which will store the results in a matlab structure.<p>
127The exact configuration file may look as follows: <div class="fragment"><pre class="fragment"><span class="comment">//Data generating system</span>
128system = { type=<span class="stringliteral">"external"</span>; filename=<span class="stringliteral">"arx_test.cfg"</span>; path=<span class="stringliteral">"system"</span>;};
129
130<span class="comment">//store results</span>
131logger = {
132        type= <span class="stringliteral">"mexlog"</span>;
133        maxlen = 90; <span class="comment">//</span>
134    <span class="comment">//dirname = "exp/ax";</span>
135};
136
137<span class="comment">//estimation</span>
138estimator = {
139   type = <span class="stringliteral">"ARXest"</span>;
140        y = {type=<span class="stringliteral">"rv"</span>; names=[<span class="stringliteral">"y"</span>]; };
141        rgr = {type=<span class="stringliteral">"rv"</span>;
142                names = [<span class="stringliteral">"y"</span>,<span class="stringliteral">"y"</span>,<span class="stringliteral">"y"</span>,<span class="stringliteral">"u"</span>];
143                times = [-1, -2, -3, -1];
144        };
145
146        <span class="comment">//optional fields</span>
147        dV0 = [1e-3, 1e-5, 1e-5, 1e-5, 1e-5]; <span class="comment">//default: 1e-3 for y, 1e-5 for rgr</span>
148        <span class="comment">//nu0 = 8.;      //default: rgrlen + 2</span>
149        frg = .9991;    <span class="comment">// forgetting, default frg=1.0</span>
150};
151
152<span class="comment">//experiment description</span>
153experiment:{
154        ndat = 90;
155};
156</pre></div><p>
157The resulting structure can be displayed using matlab script arx_test_disp.m, typically producing the following results: <div align="center">
158<img src="arx_ui_mex.png" alt="arx_ui_mex.png">
159</div>
160  </div>
161<hr size="1"><address style="text-align: right;"><small>Generated on Thu Apr 23 21:06:43 2009 for mixpp by&nbsp;
162<a href="http://www.doxygen.org/index.html">
163<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address>
164</body>
165</html>
Note: See TracBrowser for help on using the browser.