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 | <!-- |
---|
10 | function 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 | } |
---|
22 | function 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 | } |
---|
46 | window.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 Page</span></a></li> |
---|
53 | <li class="current"><a href="pages.html"><span>Related 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"> |
---|
64 | Command-line usage</a></h2> |
---|
65 | In 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> |
---|
66 | system = { |
---|
67 | <span class="keyword">class </span>= "ArxDS"; |
---|
68 | y = {<span class="keyword">class</span>=<span class="stringliteral">"RV"</span>; names=(<span class="stringliteral">"y"</span>, <span class="stringliteral">"u"</span>);}; |
---|
69 | u = {<span class="keyword">class</span>=<span class="stringliteral">"RV"</span>; names=(); }; |
---|
70 | rgr = {<span class="keyword">class</span>=<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 = (2,4,[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 = (2,2,[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> |
---|
87 | logger = { |
---|
88 | <span class="keyword">class</span>= <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> |
---|
94 | estimator = { |
---|
95 | <span class="keyword">class </span>= "ARX"; |
---|
96 | y = {<span class="keyword">class</span>=<span class="stringliteral">"RV"</span>; names=(<span class="stringliteral">"y"</span>); }; |
---|
97 | rgr = {<span class="keyword">class</span>=<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> |
---|
109 | experiment:{ |
---|
110 | ndat = 9000; |
---|
111 | }; |
---|
112 | </pre></div><p> |
---|
113 | The 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> |
---|
121 | When 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"> |
---|
125 | Matlab mex file</a></h2> |
---|
126 | The 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> |
---|
127 | The exact configuration file may look as follows: <div class="fragment"><pre class="fragment"><span class="comment">//Data generating system</span> |
---|
128 | system = { 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> |
---|
131 | logger = { |
---|
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> |
---|
138 | estimator = { |
---|
139 | type = <span class="stringliteral">"ARX"</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> |
---|
153 | experiment:{ |
---|
154 | ndat = 90; |
---|
155 | }; |
---|
156 | </pre></div><p> |
---|
157 | The 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 Mon Jun 15 13:47:07 2009 for mixpp by |
---|
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> |
---|