Product of independent epdfs. For dependent pdfs, use mprod. More...
#include <emix.h>
| Public Member Functions | |
| eprod () | |
| Default constructor. | |
| void | set_parameters (const Array< const epdf * > &epdfs0, bool named=true) | 
| Set internal. | |
| vec | mean () const | 
| return expected value | |
| vec | variance () const | 
| return expected variance (not covariance!) | |
| vec | sample () const | 
| Returns a sample,  from density  . | |
| double | evallog (const vec &val) const | 
| const epdf * | operator() (int i) const | 
| access function | |
| ~eprod () | |
| Destructor. | |
| void | from_setting (const Setting &set) | 
| virtual string | to_string () | 
| This method returns a basic info about the current instance. | |
| virtual void | to_setting (Setting &set) const | 
| This method save all the instance properties into the Setting structure. | |
| virtual void | validate () | 
| This method TODO. | |
| Constructors | |
| Construction of each epdf should support two types of constructors: 
 The following constructors should be supported for convenience: 
 All internal data structures are constructed as empty. Their values (including sizes) will be set by method  | |
| void | set_parameters (int dim0) | 
| Matematical Operations | |
| virtual mat | sample_m (int N) const | 
| Returns N samples,  from density  . | |
| virtual vec | evallog_m (const mat &Val) const | 
| Compute log-probability of multiple values argument val. | |
| virtual vec | evallog_m (const Array< vec > &Avec) const | 
| Compute log-probability of multiple values argument val. | |
| virtual shared_ptr< mpdf > | condition (const RV &rv) const | 
| Return conditional density on the given RV, the remaining rvs will be in conditioning. | |
| virtual shared_ptr< epdf > | marginal (const RV &rv) const | 
| Return marginal density on the given RV, the remainig rvs are intergrated out. | |
| virtual void | qbounds (vec &lb, vec &ub, double percentage=0.95) const | 
| Lower and upper bounds of percentage% quantile, returns mean-2*sigma as default. | |
| Connection to other classes | |
| void | set_rv (const RV &rv0) | 
| Name its rv. | |
| bool | isnamed () const | 
| True if rv is assigned. | |
| const RV & | _rv () const | 
| Return name (fails when isnamed is false). | |
| Access to attributes | |
| int | dimension () const | 
| Size of the random variable. | |
| Protected Attributes | |
| Array< const epdf * > | epdfs | 
| Components (epdfs). | |
| Array< datalink * > | dls | 
| Array of indeces. | |
| int | dim | 
| dimension of the random variable | |
| RV | rv | 
| Description of the random variable. | |
Product of independent epdfs. For dependent pdfs, use mprod.
| double bdm::eprod::evallog | ( | const vec & | val | ) | const  [inline, virtual] | 
Compute log-probability of argument val In case the argument is out of suport return -Infinity 
Reimplemented from bdm::epdf.
References bdm_assert_debug, dls, and epdfs.
| void bdm::epdf::from_setting | ( | const Setting & | set | ) |  [inline, virtual, inherited] | 
Load from structure with elements:
 { rv = {class="RV", names=(...),}; // RV describing meaning of random variable
   // elements of offsprings
 }
Reimplemented from bdm::root.
Reimplemented in bdm::enorm< sq_T >, bdm::egiw, bdm::egamma, bdm::euni, bdm::merger_base, bdm::merger_mix, bdm::enorm< ldmat >, bdm::enorm< chmat >, and bdm::enorm< fsqmat >.
References bdm::epdf::set_rv().
 1.6.1
 1.6.1