1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
---|
2 | <html xmlns="http://www.w3.org/1999/xhtml"> |
---|
3 | <head> |
---|
4 | <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> |
---|
5 | <title>mixpp: bdm::egiwmix Class Reference</title> |
---|
6 | <link href="tabs.css" rel="stylesheet" type="text/css"/> |
---|
7 | <link href="doxygen.css" rel="stylesheet" type="text/css"/> |
---|
8 | </head> |
---|
9 | <body> |
---|
10 | <!-- Generated by Doxygen 1.6.1 --> |
---|
11 | <script type="text/javascript"> |
---|
12 | <!-- |
---|
13 | function changeDisplayState (e){ |
---|
14 | var num=this.id.replace(/[^[0-9]/g,''); |
---|
15 | var button=this.firstChild; |
---|
16 | var sectionDiv=document.getElementById('dynsection'+num); |
---|
17 | if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){ |
---|
18 | sectionDiv.style.display='block'; |
---|
19 | button.src='open.gif'; |
---|
20 | }else{ |
---|
21 | sectionDiv.style.display='none'; |
---|
22 | button.src='closed.gif'; |
---|
23 | } |
---|
24 | } |
---|
25 | function initDynSections(){ |
---|
26 | var divs=document.getElementsByTagName('div'); |
---|
27 | var sectionCounter=1; |
---|
28 | for(var i=0;i<divs.length-1;i++){ |
---|
29 | if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){ |
---|
30 | var header=divs[i]; |
---|
31 | var section=divs[i+1]; |
---|
32 | var button=header.firstChild; |
---|
33 | if (button!='IMG'){ |
---|
34 | divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild); |
---|
35 | button=document.createElement('img'); |
---|
36 | divs[i].insertBefore(button,divs[i].firstChild); |
---|
37 | } |
---|
38 | header.style.cursor='pointer'; |
---|
39 | header.onclick=changeDisplayState; |
---|
40 | header.id='dynheader'+sectionCounter; |
---|
41 | button.src='closed.gif'; |
---|
42 | section.id='dynsection'+sectionCounter; |
---|
43 | section.style.display='none'; |
---|
44 | section.style.marginLeft='14px'; |
---|
45 | sectionCounter++; |
---|
46 | } |
---|
47 | } |
---|
48 | } |
---|
49 | window.onload = initDynSections; |
---|
50 | --> |
---|
51 | </script> |
---|
52 | <div class="navigation" id="top"> |
---|
53 | <div class="tabs"> |
---|
54 | <ul> |
---|
55 | <li><a href="main.html"><span>Main Page</span></a></li> |
---|
56 | <li><a href="pages.html"><span>Related Pages</span></a></li> |
---|
57 | <li class="current"><a href="annotated.html"><span>Classes</span></a></li> |
---|
58 | <li><a href="files.html"><span>Files</span></a></li> |
---|
59 | </ul> |
---|
60 | </div> |
---|
61 | <div class="tabs"> |
---|
62 | <ul> |
---|
63 | <li><a href="annotated.html"><span>Class List</span></a></li> |
---|
64 | <li><a href="classes.html"><span>Class Index</span></a></li> |
---|
65 | <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li> |
---|
66 | <li><a href="functions.html"><span>Class Members</span></a></li> |
---|
67 | </ul> |
---|
68 | </div> |
---|
69 | <div class="navpath"><b>bdm</b>::<a class="el" href="classbdm_1_1egiwmix.html">egiwmix</a> |
---|
70 | </div> |
---|
71 | </div> |
---|
72 | <div class="contents"> |
---|
73 | <h1>bdm::egiwmix Class Reference</h1><!-- doxytag: class="bdm::egiwmix" --><!-- doxytag: inherits="bdm::egiw" --> |
---|
74 | <p>Mixture of egiws. |
---|
75 | <a href="#_details">More...</a></p> |
---|
76 | <hr/><a name="_details"></a><h2>Detailed Description</h2> |
---|
77 | <p>Mixture of egiws. </p> |
---|
78 | |
---|
79 | <p><code>#include <<a class="el" href="emix_8h_source.html">emix.h</a>></code></p> |
---|
80 | |
---|
81 | <p><a href="classbdm_1_1egiwmix-members.html">List of all members.</a></p> |
---|
82 | <table border="0" cellpadding="0" cellspacing="0"> |
---|
83 | <tr><td colspan="2"><h2>Public Member Functions</h2></td></tr> |
---|
84 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a41f4cf7baf554e0a70bf495457179dbb"></a><!-- doxytag: member="bdm::egiwmix::egiwmix" ref="a41f4cf7baf554e0a70bf495457179dbb" args="()" --> |
---|
85 | </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a41f4cf7baf554e0a70bf495457179dbb">egiwmix</a> ()</td></tr> |
---|
86 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Default constructor. <br/></td></tr> |
---|
87 | <tr><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#ac4627222e22df6e14f8f1496e13c4975">set_parameters</a> (const vec &<a class="el" href="classbdm_1_1egiwmix.html#a2deb6d7cd689949b92450227de98afa4">w</a>, const Array< <a class="el" href="classbdm_1_1egiw.html">egiw</a> * > &<a class="el" href="classbdm_1_1egiwmix.html#a8d0a3acd6ced68349b8f9950f4658280">Coms</a>, bool copy=false)</td></tr> |
---|
88 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a74e7c77bd89a454a7fd984945c58df1c"></a><!-- doxytag: member="bdm::egiwmix::mean" ref="a74e7c77bd89a454a7fd984945c58df1c" args="() const " --> |
---|
89 | vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a74e7c77bd89a454a7fd984945c58df1c">mean</a> () const </td></tr> |
---|
90 | <tr><td class="mdescLeft"> </td><td class="mdescRight">return expected value <br/></td></tr> |
---|
91 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a8bd92fb4c94a46220e84d9a39ddd2e28"></a><!-- doxytag: member="bdm::egiwmix::sample" ref="a8bd92fb4c94a46220e84d9a39ddd2e28" args="() const " --> |
---|
92 | vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a8bd92fb4c94a46220e84d9a39ddd2e28">sample</a> () const </td></tr> |
---|
93 | <tr><td class="mdescLeft"> </td><td class="mdescRight">return a sample from the density <br/></td></tr> |
---|
94 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a96e1cfb7157b87f04e2957ca4d883425"></a><!-- doxytag: member="bdm::egiwmix::variance" ref="a96e1cfb7157b87f04e2957ca4d883425" args="() const " --> |
---|
95 | vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a96e1cfb7157b87f04e2957ca4d883425">variance</a> () const </td></tr> |
---|
96 | <tr><td class="mdescLeft"> </td><td class="mdescRight">return the expected variance <br/></td></tr> |
---|
97 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a99962cd566fc4e6d59099dae6b7ecb8c"></a><!-- doxytag: member="bdm::egiwmix::mean_mat" ref="a99962cd566fc4e6d59099dae6b7ecb8c" args="(mat &M, mat &R) const " --> |
---|
98 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a99962cd566fc4e6d59099dae6b7ecb8c">mean_mat</a> (mat &M, mat &R) const </td></tr> |
---|
99 | <tr><td class="mdescLeft"> </td><td class="mdescRight">expected values of the linear coefficient and the covariance matrix are written to <code>M</code> and <code>R</code> , respectively <br/></td></tr> |
---|
100 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a5713da45d66410382d6eca4e1b05a132"></a><!-- doxytag: member="bdm::egiwmix::evallog_nn" ref="a5713da45d66410382d6eca4e1b05a132" args="(const vec &val) const " --> |
---|
101 | double </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a5713da45d66410382d6eca4e1b05a132">evallog_nn</a> (const vec &val) const </td></tr> |
---|
102 | <tr><td class="mdescLeft"> </td><td class="mdescRight">In this instance, val= [theta, r]. For multivariate instances, it is stored columnwise val = [theta_1 theta_2 ... r_1 r_2 ]. <br/></td></tr> |
---|
103 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a7c9bc72ecea861dd2416f852905bf023"></a><!-- doxytag: member="bdm::egiwmix::lognc" ref="a7c9bc72ecea861dd2416f852905bf023" args="() const " --> |
---|
104 | double </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a7c9bc72ecea861dd2416f852905bf023">lognc</a> () const </td></tr> |
---|
105 | <tr><td class="mdescLeft"> </td><td class="mdescRight">logarithm of the normalizing constant, <img class="formulaInl" alt="$\mathcal{I}$" src="form_97.png"/> <br/></td></tr> |
---|
106 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aab30611d0ca7cc718956548a42a1f67d"></a><!-- doxytag: member="bdm::egiwmix::marginal" ref="aab30611d0ca7cc718956548a42a1f67d" args="(const RV &rv) const " --> |
---|
107 | <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< <a class="el" href="classbdm_1_1epdf.html">epdf</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#aab30611d0ca7cc718956548a42a1f67d">marginal</a> (const <a class="el" href="classbdm_1_1RV.html">RV</a> &<a class="el" href="classbdm_1_1epdf.html#a62c5b8ff71d9ebe6cd58d3c342eb1dc8">rv</a>) const </td></tr> |
---|
108 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Return marginal density on the given <a class="el" href="classbdm_1_1RV.html" title="Class representing variables, most often random variables.">RV</a>, the remainig rvs are intergrated out. <br/></td></tr> |
---|
109 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0f403bb5b09d5855b7098665290434bf"></a><!-- doxytag: member="bdm::egiwmix::marginal" ref="a0f403bb5b09d5855b7098665290434bf" args="(const RV &rv, emix &target) const " --> |
---|
110 | void </td><td class="memItemRight" valign="bottom"><b>marginal</b> (const <a class="el" href="classbdm_1_1RV.html">RV</a> &<a class="el" href="classbdm_1_1epdf.html#a62c5b8ff71d9ebe6cd58d3c342eb1dc8">rv</a>, <a class="el" href="classbdm_1_1emix.html">emix</a> &target) const </td></tr> |
---|
111 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a884d203ca3994b9fba4c8bd440f355ea"></a><!-- doxytag: member="bdm::egiwmix::_w" ref="a884d203ca3994b9fba4c8bd440f355ea" args="()" --> |
---|
112 | vec & </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a884d203ca3994b9fba4c8bd440f355ea">_w</a> ()</td></tr> |
---|
113 | <tr><td class="mdescLeft"> </td><td class="mdescRight">returns a pointer to the internal mean value. Use with Care! <br/></td></tr> |
---|
114 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aadc550fe74df25524c20867e89b5b096"></a><!-- doxytag: member="bdm::egiwmix::ownComs" ref="aadc550fe74df25524c20867e89b5b096" args="()" --> |
---|
115 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#aadc550fe74df25524c20867e89b5b096">ownComs</a> ()</td></tr> |
---|
116 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Auxiliary function for taking ownership of the <a class="el" href="classbdm_1_1egiwmix.html#a8d0a3acd6ced68349b8f9950f4658280" title="Component (epdfs).">Coms()</a>. <br/></td></tr> |
---|
117 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad20a56a7b129c1ea9f71725e15f8ad8c"></a><!-- doxytag: member="bdm::egiwmix::_Coms" ref="ad20a56a7b129c1ea9f71725e15f8ad8c" args="(int i)" --> |
---|
118 | <a class="el" href="classbdm_1_1egiw.html">egiw</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#ad20a56a7b129c1ea9f71725e15f8ad8c">_Coms</a> (int i)</td></tr> |
---|
119 | <tr><td class="mdescLeft"> </td><td class="mdescRight">access function <br/></td></tr> |
---|
120 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="adc999c5c1402c450200f22128db688b2"></a><!-- doxytag: member="bdm::egiwmix::set_rv" ref="adc999c5c1402c450200f22128db688b2" args="(const RV &rv)" --> |
---|
121 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#adc999c5c1402c450200f22128db688b2">set_rv</a> (const <a class="el" href="classbdm_1_1RV.html">RV</a> &<a class="el" href="classbdm_1_1epdf.html#a62c5b8ff71d9ebe6cd58d3c342eb1dc8">rv</a>)</td></tr> |
---|
122 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Name its rv. <br/></td></tr> |
---|
123 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a10894d50e82130cc5b93d3cbc30b2e4d"></a><!-- doxytag: member="bdm::egiwmix::approx" ref="a10894d50e82130cc5b93d3cbc30b2e4d" args="()" --> |
---|
124 | <a class="el" href="classbdm_1_1egiw.html">egiw</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a10894d50e82130cc5b93d3cbc30b2e4d">approx</a> ()</td></tr> |
---|
125 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Approximation of a GiW mix by a single GiW pdf. <br/></td></tr> |
---|
126 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a66d2ba9295c306012b309efcc9e516f0"></a><!-- doxytag: member="bdm::egiwmix::est_theta" ref="a66d2ba9295c306012b309efcc9e516f0" args="() const " --> |
---|
127 | vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a66d2ba9295c306012b309efcc9e516f0">est_theta</a> () const </td></tr> |
---|
128 | <tr><td class="mdescLeft"> </td><td class="mdescRight">LS estimate of <img class="formulaInl" alt="$\theta$" src="form_98.png"/>. <br/></td></tr> |
---|
129 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a88c321a2051d1afdbb31a098896a717b"></a><!-- doxytag: member="bdm::egiwmix::est_theta_cov" ref="a88c321a2051d1afdbb31a098896a717b" args="() const " --> |
---|
130 | <a class="el" href="classbdm_1_1ldmat.html">ldmat</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a88c321a2051d1afdbb31a098896a717b">est_theta_cov</a> () const </td></tr> |
---|
131 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Covariance of the LS estimate. <br/></td></tr> |
---|
132 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a8e610e95401a11baf34f65e16ecd87be"></a><!-- doxytag: member="bdm::egiwmix::pow" ref="a8e610e95401a11baf34f65e16ecd87be" args="(double p)" --> |
---|
133 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a8e610e95401a11baf34f65e16ecd87be">pow</a> (double p)</td></tr> |
---|
134 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Power of the density, used e.g. to flatten the density. <br/></td></tr> |
---|
135 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa36d06ecdd6f4c79dc122510eaccc692"></a><!-- doxytag: member="bdm::egiwmix::evallog" ref="aa36d06ecdd6f4c79dc122510eaccc692" args="(const vec &val) const " --> |
---|
136 | virtual double </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1eEF.html#aa36d06ecdd6f4c79dc122510eaccc692">evallog</a> (const vec &val) const </td></tr> |
---|
137 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Evaluate normalized log-probability. <br/></td></tr> |
---|
138 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a6886c60b6b690e503913240db5de0c6f"></a><!-- doxytag: member="bdm::egiwmix::evallog_m" ref="a6886c60b6b690e503913240db5de0c6f" args="(const mat &Val) const " --> |
---|
139 | virtual vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1eEF.html#a6886c60b6b690e503913240db5de0c6f">evallog_m</a> (const mat &Val) const </td></tr> |
---|
140 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Evaluate normalized log-probability for many samples. <br/></td></tr> |
---|
141 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad793f4fd6d0dcec5f16bff0ae45fc7d5"></a><!-- doxytag: member="bdm::egiwmix::evallog_m" ref="ad793f4fd6d0dcec5f16bff0ae45fc7d5" args="(const Array< vec > &Val) const " --> |
---|
142 | virtual vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1eEF.html#ad793f4fd6d0dcec5f16bff0ae45fc7d5">evallog_m</a> (const Array< vec > &Val) const </td></tr> |
---|
143 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Evaluate normalized log-probability for many samples. <br/></td></tr> |
---|
144 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aaf0e6941ba5919cae1bc530e2181b109"></a><!-- doxytag: member="bdm::egiwmix::to_string" ref="aaf0e6941ba5919cae1bc530e2181b109" args="()" --> |
---|
145 | virtual string </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1root.html#aaf0e6941ba5919cae1bc530e2181b109">to_string</a> ()</td></tr> |
---|
146 | <tr><td class="mdescLeft"> </td><td class="mdescRight">This method returns a basic info about the current instance. <br/></td></tr> |
---|
147 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a67d954d255ede776eade7334d4895790"></a><!-- doxytag: member="bdm::egiwmix::to_setting" ref="a67d954d255ede776eade7334d4895790" args="(Setting &set) const " --> |
---|
148 | virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1root.html#a67d954d255ede776eade7334d4895790">to_setting</a> (Setting &set) const </td></tr> |
---|
149 | <tr><td class="mdescLeft"> </td><td class="mdescRight">This method save all the instance properties into the Setting structure. <br/></td></tr> |
---|
150 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a1c314bd6d6dacb8ba78ea5eb88fd9516"></a><!-- doxytag: member="bdm::egiwmix::validate" ref="a1c314bd6d6dacb8ba78ea5eb88fd9516" args="()" --> |
---|
151 | virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1root.html#a1c314bd6d6dacb8ba78ea5eb88fd9516">validate</a> ()</td></tr> |
---|
152 | <tr><td class="mdescLeft"> </td><td class="mdescRight">This method TODO. <br/></td></tr> |
---|
153 | <tr><td colspan="2"><div class="groupHeader">Constructors</div></td></tr> |
---|
154 | <tr><td colspan="2"><div class="groupText"><p><a class="anchor" id="amgrp559a25fdb98a7d1fd1c3771ac568d5e9"></a> </p> |
---|
155 | <br/><br/></div></td></tr> |
---|
156 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a40b04f8ef133d089c4be2c7983e18b5c"></a><!-- doxytag: member="bdm::egiwmix::set_parameters" ref="a40b04f8ef133d089c4be2c7983e18b5c" args="(int dimx0, ldmat V0, double nu0=-1.0)" --> |
---|
157 | void </td><td class="memItemRight" valign="bottom"><b>set_parameters</b> (int dimx0, <a class="el" href="classbdm_1_1ldmat.html">ldmat</a> V0, double nu0=-1.0)</td></tr> |
---|
158 | <tr><td colspan="2"><div class="groupHeader">Constructors</div></td></tr> |
---|
159 | <tr><td colspan="2"><div class="groupText"><p><a class="anchor" id="amgrp559a25fdb98a7d1fd1c3771ac568d5e9"></a> Construction of each <a class="el" href="classbdm_1_1epdf.html" title="Probability density function with numerical statistics, e.g. posterior density.">epdf</a> should support two types of constructors: </p> |
---|
160 | <ul> |
---|
161 | <li>empty constructor, </li> |
---|
162 | <li>copy constructor,</li> |
---|
163 | </ul> |
---|
164 | <p>The following constructors should be supported for convenience: </p> |
---|
165 | <ul> |
---|
166 | <li>constructor followed by calling <code><a class="el" href="classbdm_1_1egiwmix.html#ac4627222e22df6e14f8f1496e13c4975">set_parameters()</a></code> </li> |
---|
167 | <li>constructor accepting random variables calling <code><a class="el" href="classbdm_1_1egiwmix.html#adc999c5c1402c450200f22128db688b2" title="Name its rv.">set_rv()</a></code> </li> |
---|
168 | </ul> |
---|
169 | <p>All internal data structures are constructed as empty. Their values (including sizes) will be set by method <code><a class="el" href="classbdm_1_1egiwmix.html#ac4627222e22df6e14f8f1496e13c4975">set_parameters()</a></code>. This way references can be initialized in constructors. </p> |
---|
170 | <br/><br/></div></td></tr> |
---|
171 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a840de94aa33cf4f2ebd2427f45a165d8"></a><!-- doxytag: member="bdm::egiwmix::set_parameters" ref="a840de94aa33cf4f2ebd2427f45a165d8" args="(int dim0)" --> |
---|
172 | void </td><td class="memItemRight" valign="bottom"><b>set_parameters</b> (int dim0)</td></tr> |
---|
173 | <tr><td colspan="2"><div class="groupHeader">Access attributes</div></td></tr> |
---|
174 | <tr><td colspan="2"><div class="groupText"><p><a class="anchor" id="amgrp8937227e303215af8852936dc1bf96ca"></a> </p> |
---|
175 | <br/><br/></div></td></tr> |
---|
176 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a15792f3112e5cf67d572f491b09324c8"></a><!-- doxytag: member="bdm::egiwmix::_V" ref="a15792f3112e5cf67d572f491b09324c8" args="()" --> |
---|
177 | <a class="el" href="classbdm_1_1ldmat.html">ldmat</a> & </td><td class="memItemRight" valign="bottom"><b>_V</b> ()</td></tr> |
---|
178 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aad9c539a80a552e837245ddcebcbbba4"></a><!-- doxytag: member="bdm::egiwmix::_V" ref="aad9c539a80a552e837245ddcebcbbba4" args="() const " --> |
---|
179 | const <a class="el" href="classbdm_1_1ldmat.html">ldmat</a> & </td><td class="memItemRight" valign="bottom"><b>_V</b> () const </td></tr> |
---|
180 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa025ee710274ca142dd0ae978735ad4a"></a><!-- doxytag: member="bdm::egiwmix::_nu" ref="aa025ee710274ca142dd0ae978735ad4a" args="()" --> |
---|
181 | double & </td><td class="memItemRight" valign="bottom"><b>_nu</b> ()</td></tr> |
---|
182 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="acf3b2bcb158c15c24788bba90e4154e4"></a><!-- doxytag: member="bdm::egiwmix::_nu" ref="acf3b2bcb158c15c24788bba90e4154e4" args="() const " --> |
---|
183 | const double & </td><td class="memItemRight" valign="bottom"><b>_nu</b> () const </td></tr> |
---|
184 | <tr><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a55b76ec75bd2df5ef9cab3be20a33bbb">from_setting</a> (const Setting &set)</td></tr> |
---|
185 | <tr><td colspan="2"><div class="groupHeader">Matematical Operations</div></td></tr> |
---|
186 | <tr><td colspan="2"><div class="groupText"><p><a class="anchor" id="amgrp96552c993870a5dd6bb0ea321f1ceb78"></a> </p> |
---|
187 | <br/><br/></div></td></tr> |
---|
188 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ab4cf45fd83cc7573ede9fe1215256058"></a><!-- doxytag: member="bdm::egiwmix::sample_m" ref="ab4cf45fd83cc7573ede9fe1215256058" args="(int N) const " --> |
---|
189 | virtual mat </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#ab4cf45fd83cc7573ede9fe1215256058">sample_m</a> (int N) const </td></tr> |
---|
190 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Returns N samples, <img class="formulaInl" alt="$ [x_1 , x_2 , \ldots \ $" src="form_14.png"/> from density <img class="formulaInl" alt="$ f_x(rv)$" src="form_15.png"/>. <br/></td></tr> |
---|
191 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a1499d35b79bce0cfa64fc5cafb9c03b2"></a><!-- doxytag: member="bdm::egiwmix::condition" ref="a1499d35b79bce0cfa64fc5cafb9c03b2" args="(const RV &rv) const " --> |
---|
192 | virtual <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< <a class="el" href="classbdm_1_1mpdf.html">mpdf</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#a1499d35b79bce0cfa64fc5cafb9c03b2">condition</a> (const <a class="el" href="classbdm_1_1RV.html">RV</a> &<a class="el" href="classbdm_1_1epdf.html#a62c5b8ff71d9ebe6cd58d3c342eb1dc8">rv</a>) const </td></tr> |
---|
193 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Return conditional density on the given <a class="el" href="classbdm_1_1RV.html" title="Class representing variables, most often random variables.">RV</a>, the remaining rvs will be in conditioning. <br/></td></tr> |
---|
194 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0a7705e80601957f7226d333a0a6d539"></a><!-- doxytag: member="bdm::egiwmix::qbounds" ref="a0a7705e80601957f7226d333a0a6d539" args="(vec &lb, vec &ub, double percentage=0.95) const " --> |
---|
195 | virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#a0a7705e80601957f7226d333a0a6d539">qbounds</a> (vec &lb, vec &ub, double percentage=0.95) const </td></tr> |
---|
196 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Lower and upper bounds of <code>percentage</code> % quantile, returns mean-2*sigma as default. <br/></td></tr> |
---|
197 | <tr><td colspan="2"><div class="groupHeader">Connection to other classes</div></td></tr> |
---|
198 | <tr><td colspan="2"><div class="groupText"><p><a class="anchor" id="amgrp14fc6e1cb822e9dfc5edc16c20fabe11"></a>Description of the random quantity via attribute <code>rv</code> is optional. For operations such as sampling <code>rv</code> does not need to be set. However, for <code>marginalization</code> and <code>conditioning</code> <code>rv</code> has to be set. NB: </p> |
---|
199 | <br/><br/></div></td></tr> |
---|
200 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ac4b863ff84c7a4882fb3ad18556027f9"></a><!-- doxytag: member="bdm::egiwmix::isnamed" ref="ac4b863ff84c7a4882fb3ad18556027f9" args="() const " --> |
---|
201 | bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#ac4b863ff84c7a4882fb3ad18556027f9">isnamed</a> () const </td></tr> |
---|
202 | <tr><td class="mdescLeft"> </td><td class="mdescRight">True if rv is assigned. <br/></td></tr> |
---|
203 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa4ab378d5e004c3ff3e2d4e64f7bba21"></a><!-- doxytag: member="bdm::egiwmix::_rv" ref="aa4ab378d5e004c3ff3e2d4e64f7bba21" args="() const " --> |
---|
204 | const <a class="el" href="classbdm_1_1RV.html">RV</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#aa4ab378d5e004c3ff3e2d4e64f7bba21">_rv</a> () const </td></tr> |
---|
205 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Return name (fails when isnamed is false). <br/></td></tr> |
---|
206 | <tr><td colspan="2"><div class="groupHeader">Access to attributes</div></td></tr> |
---|
207 | <tr><td colspan="2"><div class="groupText"><p><a class="anchor" id="amgrpb6eb094f9e6af11f8a7d9efa9d8e3623"></a> </p> |
---|
208 | <br/><br/></div></td></tr> |
---|
209 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a7083a65f7b7a0d0d13b2c516bd2ec29c"></a><!-- doxytag: member="bdm::egiwmix::dimension" ref="a7083a65f7b7a0d0d13b2c516bd2ec29c" args="() const " --> |
---|
210 | int </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#a7083a65f7b7a0d0d13b2c516bd2ec29c">dimension</a> () const </td></tr> |
---|
211 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Size of the random variable. <br/></td></tr> |
---|
212 | <tr><td colspan="2"><h2>Protected Attributes</h2></td></tr> |
---|
213 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a2deb6d7cd689949b92450227de98afa4"></a><!-- doxytag: member="bdm::egiwmix::w" ref="a2deb6d7cd689949b92450227de98afa4" args="" --> |
---|
214 | vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a2deb6d7cd689949b92450227de98afa4">w</a></td></tr> |
---|
215 | <tr><td class="mdescLeft"> </td><td class="mdescRight">weights of the components <br/></td></tr> |
---|
216 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a8d0a3acd6ced68349b8f9950f4658280"></a><!-- doxytag: member="bdm::egiwmix::Coms" ref="a8d0a3acd6ced68349b8f9950f4658280" args="" --> |
---|
217 | Array< <a class="el" href="classbdm_1_1egiw.html">egiw</a> * > </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a8d0a3acd6ced68349b8f9950f4658280">Coms</a></td></tr> |
---|
218 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Component (epdfs). <br/></td></tr> |
---|
219 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a2a363169e5aa6c7cad1f4d7647fe9eec"></a><!-- doxytag: member="bdm::egiwmix::destroyComs" ref="a2a363169e5aa6c7cad1f4d7647fe9eec" args="" --> |
---|
220 | bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiwmix.html#a2a363169e5aa6c7cad1f4d7647fe9eec">destroyComs</a></td></tr> |
---|
221 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Flag if owning Coms. <br/></td></tr> |
---|
222 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aae56852845c6af176fd9017dbebbbd52"></a><!-- doxytag: member="bdm::egiwmix::V" ref="aae56852845c6af176fd9017dbebbbd52" args="" --> |
---|
223 | <a class="el" href="classbdm_1_1ldmat.html">ldmat</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#aae56852845c6af176fd9017dbebbbd52">V</a></td></tr> |
---|
224 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Extended information matrix of sufficient statistics. <br/></td></tr> |
---|
225 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a447eacf19d4f4083872686f044814dc4"></a><!-- doxytag: member="bdm::egiwmix::nu" ref="a447eacf19d4f4083872686f044814dc4" args="" --> |
---|
226 | double </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a447eacf19d4f4083872686f044814dc4">nu</a></td></tr> |
---|
227 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Number of data records (degrees of freedom) of sufficient statistics. <br/></td></tr> |
---|
228 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a23e4d78bea7e98840f3da30e76a2b57a"></a><!-- doxytag: member="bdm::egiwmix::dimx" ref="a23e4d78bea7e98840f3da30e76a2b57a" args="" --> |
---|
229 | int </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a23e4d78bea7e98840f3da30e76a2b57a">dimx</a></td></tr> |
---|
230 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Dimension of the output. <br/></td></tr> |
---|
231 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a322414c32d9a21a006a5aab0311f64fd"></a><!-- doxytag: member="bdm::egiwmix::nPsi" ref="a322414c32d9a21a006a5aab0311f64fd" args="" --> |
---|
232 | int </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1egiw.html#a322414c32d9a21a006a5aab0311f64fd">nPsi</a></td></tr> |
---|
233 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Dimension of the regressor. <br/></td></tr> |
---|
234 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a16adac20ec7fe07e1ea0b27d917788ce"></a><!-- doxytag: member="bdm::egiwmix::dim" ref="a16adac20ec7fe07e1ea0b27d917788ce" args="" --> |
---|
235 | int </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#a16adac20ec7fe07e1ea0b27d917788ce">dim</a></td></tr> |
---|
236 | <tr><td class="mdescLeft"> </td><td class="mdescRight">dimension of the random variable <br/></td></tr> |
---|
237 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a62c5b8ff71d9ebe6cd58d3c342eb1dc8"></a><!-- doxytag: member="bdm::egiwmix::rv" ref="a62c5b8ff71d9ebe6cd58d3c342eb1dc8" args="" --> |
---|
238 | <a class="el" href="classbdm_1_1RV.html">RV</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1epdf.html#a62c5b8ff71d9ebe6cd58d3c342eb1dc8">rv</a></td></tr> |
---|
239 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Description of the random variable. <br/></td></tr> |
---|
240 | </table> |
---|
241 | <hr/><h2>Member Function Documentation</h2> |
---|
242 | <a class="anchor" id="a55b76ec75bd2df5ef9cab3be20a33bbb"></a><!-- doxytag: member="bdm::egiwmix::from_setting" ref="a55b76ec75bd2df5ef9cab3be20a33bbb" args="(const Setting &set)" --> |
---|
243 | <div class="memitem"> |
---|
244 | <div class="memproto"> |
---|
245 | <table class="memname"> |
---|
246 | <tr> |
---|
247 | <td class="memname">void bdm::egiw::from_setting </td> |
---|
248 | <td>(</td> |
---|
249 | <td class="paramtype">const Setting & </td> |
---|
250 | <td class="paramname"> <em>set</em></td> |
---|
251 | <td> ) </td> |
---|
252 | <td><code> [inline, virtual, inherited]</code></td> |
---|
253 | </tr> |
---|
254 | </table> |
---|
255 | </div> |
---|
256 | <div class="memdoc"> |
---|
257 | <p>Create Gauss-inverse-Wishart density </p> |
---|
258 | <p class="formulaDsp"> |
---|
259 | <img class="formulaDsp" alt="\[ f(rv) = GiW(V,\nu) \]" src="form_165.png"/> |
---|
260 | </p> |
---|
261 | <p> from structure </p> |
---|
262 | <div class="fragment"><pre class="fragment"> <span class="keyword">class </span>= 'egiw'; |
---|
263 | <a class="code" href="classbdm_1_1egiw.html#aae56852845c6af176fd9017dbebbbd52" title="Extended information matrix of sufficient statistics.">V</a> = []; <span class="comment">// square matrix</span> |
---|
264 | <a class="code" href="classbdm_1_1egiw.html#a447eacf19d4f4083872686f044814dc4" title="Number of data records (degrees of freedom) of sufficient statistics.">nu</a> = []; <span class="comment">// scalar \nu ((almost) degrees of freedom)</span> |
---|
265 | <span class="comment">// when missing, it will be computed to obtain proper pdf</span> |
---|
266 | <a class="code" href="classbdm_1_1egiw.html#a23e4d78bea7e98840f3da30e76a2b57a" title="Dimension of the output.">dimx</a> = []; <span class="comment">// dimension of the wishart part</span> |
---|
267 | <a class="code" href="classbdm_1_1epdf.html#a62c5b8ff71d9ebe6cd58d3c342eb1dc8" title="Description of the random variable.">rv</a> = RV({<span class="stringliteral">'name'</span>}) <span class="comment">// description of RV</span> |
---|
268 | rvc = RV({<span class="stringliteral">'name'</span>}) <span class="comment">// description of RV in condition</span> |
---|
269 | </pre></div> |
---|
270 | <p>Reimplemented from <a class="el" href="classbdm_1_1epdf.html#afa9efc98a065b31c630fe18cc418f725">bdm::epdf</a>.</p> |
---|
271 | |
---|
272 | <p>References <a class="el" href="exp__family_8h_source.html#l00210">bdm::egiw::dimx</a>, <a class="el" href="user__info_8h_source.html#l00443">bdm::UI::get()</a>, <a class="el" href="exp__family_8h_source.html#l00208">bdm::egiw::nu</a>, and <a class="el" href="exp__family_8h_source.html#l00206">bdm::egiw::V</a>.</p> |
---|
273 | |
---|
274 | </div> |
---|
275 | </div> |
---|
276 | <a class="anchor" id="ac4627222e22df6e14f8f1496e13c4975"></a><!-- doxytag: member="bdm::egiwmix::set_parameters" ref="ac4627222e22df6e14f8f1496e13c4975" args="(const vec &w, const Array< egiw * > &Coms, bool copy=false)" --> |
---|
277 | <div class="memitem"> |
---|
278 | <div class="memproto"> |
---|
279 | <table class="memname"> |
---|
280 | <tr> |
---|
281 | <td class="memname">void bdm::egiwmix::set_parameters </td> |
---|
282 | <td>(</td> |
---|
283 | <td class="paramtype">const vec & </td> |
---|
284 | <td class="paramname"> <em>w</em>, </td> |
---|
285 | </tr> |
---|
286 | <tr> |
---|
287 | <td class="paramkey"></td> |
---|
288 | <td></td> |
---|
289 | <td class="paramtype">const Array< <a class="el" href="classbdm_1_1egiw.html">egiw</a> * > & </td> |
---|
290 | <td class="paramname"> <em>Coms</em>, </td> |
---|
291 | </tr> |
---|
292 | <tr> |
---|
293 | <td class="paramkey"></td> |
---|
294 | <td></td> |
---|
295 | <td class="paramtype">bool </td> |
---|
296 | <td class="paramname"> <em>copy</em> = <code>false</code></td><td> </td> |
---|
297 | </tr> |
---|
298 | <tr> |
---|
299 | <td></td> |
---|
300 | <td>)</td> |
---|
301 | <td></td><td></td><td></td> |
---|
302 | </tr> |
---|
303 | </table> |
---|
304 | </div> |
---|
305 | <div class="memdoc"> |
---|
306 | <p>Set weights <code>w</code> and components <code>Coms</code> By default Coms are copied inside. Parameter <code>copy</code> can be set to false if Coms live externally. Use method <a class="el" href="classbdm_1_1egiwmix.html#aadc550fe74df25524c20867e89b5b096" title="Auxiliary function for taking ownership of the Coms().">ownComs()</a> if Coms should be destroyed by the destructor. </p> |
---|
307 | |
---|
308 | <p>References <a class="el" href="bdmerror_8h_source.html#l00047">bdm_assert_debug</a>, <a class="el" href="bdmerror_8h_source.html#l00051">bdm_error</a>, <a class="el" href="emix_8h_source.html#l00211">Coms</a>, <a class="el" href="emix_8h_source.html#l00213">destroyComs</a>, <a class="el" href="bdmbase_8h_source.html#l00329">bdm::epdf::dim</a>, <a class="el" href="bdmbase_8h_source.html#l00435">bdm::epdf::dimension()</a>, and <a class="el" href="emix_8h_source.html#l00209">w</a>.</p> |
---|
309 | |
---|
310 | </div> |
---|
311 | </div> |
---|
312 | <hr/>The documentation for this class was generated from the following files:<ul> |
---|
313 | <li><a class="el" href="emix_8h_source.html">emix.h</a></li> |
---|
314 | <li>emix.cpp</li> |
---|
315 | </ul> |
---|
316 | </div> |
---|
317 | <hr size="1"/><address style="text-align: right;"><small>Generated on Fri Sep 18 00:12:04 2009 for mixpp by |
---|
318 | <a href="http://www.doxygen.org/index.html"> |
---|
319 | <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address> |
---|
320 | </body> |
---|
321 | </html> |
---|