bdm::mprod Class Reference

Chain rule decomposition of epdf. More...

#include <emix.h>

Inheritance diagram for bdm::mprod:

Inheritance graph
[legend]
Collaboration diagram for bdm::mprod:

Collaboration graph
[legend]

List of all members.

Public Member Functions

 mprod (Array< mpdf * > mFacs)
 Constructor from list of mFacs,.
double evallogcond (const vec &val, const vec &cond)
 Shortcut for conditioning and evaluation of the internal epdf. In some cases, this operation can be implemented efficiently.
vec samplecond (const vec &cond, double &ll)
mat samplecond (const vec &cond, vec &ll, int N)
RV getrv (bool checkoverlap=false)
 find common rv, flag
void setrvc (const RV &rv, RV &rvc)
 common rvc of all mpdfs is written to rvc
virtual vec samplecond (const vec &cond)
 Returns a sample from the density conditioned on cond, $x \sim epdf(rv|cond)$.
virtual mat samplecond_m (const vec &cond, vec &ll, int N)
 Returns.
virtual void condition (const vec &cond)
 Update ep so that it represents this mpdf conditioned on rvc = cond.
virtual vec evallogcond_m (const mat &Dt, const vec &cond)
 Matrix version of evallogcond.
RV _rvc () const
 access function
RV _rv () const
 access function
epdf_epdf ()
 access function
epdf_e ()
 access function

Protected Attributes

Array< epdf * > epdfs
 pointers to epdfs - shortcut to mpdfs()._epdf()
Array< datalink_m2m * > dls
 Data link for each mpdfs.
int n
 Number of mpdfs in the composite.
Array< mpdf * > mpdfs
 Elements of composition.
RV rv
 modeled random variable
RV rvc
 random variable in condition
epdfep
 pointer to internal epdf


Detailed Description

Chain rule decomposition of epdf.

Probability density in the form of Chain-rule decomposition: \[ f(x_1,x_2,x_3) = f(x_1|x_2,x_3)f(x_2,x_3)f(x_3) \] Note that


Member Function Documentation

vec bdm::mprod::samplecond ( const vec &  cond,
double &  ll 
) [inline]

Ugly hack to help to discover if mpfs are not in proper order. Correct solution = check that explicitely.

References bdm::RV::count(), dls, epdfs, bdm::compositepdf::mpdfs, bdm::compositepdf::n, and bdm::mpdf::rv.

RV bdm::compositepdf::getrv ( bool  checkoverlap = false  )  [inherited]

find common rv, flag

Parameters:
checkoverlap modifies whether overlaps are acceptable

References bdm::RV::add(), bdm::compositepdf::mpdfs, and bdm::compositepdf::n.

virtual vec bdm::mpdf::samplecond ( const vec &  cond  )  [inline, virtual, inherited]

Returns a sample from the density conditioned on cond, $x \sim epdf(rv|cond)$.

Parameters:
cond is numeric value of rv

References bdm::mpdf::condition(), bdm::mpdf::ep, and bdm::epdf::sample().

Referenced by bdm::MPF< BM_T >::bayes(), bdm::PF::bayes(), and bdm::ArxDS::step().

virtual mat bdm::mpdf::samplecond_m ( const vec &  cond,
vec &  ll,
int  N 
) [inline, virtual, inherited]

Returns.

Parameters:
N samples from the density conditioned on cond, $x \sim epdf(rv|cond)$.
cond is numeric value of rv
ll is a return value of log-likelihood of the sample.

References bdm::mpdf::condition(), bdm::RV::count(), bdm::mpdf::ep, bdm::epdf::evallog(), bdm::mpdf::rv, and bdm::epdf::sample().


The documentation for this class was generated from the following file:

Generated on Wed Feb 11 10:20:52 2009 for mixpp by  doxygen 1.5.6