root/bdm/stat/emix.cpp @ 254

Revision 254, 2.2 kB (checked in by smidl, 15 years ago)

create namespace bdm

  • Property svn:eol-style set to native
Line 
1#include "emix.h"
2
3namespace bdm{
4
5void emix::set_parameters ( const vec &w0, const Array<epdf*> &Coms0, bool copy ) {
6        w = w0/sum ( w0 );
7        int i;
8        for ( i=0;i<w.length();i++ ) {
9                it_assert_debug ( rv.equal ( Coms0 ( i )->_rv() ),"RVs do not match!" );
10        }
11        if ( copy ) {
12                Coms.set_length(Coms0.length());
13                for ( i=0;i<w.length();i++ ) {it_error("Not imp...");
14                        *Coms ( i ) =*Coms0 ( i );}
15                destroyComs=true;
16        }
17        else {
18                Coms = Coms0;
19                destroyComs=false;
20        }
21}
22
23vec emix::sample() const {
24        //Sample which component
25        vec cumDist = cumsum ( w );
26        double u0;
27        #pragma omp critical
28        u0 = UniRNG.sample();
29
30        int i=0;
31        while ( ( cumDist ( i ) <u0 ) && ( i< ( w.length()-1 ) ) ) {i++;}
32
33        return Coms ( i )->sample();
34}
35
36emix* emix::marginal(const RV &rv) const{
37        Array<epdf*> Cn(Coms.length());
38        for(int i=0;i<Coms.length();i++){Cn(i)=Coms(i)->marginal(rv);}
39        emix* tmp = new emix(rv);
40        tmp->set_parameters(w,Cn,false);
41        tmp->ownComs();
42        return tmp;
43}
44
45mratio* emix::condition(const RV &rv) const{
46        return new mratio(this,rv);
47};
48
49}
50// mprod::mprod ( Array<mpdf*> mFacs, bool overlap) : mpdf ( RV(), RV() ), n ( mFacs.length() ), epdfs ( n ), mpdfs ( mFacs ), rvinds ( n ), rvcinrv ( n ), irvcs_rvc ( n ) {
51//              int i;
52//              bool rvaddok;
53//              // Create rv
54//              for ( i = 0;i < n;i++ ) {
55//                      rvaddok=rv.add ( mpdfs ( i )->_rv() ); //add rv to common rvs.
56//                      // If rvaddok==false, mpdfs overlap => assert error.
57//                      it_assert_debug(rvaddok||overlap,"mprod::mprod() input mpdfs overlap in rv!");
58//                      epdfs ( i ) = & ( mpdfs ( i )->_epdf() ); // add pointer to epdf
59//              };
60//              // Create rvc
61//              for ( i = 0;i < n;i++ ) {
62//                      rvc.add ( mpdfs ( i )->_rvc().subt ( rv ) ); //add rv to common rvs.
63//              };
64//
65// //           independent = true;
66//              //test rvc of mpdfs and fill rvinds
67//              for ( i = 0;i < n;i++ ) {
68//                      // find ith rv in common rv
69//                      rvsinrv ( i ) = mpdfs ( i )->_rv().dataind ( rv );
70//                      // find ith rvc in common rv
71//                      rvcinrv ( i ) = mpdfs ( i )->_rvc().dataind ( rv );
72//                      // find ith rvc in common rv
73//                      irvcs_rvc ( i ) = mpdfs ( i )->_rvc().dataind ( rvc );
74//                      //
75// /*                   if ( rvcinrv ( i ).length() >0 ) {independent = false;}
76//                      if ( irvcs_rvc ( i ).length() >0 ) {independent = false;}*/
77//              }
78//      };
Note: See TracBrowser for help on using the browser.