| [591] | 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | 
|---|
|  | 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | 
|---|
|  | 3 | <head> | 
|---|
|  | 4 | <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> | 
|---|
|  | 5 | <title>mixpp: arx_ctrl.h Source File</title> | 
|---|
|  | 6 | <link href="tabs.css" rel="stylesheet" type="text/css"/> | 
|---|
|  | 7 | <link href="doxygen.css" rel="stylesheet" type="text/css"/> | 
|---|
|  | 8 | </head> | 
|---|
|  | 9 | <body> | 
|---|
|  | 10 | <!-- Generated by Doxygen 1.6.1 --> | 
|---|
|  | 11 | <script type="text/javascript"> | 
|---|
|  | 12 | <!-- | 
|---|
|  | 13 | function changeDisplayState (e){ | 
|---|
|  | 14 | var num=this.id.replace(/[^[0-9]/g,''); | 
|---|
|  | 15 | var button=this.firstChild; | 
|---|
|  | 16 | var sectionDiv=document.getElementById('dynsection'+num); | 
|---|
|  | 17 | if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){ | 
|---|
|  | 18 | sectionDiv.style.display='block'; | 
|---|
|  | 19 | button.src='open.gif'; | 
|---|
|  | 20 | }else{ | 
|---|
|  | 21 | sectionDiv.style.display='none'; | 
|---|
|  | 22 | button.src='closed.gif'; | 
|---|
|  | 23 | } | 
|---|
|  | 24 | } | 
|---|
|  | 25 | function initDynSections(){ | 
|---|
|  | 26 | var divs=document.getElementsByTagName('div'); | 
|---|
|  | 27 | var sectionCounter=1; | 
|---|
|  | 28 | for(var i=0;i<divs.length-1;i++){ | 
|---|
|  | 29 | if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){ | 
|---|
|  | 30 | var header=divs[i]; | 
|---|
|  | 31 | var section=divs[i+1]; | 
|---|
|  | 32 | var button=header.firstChild; | 
|---|
|  | 33 | if (button!='IMG'){ | 
|---|
|  | 34 | divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild); | 
|---|
|  | 35 | button=document.createElement('img'); | 
|---|
|  | 36 | divs[i].insertBefore(button,divs[i].firstChild); | 
|---|
|  | 37 | } | 
|---|
|  | 38 | header.style.cursor='pointer'; | 
|---|
|  | 39 | header.onclick=changeDisplayState; | 
|---|
|  | 40 | header.id='dynheader'+sectionCounter; | 
|---|
|  | 41 | button.src='closed.gif'; | 
|---|
|  | 42 | section.id='dynsection'+sectionCounter; | 
|---|
|  | 43 | section.style.display='none'; | 
|---|
|  | 44 | section.style.marginLeft='14px'; | 
|---|
|  | 45 | sectionCounter++; | 
|---|
|  | 46 | } | 
|---|
|  | 47 | } | 
|---|
|  | 48 | } | 
|---|
|  | 49 | window.onload = initDynSections; | 
|---|
|  | 50 | --> | 
|---|
|  | 51 | </script> | 
|---|
|  | 52 | <div class="navigation" id="top"> | 
|---|
|  | 53 | <div class="tabs"> | 
|---|
|  | 54 | <ul> | 
|---|
|  | 55 | <li><a href="main.html"><span>Main Page</span></a></li> | 
|---|
|  | 56 | <li><a href="pages.html"><span>Related Pages</span></a></li> | 
|---|
|  | 57 | <li><a href="annotated.html"><span>Classes</span></a></li> | 
|---|
|  | 58 | <li class="current"><a href="files.html"><span>Files</span></a></li> | 
|---|
|  | 59 | </ul> | 
|---|
|  | 60 | </div> | 
|---|
|  | 61 | <div class="tabs"> | 
|---|
|  | 62 | <ul> | 
|---|
|  | 63 | <li><a href="files.html"><span>File List</span></a></li> | 
|---|
|  | 64 | <li><a href="globals.html"><span>File Members</span></a></li> | 
|---|
|  | 65 | </ul> | 
|---|
|  | 66 | </div> | 
|---|
|  | 67 | <h1>arx_ctrl.h</h1><a href="arx__ctrl_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 | 
|---|
|  | 68 | <a name="l00013"></a>00013 <span class="preprocessor">#include "../base/bdmbase.h"</span> | 
|---|
|  | 69 | <a name="l00014"></a>00014 <span class="preprocessor">#include "<a class="code" href="ctrlbase_8h.html" title="Base classes for designers of control strategy.">ctrlbase.h</a>"</span> | 
|---|
|  | 70 | <a name="l00015"></a>00015 <span class="preprocessor">#include "../estim/arx.h"</span> | 
|---|
|  | 71 | <a name="l00016"></a>00016 <span class="preprocessor">#include "../estim/kalman.h"</span> | 
|---|
|  | 72 | <a name="l00017"></a>00017 | 
|---|
|  | 73 | <a name="l00018"></a>00018 <span class="keyword">namespace </span>bdm{ | 
|---|
|  | 74 | <a name="l00019"></a>00019 | 
|---|
|  | 75 | <a name="l00021"></a><a class="code" href="classbdm_1_1LQG__ARX.html">00021</a>         <span class="keyword">class </span><a class="code" href="classbdm_1_1LQG__ARX.html" title="Controller using ARX model for estimation and LQG designer for control.">LQG_ARX</a> : <span class="keyword">public</span> <a class="code" href="classbdm_1_1Controller.html">Controller</a>{ | 
|---|
|  | 76 | <a name="l00022"></a>00022                 <span class="keyword">protected</span>: | 
|---|
|  | 77 | <a name="l00024"></a><a class="code" href="classbdm_1_1LQG__ARX.html#ae826eb0d2392dfd782d5f213df6288cc">00024</a>                         shared_prt<ARX> <a class="code" href="classbdm_1_1LQG__ARX.html#ae826eb0d2392dfd782d5f213df6288cc" title="Internal ARX estimator.">ar</a>; | 
|---|
|  | 78 | <a name="l00026"></a><a class="code" href="classbdm_1_1LQG__ARX.html#afb08b341bf00588e7aa6aba33db315c9">00026</a>                         <a class="code" href="classbdm_1_1LQG.html">LQG</a> <a class="code" href="classbdm_1_1LQG__ARX.html#afb08b341bf00588e7aa6aba33db315c9" title="Internal LQG designer.">lq</a>; | 
|---|
|  | 79 | <a name="l00028"></a><a class="code" href="classbdm_1_1LQG__ARX.html#ad5ddc7af692f2c1b2f04ea903ed966f4">00028</a>                         sharer_ptr<StateSpace> <a class="code" href="classbdm_1_1LQG__ARX.html#ad5ddc7af692f2c1b2f04ea903ed966f4" title="Intermediate StateSpace model.">stsp</a>; | 
|---|
|  | 80 | <a name="l00030"></a>00030                 <span class="keyword">public</span>: | 
|---|
|  | 81 | <a name="l00032"></a><a class="code" href="classbdm_1_1LQG__ARX.html#aa8b901b37f009400fa68bfdefa473eeb">00032</a>                         <a class="code" href="classbdm_1_1LQG__ARX.html#aa8b901b37f009400fa68bfdefa473eeb">LQG_ARX</a>(): <a class="code" href="classbdm_1_1LQG__ARX.html#ae826eb0d2392dfd782d5f213df6288cc" title="Internal ARX estimator.">ar</a>(), <a class="code" href="classbdm_1_1LQG__ARX.html#afb08b341bf00588e7aa6aba33db315c9" title="Internal LQG designer.">lq</a>(), statemodel(new <a class="code" href="classbdm_1_1StateSpace.html" title="Basic elements of linear state-space model.">StateSpace</a>) { } | 
|---|
|  | 82 | <a name="l00033"></a>00033 | 
|---|
|  | 83 | <a name="l00034"></a>00034                         <span class="keywordtype">void</span> initialize() { | 
|---|
|  | 84 | <a name="l00035"></a>00035 | 
|---|
|  | 85 | <a name="l00036"></a>00036                         } | 
|---|
|  | 86 | <a name="l00038"></a><a class="code" href="classbdm_1_1LQG__ARX.html#a838a63f9481b4bb8055896492a30c0af">00038</a>                         <span class="keywordtype">void</span> <a class="code" href="classbdm_1_1LQG__ARX.html#a838a63f9481b4bb8055896492a30c0af" title="adaptation is to store arx estimates in stsp">adapt</a>(){ | 
|---|
|  | 87 | <a name="l00039"></a>00039                                 <a class="code" href="classbdm_1_1ARX.html" title="Linear Autoregressive model with Gaussian noise.">ARX</a>.to_state_space(<a class="code" href="classbdm_1_1LQG__ARX.html#ad5ddc7af692f2c1b2f04ea903ed966f4" title="Intermediate StateSpace model.">stsp</a>); | 
|---|
|  | 88 | <a name="l00040"></a>00040                         } | 
|---|
|  | 89 | <a name="l00043"></a>00043 | 
|---|
|  | 90 | <a name="l00055"></a><a class="code" href="classbdm_1_1LQG__ARX.html#a2c9556d56bb75fc2eb6c0c7d8e9e0145">00055</a>                         <span class="keywordtype">void</span> <a class="code" href="classbdm_1_1LQG__ARX.html#a2c9556d56bb75fc2eb6c0c7d8e9e0145" title="LQG is defined by quadratic loss function.">from_settings</a>(<span class="keyword">const</span> Settings &<span class="keyword">set</span>){ | 
|---|
|  | 91 | <a name="l00056"></a>00056                                 <a class="code" href="classbdm_1_1LQG__ARX.html#ae826eb0d2392dfd782d5f213df6288cc" title="Internal ARX estimator.">ar</a>=UI::build<ARX> (<span class="keyword">set</span>, <span class="stringliteral">"ARX"</span>,UI::compulsory); | 
|---|
|  | 92 | <a name="l00057"></a>00057 | 
|---|
|  | 93 | <a name="l00058"></a>00058                                 <a class="code" href="classbdm_1_1UI.html#acd1667e6fec99ec64dabcb3ca2ff922d">UI::get</a>(Qu, <span class="keyword">set</span>, <span class="stringliteral">"Qu"</span>, UI::compulsory); | 
|---|
|  | 94 | <a name="l00059"></a>00059                                 UI::get(Qy, <span class="keyword">set</span>, <span class="stringliteral">"Qy"</span>, UI::compulsory); | 
|---|
|  | 95 | <a name="l00060"></a>00060 | 
|---|
|  | 96 | <a name="l00061"></a>00061                                 <span class="keywordflow">if</span> (!UI::get(y_req, <span class="keyword">set</span>, <span class="stringliteral">"yreq"</span>, UI::optional)) | 
|---|
|  | 97 | <a name="l00062"></a>00062                                         y_req = zeros(yrv._dsize()); | 
|---|
|  | 98 | <a name="l00063"></a>00063                                 <span class="keywordflow">if</span> (!UI::get(u_req, <span class="keyword">set</span>, <span class="stringliteral">"ureq"</span>, UI::optional)) | 
|---|
|  | 99 | <a name="l00064"></a>00064                                         u_req = zeros(urv._dsize()); | 
|---|
|  | 100 | <a name="l00065"></a>00065                         } | 
|---|
|  | 101 | <a name="l00066"></a>00066         }; | 
|---|
|  | 102 | <a name="l00067"></a>00067 | 
|---|
|  | 103 | <a name="l00068"></a>00068 } <span class="comment">// namespace</span> | 
|---|
|  | 104 | </pre></div></div> | 
|---|
| [616] | 105 | <hr size="1"/><address style="text-align: right;"><small>Generated on Sun Sep 13 23:08:55 2009 for mixpp by  | 
|---|
| [591] | 106 | <a href="http://www.doxygen.org/index.html"> | 
|---|
|  | 107 | <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address> | 
|---|
|  | 108 | </body> | 
|---|
|  | 109 | </html> | 
|---|