root/tests/arx_test.cpp @ 187

Revision 170, 0.9 kB (checked in by smidl, 16 years ago)

Mixtures of EF and related changes to libEF and BM

  • Property svn:eol-style set to native
Line 
1#include <estim/arx.h>
2#include <stat/libEF.h>
3using namespace itpp;
4
5//These lines are needed for use of cout and endl
6using std::cout;
7using std::endl;
8
9int main() {
10        // Setup model
11        vec th("0.8 -0.3 0.4 0.01");
12        int ord=th.length();
13        double sqr=0.1;
14       
15        //Test constructor
16        mat V0 = 0.00001*eye(ord+1); V0(0.0)*= 10; //
17        double nu0 = ord+1;
18       
19        RV thr("{theta_and_r }",vec_1(ord+1));
20        ARX Ar(thr, V0, nu0);
21        const epdf& Ar_ep = Ar._epdf();
22                               
23        //Test estimation
24        int ndat = 10000;
25        int t,j;
26        vec Yt(ndat);
27        vec LL(ndat);
28        Yt.set_subvector(0,randn(ord)); //initial values
29        vec rgr(ord);
30       
31        cout << Ar_ep.mean()<<endl;
32        for (t=ord; t<ndat; t++) {
33                for(j=0;j<(ord);j++){rgr(j)=Yt(t-j-1);}
34                Yt(t) = th*rgr + sqr * NorRNG();
35               
36                vec Psi = concat(Yt(t), rgr);
37                Ar.bayes(Psi);
38                LL(t) = Ar._ll();
39        }
40        cout << Ar_ep.mean()<<endl;
41       
42        // Test brute-froce structure estimation
43        cout << Ar.structure_est(egiw(thr,V0,nu0)) <<endl;
44}
Note: See TracBrowser for help on using the browser.