Changeset 135 for matlab/mex

Show
Ignore:
Timestamp:
07/25/08 15:04:05 (16 years ago)
Author:
smidl
Message:

oprava simulatoru

Files:
1 modified

Legend:

Unmodified
Added
Removed
  • matlab/mex/linefit2.cpp

    r133 r135  
    1212        // Convert input variables to IT++ format 
    1313        mat Data = mxArray2mat ( input[0] ); 
    14         if (Data.rows()!=2) 
    15                 { if (Data.cols()==2) Data=Data.T(); else mexErrMsgTxt("Data are not 2D!");} 
     14        if ( Data.rows() !=2 ) 
     15                { if ( Data.cols() ==2 ) Data=Data.T(); else mexErrMsgTxt ( "Data are not 2D!" );} 
    1616        int ilow = mxArray2int ( input[1] )-1; 
    1717        int ihi = mxArray2int ( input[2] )-1; //coreection for different indeces 
     
    2020        // ------------------ Start of routine --------------------------- 
    2121        int ndat=Data.cols(); 
    22         int npsi=Data.rows()+1; //add a constant 
     22        int npsi=Data.rows() +1; //add a constant 
    2323        RV thr ( "1","{ theta_r }",vec_1 ( npsi ),vec_1 ( 0 ) ); 
    2424 
    25         mat V0=1e-8*eye ( npsi ); V0 ( 0,0 ) =10.0; 
    26         vec rgr(npsi); 
    27         double nu0=2; 
     25        mat V0=1e-8*eye ( npsi ); V0 ( 0,0 ) =1e-4; 
     26        vec rgr ( npsi ); 
     27        double nu0=0.1; 
    2828        // fitting a linear part => third coef is "1" 
    29         rgr(2) = 1.0; 
     29        rgr ( 2 ) = 1.0; 
    3030 
    3131        // RESULTS 
    32         mat Tlls=zeros(ihi,ihi); 
     32        mat Tlls=zeros ( ihi+1,ihi+1); 
    3333        // AR model 
    3434        ARX Ar ( thr,V0,nu0 ); 
    3535 
    3636        //Initialize 
    37         for (int i=ilow; i<ihi; i++) { 
    38                 rgr.set_subvector(0,Data.get_col ( i )); 
    39                 Ar.bayes(rgr); 
     37        for ( int i=ilow+2; i<ihi-2; i++ ) { 
     38                rgr.set_subvector ( 0,Data.get_col ( i ) ); 
     39                Ar.bayes ( rgr ); 
    4040        } 
    41         Ar.get_parameters(V0,nu0); 
    42         V0 /=V0(1,1); 
    43         nu0=3; 
    44         Ar.set_parameters(V0,nu0); 
    45                  
    4641        // FLATTEN 
    47         for (int i=ilow; i<ihi; i++) { 
    48                 Ar.set_parameters(V0,nu0); 
    49                 for (int t=i+1; t<ihi; t++) { 
    50                         rgr.set_subvector(0,Data.get_col ( t )); 
    51                         Ar.bayes(rgr); 
    52                         Tlls(i,t)=Ar._tll(); 
     42/*      Ar.get_parameters ( V0,nu0 ); 
     43        V0 *=1.0/nu0/10000.; // same flattening factor as for nu0 
     44        nu0=1./10000.;*/ 
     45        Ar.set_parameters ( V0,nu0 ); 
     46 
     47        for ( int i=ilow; i<=ihi; i++ ) { 
     48                Ar.set_parameters ( V0,nu0 ); 
     49                for ( int t=i; t<=ihi; t++ ) { 
     50                        rgr.set_subvector ( 0,Data.get_col ( t ) ); 
     51                        Ar.bayes ( rgr ); 
     52                        Tlls ( i,t ) =Ar._tll(); 
    5353                } 
    5454        } 
    5555 
    56         max_index(Tlls,ilow,ihi); 
     56        max_index ( Tlls,ilow,ihi ); 
    5757 
    5858        // ------------------ End of routine ----------------------------- 
    5959 
    6060        output[0] = mxCreateDoubleMatrix ( 2,1, mxREAL ); 
    61         ivec2mxArray (vec_2(ilow+1,ihi+1) , output[0] ); 
     61        ivec2mxArray ( vec_2 ( ilow+1,ihi+1 ) , output[0] ); 
    6262 
    6363        if ( n_output>1 ) { 
    64         // Create output vectors 
    65         output[1] = mxCreateDoubleMatrix ( Tlls.rows(),Tlls.cols(), mxREAL ); 
    66         // Convert the IT++ format to Matlab format for output 
    67         mat2mxArray ( Tlls, output[1] ); 
     64                // Create output vectors 
     65                output[1] = mxCreateDoubleMatrix ( Tlls.rows(),Tlls.cols(), mxREAL ); 
     66                // Convert the IT++ format to Matlab format for output 
     67                mat2mxArray ( Tlls, output[1] ); 
    6868        } 
    69          
     69 
     70        if ( n_output>2 ) { 
     71                Ar.set_parameters ( V0,nu0 ); 
     72                // Redo Ar for given points 
     73                for ( int i=ilow; i<=ihi; i++ ) { 
     74                        rgr.set_subvector ( 0,Data.get_col ( i ) ); 
     75                        Ar.bayes ( rgr ); 
     76                } 
     77 
     78                // Create output vectors 
     79                output[2] = mxCreateDoubleMatrix ( 3,1, mxREAL ); 
     80                // Convert the IT++ format to Matlab format for output 
     81//              mat2mxArray ( Ar._epdf().mean(), output[2] ); 
     82                mat2mxArray ( Ar._epdf().mean(), output[2] ); 
     83        } 
     84 
    7085}