#include <libDC.h>


| Public Member Functions | |
| ldmat (const mat &L, const vec &D) | |
| Construct by copy of L and D. | |
| ldmat (const mat &V) | |
| Construct by decomposition of full matrix V. | |
| ldmat (vec D0) | |
| Construct diagonal matrix with diagonal D0. | |
| ldmat () | |
| Default constructor. | |
| ldmat (const int dim0) | |
| Default initialization with proper size. | |
| virtual | ~ldmat () | 
| Destructor for future use;. | |
| void | opupdt (const vec &v, double w) | 
| mat | to_mat () | 
| Conversion to full matrix. | |
| void | mult_sym (const mat &C) | 
| Inplace symmetric multiplication by a SQUARE matrix  , i.e.  . | |
| void | mult_sym_t (const mat &C) | 
| Inplace symmetric multiplication by a SQUARE transpose of matrix  , i.e.  . | |
| void | add (const ldmat &ld2, double w=1.0) | 
| Add another matrix in LD form with weight w. | |
| double | logdet () const | 
| Logarithm of a determinant. | |
| double | qform (const vec &v) const | 
| Evaluates quadratic form  ;. | |
| double | invqform (const vec &v) const | 
| Evaluates quadratic form  ;. | |
| void | clear () | 
| Clearing matrix so that it corresponds to zeros. | |
| int | cols () const | 
| access function | |
| int | rows () const | 
| access function | |
| vec | sqrt_mult (const vec &v) const | 
| Multiplies square root of  by vector  . | |
| virtual void | inv (ldmat &Inv) const | 
| Matrix inversion preserving the chosen form. | |
| void | mult_sym (const mat &C, ldmat &U) const | 
| Symmetric multiplication of  by a general matrix  , result of which is stored in the current class. | |
| void | mult_sym_t (const mat &C, ldmat &U) const | 
| Symmetric multiplication of  by a transpose of a general matrix  , result of which is stored in the current class. | |
| void | ldform (const mat &A, const vec &D0) | 
| Transforms general  into pure  . | |
| void | setD (const vec &nD) | 
| Access functions. | |
| void | setD (const vec &nD, int i) | 
| Access functions. | |
| void | setL (const vec &nL) | 
| Access functions. | |
| ldmat & | operator+= (const ldmat &ldA) | 
| add another ldmat matrix | |
| ldmat & | operator-= (const ldmat &ldA) | 
| subtract another ldmat matrix | |
| ldmat & | operator*= (double x) | 
| multiply by a scalar | |
| Protected Attributes | |
| vec | D | 
| Positive vector  . | |
| mat | L | 
| Lower-triangular matrix  . | |
| Friends | |
| std::ostream & | operator<< (std::ostream &os, const ldmat &sq) | 
| print both LandD | |
Matrix is decomposed as follows:
![\[M = L'DL\]](form_5.png) 
 where only  and
 and  matrices are stored. All inplace operations modifies only these and the need to compose and decompose the matrix is avoided.
 matrices are stored. All inplace operations modifies only these and the need to compose and decompose the matrix is avoided. 
| void ldmat::opupdt | ( | const vec & | v, | |
| double | w | |||
| ) |  [virtual] | 
| void ldmat::mult_sym | ( | const mat & | C | ) |  [virtual] | 
| void ldmat::mult_sym_t | ( | const mat & | C | ) |  [virtual] | 
| vec ldmat::sqrt_mult | ( | const vec & | v | ) | const  [virtual] | 
Multiplies square root of  by vector
 by vector  .
. 
Used e.g. in generating normal samples.
Implements sqmat.
References D, sqmat::dim, and L.
| void ldmat::inv | ( | ldmat & | Inv | ) | const  [virtual] | 
Matrix inversion preserving the chosen form.
| Inv | a space where the inverse is stored. | 
References clear(), D, sqmat::dim, L, and opupdt().
| void ldmat::mult_sym | ( | const mat & | C, | |
| ldmat & | U | |||
| ) | const | 
| void ldmat::mult_sym_t | ( | const mat & | C, | |
| ldmat & | U | |||
| ) | const | 
| void ldmat::ldform | ( | const mat & | A, | |
| const vec & | D0 | |||
| ) | 
Transforms general  into pure
 into pure  .
. 
The new decomposition fullfills:  
 
| A | general matrix | |
| D0 | general vector | 
References D, sqmat::dim, and L.
Referenced by ldmat(), mult_sym(), and mult_sym_t().
add another ldmat matrix
Operations: mapping of add operation to operators
subtract another ldmat matrix
mapping of negative add operation to operators
 1.5.5
 1.5.5