00001 
00013 #ifndef AR_H
00014 #define AR_H
00015 
00016 #include <itpp/itbase.h>
00017 #include "../stat/libFN.h"
00018 #include "../stat/libEF.h"
00019 
00020 using namespace itpp;
00021 
00036 class ARX: public BMEF {
00037 protected:
00039         egiw est;
00041         ldmat &V;
00043         double ν
00044 public:
00046         ARX ( const RV &rv, const mat &V0, const double &nu0, const double frg0=1.0 ) : BMEF ( rv,frg0 ),est ( rv,V0,nu0 ), V ( est._V() ), nu ( est._nu() )
00047         {last_lognc=est.lognc();};
00048 
00050         ARX ( const ARX &A0 ) : BMEF ( A0),est ( rv,A0.V,A0.nu ), V ( est._V() ), nu ( est._nu() ) {};
00051 
00053         ARX* _copy_(bool changerv=false);
00054         
00055 
00056 
00058         void set_parameters ( const ldmat &V0, const double &nu0 )
00059         {est._V() =V0;est._nu() =nu0;last_lognc=est.lognc();}
00060         void set_statistics ( const BMEF* BM0 );
00062         void get_parameters ( mat &V0, double &nu0 ) {V0=est._V().to_mat(); nu0=est._nu();}
00064         void bayes ( const vec &dt, const double w );
00065         void bayes ( const vec &dt ) {bayes ( dt,1.0 );};
00066         const epdf& _epdf() const {return est;}
00067         double logpred ( const vec &dt ) const;
00068         void flatten (const BMEF* B ) {
00069                 const ARX* A=dynamic_cast<const ARX*>(B);
00070                 
00071                 est.pow ( A->nu/nu);
00072                 if(evalll){last_lognc=est.lognc();}
00073         }
00075         enorm<ldmat>* predictor(const RV &rv0, const vec &rgr) const; 
00076         enorm<ldmat>* predictor(const RV &rv0) const {it_assert_debug(rv0.count()==V.rows()-1,"Regressor is not only 1");return predictor(rv0,vec_1(1.0));}
00077         mlnorm<ldmat>* predictor(const RV &rv0, const RV &rvc0) const;
00078         mlstudent* predictor_student(const RV &rv0, const RV &rvc0) const;
00080         ivec structure_est ( egiw Eg0 );
00081         const egiw* _e() const {return &est ;};
00082 };
00083 
00084 
00085 #endif // AR_H
00086 
00087