| | 45 | <tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr> |
| | 46 | <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#b36530e155667fe9f1bd58394e50c65a">opupdt</a> (const vec &v, double w)</td></tr> |
| | 47 | |
| | 48 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="cedf4f048309056f4262c930914dfda8"></a><!-- doxytag: member="fsqmat::to_mat" ref="cedf4f048309056f4262c930914dfda8" args="()" --> |
| | 49 | mat </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#cedf4f048309056f4262c930914dfda8">to_mat</a> ()</td></tr> |
| | 50 | |
| | 51 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Conversion to full matrix. <br></td></tr> |
| | 52 | <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#acc5d2d0a243f1de6d0106065f01f518">mult_sym</a> (const mat &C, bool trans=false)</td></tr> |
| | 53 | |
| | 54 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Inplace symmetric multiplication by a SQUARE matrix $C$, i.e. $V = C*V*C'$. <a href="#acc5d2d0a243f1de6d0106065f01f518"></a><br></td></tr> |
| | 55 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="ccf5ad8fb038f82e9d2201c0606b65fa"></a><!-- doxytag: member="fsqmat::mult_sym" ref="ccf5ad8fb038f82e9d2201c0606b65fa" args="(const mat &C, fsqmat &U, bool trans=false)" --> |
| | 56 | void </td><td class="memItemRight" valign="bottom"><b>mult_sym</b> (const mat &C, <a class="el" href="classfsqmat.html">fsqmat</a> &U, bool trans=false)</td></tr> |
| | 57 | |
| | 58 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="9fa853e1ca28f2a1a1c43377e798ecb1"></a><!-- doxytag: member="fsqmat::inv" ref="9fa853e1ca28f2a1a1c43377e798ecb1" args="(fsqmat &Inv)" --> |
| | 59 | void </td><td class="memItemRight" valign="bottom"><b>inv</b> (<a class="el" href="classfsqmat.html">fsqmat</a> &Inv)</td></tr> |
| | 60 | |
| | 61 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="cfa4c359483d2322f32d1d50050f8ac4"></a><!-- doxytag: member="fsqmat::clear" ref="cfa4c359483d2322f32d1d50050f8ac4" args="()" --> |
| | 62 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#cfa4c359483d2322f32d1d50050f8ac4">clear</a> ()</td></tr> |
| | 63 | |
| | 64 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Clearing matrix so that it corresponds to zeros. <br></td></tr> |
| | 65 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="1929fbc9fe375f1d67f979d0d302336f"></a><!-- doxytag: member="fsqmat::fsqmat" ref="1929fbc9fe375f1d67f979d0d302336f" args="(const mat &M)" --> |
| | 66 | </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#1929fbc9fe375f1d67f979d0d302336f">fsqmat</a> (const mat &M)</td></tr> |
| | 67 | |
| | 68 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Constructor. <br></td></tr> |
| | 69 | <tr><td class="memItemLeft" nowrap align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#788423cc2679620dd6da8d2fca2e3e4d">inv</a> (<a class="el" href="classfsqmat.html">fsqmat</a> *Inv)</td></tr> |
| | 70 | |
| | 71 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Matrix inversion preserving the chosen form. <a href="#788423cc2679620dd6da8d2fca2e3e4d"></a><br></td></tr> |
| | 72 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="bf212272ec195ad2706e2bf4d8e7c9b3"></a><!-- doxytag: member="fsqmat::logdet" ref="bf212272ec195ad2706e2bf4d8e7c9b3" args="()" --> |
| | 73 | double </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#bf212272ec195ad2706e2bf4d8e7c9b3">logdet</a> ()</td></tr> |
| | 74 | |
| | 75 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Logarithm of a determinant. <br></td></tr> |
| | 76 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="6d047b9f7a27dfc093303a13cc9b1fba"></a><!-- doxytag: member="fsqmat::qform" ref="6d047b9f7a27dfc093303a13cc9b1fba" args="(vec &v)" --> |
| | 77 | double </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#6d047b9f7a27dfc093303a13cc9b1fba">qform</a> (vec &v)</td></tr> |
| | 78 | |
| | 79 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Evaluates quadratic form $x= v'*V*v$;. <br></td></tr> |
| | 80 | <tr><td class="memItemLeft" nowrap align="right" valign="top">vec </td><td class="memItemRight" valign="bottom"><a class="el" href="classfsqmat.html#6648dd4291b809cce14e8497d0433ad3">sqrt_mult</a> (vec &v)</td></tr> |
| | 81 | |
| | 82 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Multiplies square root of $V$ by vector $x$. <a href="#6648dd4291b809cce14e8497d0433ad3"></a><br></td></tr> |
| | 83 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="514d1fdd8a382dbd6a774f2cf1ebd3de"></a><!-- doxytag: member="fsqmat::operator+=" ref="514d1fdd8a382dbd6a774f2cf1ebd3de" args="(const fsqmat &A)" --> |
| | 84 | <a class="el" href="classfsqmat.html">fsqmat</a> & </td><td class="memItemRight" valign="bottom"><b>operator+=</b> (const <a class="el" href="classfsqmat.html">fsqmat</a> &A)</td></tr> |
| | 85 | |
| | 86 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="e976bc9d899961e1d2087b0630ed33b7"></a><!-- doxytag: member="fsqmat::operator-=" ref="e976bc9d899961e1d2087b0630ed33b7" args="(const fsqmat &A)" --> |
| | 87 | <a class="el" href="classfsqmat.html">fsqmat</a> & </td><td class="memItemRight" valign="bottom"><b>operator-=</b> (const <a class="el" href="classfsqmat.html">fsqmat</a> &A)</td></tr> |
| | 88 | |
| | 89 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="8f7ce97628a50e06641281096b2af9b7"></a><!-- doxytag: member="fsqmat::operator *=" ref="8f7ce97628a50e06641281096b2af9b7" args="(double x)" --> |
| | 90 | <a class="el" href="classfsqmat.html">fsqmat</a> & </td><td class="memItemRight" valign="bottom"><b>operator *=</b> (double x)</td></tr> |
| | 91 | |
| | 92 | <tr><td colspan="2"><br><h2>Protected Attributes</h2></td></tr> |
| | 93 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="a7a1fcb9aae19d1e4daddfc9c22ce453"></a><!-- doxytag: member="fsqmat::M" ref="a7a1fcb9aae19d1e4daddfc9c22ce453" args="" --> |
| | 94 | mat </td><td class="memItemRight" valign="bottom"><b>M</b></td></tr> |
| | 95 | |
| 49 | | This class can be used to compare performance of algorithms using decomposed matrices with perormance of the same algorithms using full matrices; <hr>The documentation for this class was generated from the following file:<ul> |
| | 100 | This class can be used to compare performance of algorithms using decomposed matrices with perormance of the same algorithms using full matrices; <hr><h2>Member Function Documentation</h2> |
| | 101 | <a class="anchor" name="b36530e155667fe9f1bd58394e50c65a"></a><!-- doxytag: member="fsqmat::opupdt" ref="b36530e155667fe9f1bd58394e50c65a" args="(const vec &v, double w)" --> |
| | 102 | <div class="memitem"> |
| | 103 | <div class="memproto"> |
| | 104 | <table class="memname"> |
| | 105 | <tr> |
| | 106 | <td class="memname">void fsqmat::opupdt </td> |
| | 107 | <td>(</td> |
| | 108 | <td class="paramtype">const vec & </td> |
| | 109 | <td class="paramname"> <em>v</em>, </td> |
| | 110 | </tr> |
| | 111 | <tr> |
| | 112 | <td class="paramkey"></td> |
| | 113 | <td></td> |
| | 114 | <td class="paramtype">double </td> |
| | 115 | <td class="paramname"> <em>w</em></td><td> </td> |
| | 116 | </tr> |
| | 117 | <tr> |
| | 118 | <td></td> |
| | 119 | <td>)</td> |
| | 120 | <td></td><td></td><td width="100%"><code> [virtual]</code></td> |
| | 121 | </tr> |
| | 122 | </table> |
| | 123 | </div> |
| | 124 | <div class="memdoc"> |
| | 125 | |
| | 126 | <p> |
| | 127 | Perfroms a rank-1 update by outer product of vectors: $V = V + w v v'$. <dl compact><dt><b>Parameters:</b></dt><dd> |
| | 128 | <table border="0" cellspacing="2" cellpadding="0"> |
| | 129 | <tr><td valign="top"></td><td valign="top"><em>v</em> </td><td>Vector forming the outer product to be added </td></tr> |
| | 130 | <tr><td valign="top"></td><td valign="top"><em>w</em> </td><td>weight of updating; can be negative</td></tr> |
| | 131 | </table> |
| | 132 | </dl> |
| | 133 | BLAS-2b operation. |
| | 134 | <p>Implements <a class="el" href="classsqmat.html#b223484796661f2dadb5607a86ce0581">sqmat</a>.</p> |
| | 135 | |
| | 136 | </div> |
| | 137 | </div><p> |
| | 138 | <a class="anchor" name="acc5d2d0a243f1de6d0106065f01f518"></a><!-- doxytag: member="fsqmat::mult_sym" ref="acc5d2d0a243f1de6d0106065f01f518" args="(const mat &C, bool trans=false)" --> |
| | 139 | <div class="memitem"> |
| | 140 | <div class="memproto"> |
| | 141 | <table class="memname"> |
| | 142 | <tr> |
| | 143 | <td class="memname">void fsqmat::mult_sym </td> |
| | 144 | <td>(</td> |
| | 145 | <td class="paramtype">const mat & </td> |
| | 146 | <td class="paramname"> <em>C</em>, </td> |
| | 147 | </tr> |
| | 148 | <tr> |
| | 149 | <td class="paramkey"></td> |
| | 150 | <td></td> |
| | 151 | <td class="paramtype">bool </td> |
| | 152 | <td class="paramname"> <em>trans</em> = <code>false</code></td><td> </td> |
| | 153 | </tr> |
| | 154 | <tr> |
| | 155 | <td></td> |
| | 156 | <td>)</td> |
| | 157 | <td></td><td></td><td width="100%"><code> [virtual]</code></td> |
| | 158 | </tr> |
| | 159 | </table> |
| | 160 | </div> |
| | 161 | <div class="memdoc"> |
| | 162 | |
| | 163 | <p> |
| | 164 | Inplace symmetric multiplication by a SQUARE matrix $C$, i.e. $V = C*V*C'$. |
| | 165 | <p> |
| | 166 | <dl compact><dt><b>Parameters:</b></dt><dd> |
| | 167 | <table border="0" cellspacing="2" cellpadding="0"> |
| | 168 | <tr><td valign="top"></td><td valign="top"><em>C</em> </td><td>multiplying matrix, </td></tr> |
| | 169 | <tr><td valign="top"></td><td valign="top"><em>trans</em> </td><td>if true, product $V = C'*V*C$ will be computed instead; </td></tr> |
| | 170 | </table> |
| | 171 | </dl> |
| | 172 | |
| | 173 | <p>Implements <a class="el" href="classsqmat.html#faa3bc90be142adde9cf74f573c70157">sqmat</a>.</p> |
| | 174 | |
| | 175 | </div> |
| | 176 | </div><p> |
| | 177 | <a class="anchor" name="788423cc2679620dd6da8d2fca2e3e4d"></a><!-- doxytag: member="fsqmat::inv" ref="788423cc2679620dd6da8d2fca2e3e4d" args="(fsqmat *Inv)" --> |
| | 178 | <div class="memitem"> |
| | 179 | <div class="memproto"> |
| | 180 | <table class="memname"> |
| | 181 | <tr> |
| | 182 | <td class="memname">virtual void fsqmat::inv </td> |
| | 183 | <td>(</td> |
| | 184 | <td class="paramtype"><a class="el" href="classfsqmat.html">fsqmat</a> * </td> |
| | 185 | <td class="paramname"> <em>Inv</em> </td> |
| | 186 | <td> ) </td> |
| | 187 | <td width="100%"><code> [virtual]</code></td> |
| | 188 | </tr> |
| | 189 | </table> |
| | 190 | </div> |
| | 191 | <div class="memdoc"> |
| | 192 | |
| | 193 | <p> |
| | 194 | Matrix inversion preserving the chosen form. |
| | 195 | <p> |
| | 196 | <dl compact><dt><b>Parameters:</b></dt><dd> |
| | 197 | <table border="0" cellspacing="2" cellpadding="0"> |
| | 198 | <tr><td valign="top"></td><td valign="top"><em>Inv</em> </td><td>a space where the inverse is stored. </td></tr> |
| | 199 | </table> |
| | 200 | </dl> |
| | 201 | |
| | 202 | </div> |
| | 203 | </div><p> |
| | 204 | <a class="anchor" name="6648dd4291b809cce14e8497d0433ad3"></a><!-- doxytag: member="fsqmat::sqrt_mult" ref="6648dd4291b809cce14e8497d0433ad3" args="(vec &v)" --> |
| | 205 | <div class="memitem"> |
| | 206 | <div class="memproto"> |
| | 207 | <table class="memname"> |
| | 208 | <tr> |
| | 209 | <td class="memname">vec fsqmat::sqrt_mult </td> |
| | 210 | <td>(</td> |
| | 211 | <td class="paramtype">vec & </td> |
| | 212 | <td class="paramname"> <em>v</em> </td> |
| | 213 | <td> ) </td> |
| | 214 | <td width="100%"><code> [inline, virtual]</code></td> |
| | 215 | </tr> |
| | 216 | </table> |
| | 217 | </div> |
| | 218 | <div class="memdoc"> |
| | 219 | |
| | 220 | <p> |
| | 221 | Multiplies square root of $V$ by vector $x$. |
| | 222 | <p> |
| | 223 | Used e.g. in generating normal samples. |
| | 224 | <p>Implements <a class="el" href="classsqmat.html#b5236c8a050199e1a9d338b0da1a08d2">sqmat</a>.</p> |
| | 225 | |
| | 226 | </div> |
| | 227 | </div><p> |
| | 228 | <hr>The documentation for this class was generated from the following file:<ul> |