Changeset 810

Show
Ignore:
Timestamp:
02/21/10 20:58:41 (15 years ago)
Author:
smidl
Message:

egiw with empty normal part

Location:
library
Files:
4 modified

Legend:

Unmodified
Added
Removed
  • library/bdm/estim/arx.h

    r796 r810  
    152152                vec dV0 ( prior._V().rows() ); 
    153153                dV0.set_subvector ( 0, prior._dimx() - 1, 1.0 ); 
    154                 dV0.set_subvector ( prior._dimx(), dV0.length() - 1, 1e-5 ); 
     154                if (dV0.length()>prior._dimx()) 
     155                        dV0.set_subvector ( prior._dimx(), dV0.length() - 1, 1e-5 ); 
    155156 
    156157                prior.set_parameters ( prior._dimx(), ldmat ( dV0 ) ); 
  • library/bdm/stat/exp_family.cpp

    r761 r810  
    9090        Omi.setCh ( Omega.sample_mat() ); 
    9191 
    92         mat Z = randn ( M.rows(), M.cols() ); 
    93         Mi = M + Omi._Ch() * Z * inv ( Vz._L() * diag ( sqrt ( Vz._D() ) ) ); 
     92        if (M._datasize()>0){ 
     93                mat Z = randn ( M.rows(), M.cols() ); 
     94                Mi = M + Omi._Ch() * Z * inv ( Vz._L() * diag ( sqrt ( Vz._D() ) ) ); 
     95        } 
    9496        Omi.inv ( Ri ); 
    9597} 
    9698 
    9799double egiw::evallog_nn ( const vec &val ) const { 
    98         bdm_assert_debug(val.length()==nPsi+dimx,"Incorrect cond in egiw::evallog_nn" ); 
     100        bdm_assert_debug(val.length()==dimx*(nPsi+dimx),"Incorrect cond in egiw::evallog_nn" ); 
    99101         
    100102        int vend = val.length() - 1; 
     
    110112                return -0.5* ( nu*log ( r ) + Vq / r ); 
    111113        } else { 
    112                 mat Th = reshape ( val ( 0, nPsi * dimx - 1 ), nPsi, dimx ); 
     114                mat Tmp; 
     115                if (nPsi>0){ 
     116                        mat Th = reshape ( val ( 0, nPsi * dimx - 1 ), nPsi, dimx ); 
     117                        Tmp = concat_vertical ( -eye ( dimx ), Th ); 
     118                } else { 
     119                        Tmp = -eye(dimx); 
     120                } 
    113121                fsqmat R ( reshape ( val ( nPsi*dimx, vend ), dimx, dimx ) ); 
    114122                double ldetR = R.logdet(); 
    115                 if ( ldetR ) return -inf; 
    116                 mat Tmp = concat_vertical ( -eye ( dimx ), Th ); 
     123                if ( !isfinite(ldetR) ) return -inf; 
    117124                fsqmat iR ( dimx ); 
    118125                R.inv ( iR ); 
     
    131138#define Inf std::numeric_limits<double>::infinity() 
    132139 
    133         double nkG = 0.5 * dimx * ( -nPsi * log2pi + sum ( log ( D ( dimx, D.length() - 1 ) ) ) ); 
     140        double nkG = 0.5 * dimx * ( -nPsi * log2pi + sum ( log ( D.mid ( dimx, nPsi ) ) ) ); 
    134141        // temporary for lgamma in Wishart 
    135142        double lg = 0; 
     
    169176        int end = L.rows() - 1; 
    170177 
    171         Vz = ldmat ( L ( dimx, end, dimx, end ), D ( dimx, end ) ); 
    172         mat iLsub = ltuinv ( Vz._L() ); 
    173         // set mean value 
    174         mat Lpsi = L ( dimx, end, 0, dimx - 1 ); 
    175         M = iLsub * Lpsi; 
    176  
    177178        Lam = ldmat ( L ( 0, dimx - 1, 0, dimx - 1 ), D ( 0, dimx - 1 ) );  //exp val of R 
    178         if ( 1 ) { // test with Peterka 
     179 
     180        if (dimx<=end){ 
     181                Vz = ldmat ( L ( dimx, end, dimx, end ), D ( dimx, end ) ); 
     182                mat iLsub = ltuinv ( Vz._L() ); 
     183                // set mean value 
     184                mat Lpsi = L ( dimx, end, 0, dimx - 1 ); 
     185                M = iLsub * Lpsi; 
     186        } 
     187/*      if ( 0 ) { // test with Peterka 
    179188                mat VF = V.to_mat(); 
    180189                mat Vf = VF ( 0, dimx - 1, 0, dimx - 1 ); 
     
    183192 
    184193                mat Lam2 = Vf - Vzf.T() * inv ( VZ ) * Vzf; 
    185         } 
     194        }*/ 
    186195} 
    187196 
     
    227236        int l = V.rows(); 
    228237        // cut out rest of lower-right part of V 
    229         const ldmat tmp ( V, linspace ( dimx, l - 1 ) ); 
    230238        // invert it 
    231239        ldmat itmp ( l ); 
    232         tmp.inv ( itmp ); 
    233  
     240        if (dimx<l){ 
     241                const ldmat tmp ( V, linspace ( dimx, l - 1 ) ); 
     242                tmp.inv ( itmp ); 
     243        } 
    234244        // following Wikipedia notation 
    235245        // m=nu-nPsi-dimx-1, p=dimx 
     
    275285 
    276286        ldmat ldR ( L ( 0, dimx - 1, 0, dimx - 1 ), D ( 0, dimx - 1 ) / ( nu - nPsi - 2*dimx - 2 ) ); //exp val of R 
    277         mat iLsub = ltuinv ( L ( dimx, end, dimx, end ) ); 
    278287 
    279288        // set mean value 
    280         mat Lpsi = L ( dimx, end, 0, dimx - 1 ); 
    281         M = iLsub * Lpsi; 
     289        if (dimx<=end){ 
     290                mat iLsub = ltuinv ( L ( dimx, end, dimx, end ) ); 
     291                mat Lpsi = L ( dimx, end, 0, dimx - 1 ); 
     292                M = iLsub * Lpsi; 
     293        } 
    282294        R = ldR.to_mat()  ; 
    283295} 
  • library/tests/testsuite/egiw.cfg

    r730 r810  
    4545        }; 
    4646  tolerance = 0.01; 
    47 } ); 
     47}, 
     48{ 
     49  class = "epdf_harness"; 
     50  epdf = { 
     51    class = "egiw"; 
     52    V = ( "matrix", 2, 2, [ 10.0, 5.0, 5.0, 15.0 ] ); 
     53    nu = 10.0; 
     54    dimx = 2; 
     55    rv :  
     56    { 
     57      class = "RV"; 
     58      names = ( "a", "b" ); 
     59    }; 
     60  }; 
     61  mean = [1.0, 0.5, 0.5, 1.5]; 
     62  variance = [1.0, 1.0]; 
     63  R = ( "matrix", 2, 2, [ 1.0, 0.0, 0.0, 1.0 ] ); 
     64  support = { 
     65        class = "rectangular_support"; 
     66        ranges = ( [ 0.0, 4.0 ], [-2.0, 2.0], [-2.0, 2.0], [0.0, 4.0 ] ); 
     67        gridsizes = [ 10, 10, 10, 10]; 
     68        }; 
     69  tolerance = 0.01; 
     70}); 
    4871 
    4972 
  • library/tests/testsuite/enorm.cfg

    r730 r810  
    103103    class = "enorm<chmat>"; 
    104104    mu = ( "matrix", 1, 2, [ 0.0, 2.0 ] ); 
    105     R = ( "matrix", 2, 2, [ 2.0, 0.0, 0.0, 0.5 ] ); 
     105    R = ( "matrix", 2, 2, [ 1.0, 0.3, 0.3, 0.5 ] ); 
    106106    rv :  
    107107    { 
     
    111111  }; 
    112112  mean = [ 0.0, 2.0 ]; 
    113   variance = [ 2.0, 0.5 ]; 
    114   R = ( "matrix", 2, 2, [ 2.0, 0.0, 0.0, 0.5 ] ); 
    115   tolerance = 0.5; 
     113  variance = [ 1.0, 0.5 ]; 
     114  R = ( "matrix", 2, 2, [ 1.0, 0.3, 0.3, 0.5 ] ); 
    116115} ); 
    117116