C++ main module for mmsd Package
1.0
|
this class describes a full symmetric matrix for lapack used More...
#include <LAP_DoubleFullSymmetricMatrix.h>
Public Member Functions | |
LAP_DoubleFullSymmetricMatrix () | |
build a matrix More... | |
LAP_DoubleFullSymmetricMatrix (const LAP_DoubleFullSymmetricMatrix &mat) | |
build a matrix for equality operator in construction More... | |
virtual | ~LAP_DoubleFullSymmetricMatrix () |
destroy a matrix More... | |
virtual SP::LAP_DoubleMatrix | NewInstance () const |
create a New instance of this More... | |
virtual double & | operator() (const tLVectorIndex &i, const tLVectorIndex &j) |
accessor of element at row i and column j taking into account the view only use the upper diagonal More... | |
virtual const double & | operator() (const tLVectorIndex &i, const tLVectorIndex &j) const |
accessor of element at row i and column j taking into account the view only use the upper diagonal More... | |
LAP_DoubleFullSymmetricMatrix & | operator= (const double &s) |
init all the matrix to s More... | |
LAP_DoubleFullSymmetricMatrix & | operator= (const LAP_DoubleFullSymmetricMatrix &s) |
init all the matrix to s More... | |
LAP_DoubleFullSymmetricMatrix & | operator^= (const lapack_real &s) |
power by s the matrix v More... | |
LAP_DoubleFullSymmetricMatrix & | operator*= (const lapack_real &s) |
multiply by s the matrix More... | |
LAP_DoubleFullSymmetricMatrix & | operator/= (const lapack_real &s) |
divide by s the matrix v More... | |
LAP_DoubleFullSymmetricMatrix & | operator+= (const lapack_real &s) |
add s to the upper matrix More... | |
LAP_DoubleFullSymmetricMatrix & | operator-= (const lapack_real &s) |
sub s to the upper matrix More... | |
LAP_DoubleFullSymmetricMatrix & | operator*= (const LAP_DoubleFullSymmetricMatrix &s) |
multiply the viewed matrices term by term More... | |
LAP_DoubleFullSymmetricMatrix & | operator/= (const LAP_DoubleFullSymmetricMatrix &s) |
divide the viewed matrices term by term More... | |
LAP_DoubleFullSymmetricMatrix & | operator-= (const LAP_DoubleFullSymmetricMatrix &s) |
sub the viewed matrix More... | |
LAP_DoubleFullSymmetricMatrix & | operator+= (const LAP_DoubleFullSymmetricMatrix &s) |
add the viewed matrix More... | |
LAP_DoubleFullSymmetricMatrix & | operator*= (const LAP_DoublePackedSymmetricMatrix &s) |
multiply the viewed matrices term by term More... | |
LAP_DoubleFullSymmetricMatrix & | operator/= (const LAP_DoublePackedSymmetricMatrix &s) |
divide the viewed matrices term by term More... | |
LAP_DoubleFullSymmetricMatrix & | operator-= (const LAP_DoublePackedSymmetricMatrix &s) |
sub the viewed matrix More... | |
LAP_DoubleFullSymmetricMatrix & | operator+= (const LAP_DoublePackedSymmetricMatrix &s) |
add the viewed matrix More... | |
void | copyUpperToLowerSubMatrix () |
copy the upper part to the lower part of the matrix More... | |
virtual void | setSize (const tLVectorIndex &n, const tLVectorIndex &p) |
set the dimension of the matrix and allocate the values array More... | |
virtual void | setSize (const tLVectorIndex &n) |
set the dimension of the matrix and alocate the values array More... | |
virtual void | setValues (SP::LAP_DoubleVector v) |
set the values of the matrix to V without allocation the values array More... | |
virtual void | setValues (const tLVectorIndex &n, const double *values) |
set the values More... | |
LAP_DoubleFullStorage & | getFullStorage () |
GET. More... | |
const LAP_DoubleFullStorage & | getFullStorage () const |
get the full storage More... | |
tLVectorIndex | getRowIncrement () const |
get the memory distance between (*this)(i,j) & (*this)(i+1,j) More... | |
tLVectorIndex | getLeadingDimension () const |
get the memory distance between (*this)(i,j) & (*this)(i,j+1) More... | |
virtual tLVectorIndex | getRowsNumber () const |
get the lines number of the matrix from view More... | |
virtual tLVectorIndex | getColumnsNumber () const |
get the columns number of the matrix from view More... | |
virtual void | getColumn (const tLVectorIndex &j, LAP_DoubleVector &v) const |
get the j-th column of this symmetric matrix in a vector More... | |
virtual void | getColumn (const tLVectorIndex &j, SP::LAP_DoubleVector v) const |
get the j-th column of this symmetric matrix in a vector More... | |
void | getColumnByReference (const tLVectorIndex &j, LAP_DoubleVector &v) |
get the column by reference the values of v pointer to the values of the column j of this More... | |
void | getColumnByReference (const tLVectorIndex &j, LAP_ConstDoubleVector &v) const |
get the column by reference the values of v pointer to the values of the column j of this More... | |
virtual void | getRow (const tLVectorIndex &i, LAP_DoubleVector &v) const |
get the i-th row in a vector More... | |
virtual void | getRow (const tLVectorIndex &i, SP::LAP_DoubleVector v) const |
get the i-th row in a vector More... | |
virtual tReal | norm2 () const |
return norm2 sqrt(sum_ij(aij^2))=sqrt(tr(AtA)); More... | |
virtual tReal | norm2 (LAP_DoubleVector &v) const |
return norm2 of the matrix and for each row; More... | |
virtual tReal | sum (const tFlag &d, LAP_DoubleVector &s) const |
make the sum among the direction if (d==ROW) sum all the columns of each row and size of s is the number of rows if (d==COL) sum all the rows of each column and size of s is the number of columns ^return the sum of all the element of the matrix More... | |
virtual tReal | sum (const tFlag &d, const tLVectorIndex &index) const |
make the sum among the direction if (d==ROW) sum all the columns of row index if (d==COL) sum all the rows of coluln at index More... | |
virtual tReal | max (const tFlag &d, const tLVectorIndex &index) const |
make get max among the direction if (d==ROW) max of all the columns of row index if (d==COL) max of all the rows of column at index More... | |
void | indexMin (tLVectorIndex &i, tLVectorIndex &j) const |
get the index of the min view element in absolute value More... | |
virtual void | vectorProduct (const LAP_DoubleVector &X, LAP_DoubleVector &Y) |
compute Y=A.X More... | |
virtual void | vectorProduct (const LAP_DoubleVector &X, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleVector &Y) const |
compute Y:=betaY+alpha.This.X More... | |
virtual void | vectorProduct (const LAP_ConstDoubleVector &X, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleVector &Y) const |
compute Y:=betaY+alpha.This.X More... | |
virtual void | vectorProduct (const tBoolean &isTrans, const tLVectorIndex &nX, const tLVectorIncrement &incX, const double *X, const lapack_real &alpha, const lapack_real &beta, const tLVectorIndex &nY, const tLVectorIncrement &incY, double *Y) const |
compute Y= op(This). X with op(A)=A or tA depending on isTrans value More... | |
virtual void | vectorProduct (const tLVectorIndex &nx, const tLVectorIncrement &incx, const double *x, const lapack_real &alpha, const lapack_real &beta, const tLVectorIndex &ny, const tLVectorIncrement &incy, double *y) const |
compute Y= betaY + alpha. This. X More... | |
virtual void | dotProduct (const LAP_DoubleVector &v) |
compute the symmetric matrix S= X.tX only the upper symmetric matric is set. (lapack method dsyr called) More... | |
virtual void | dotProduct (const double &alpha, const LAP_DoubleVector &X) |
compute the symmetric matrix S:= alpha X.tX only the upper symmetric matric is set. (lapack method dsyr called) More... | |
void | rankSymmetricProduct (const LAP_DoubleFullGeneralMatrix &A) |
compute the symmetric matrix S:=alpha op(A).t(op(A)) More... | |
void | rankSymmetricProduct (const double &alpha, const tBoolean &isTrans, const LAP_DoubleFullGeneralMatrix &A) |
compute the symmetric matrix S:=alpha op(A).t(op(A)) More... | |
virtual void | rankSymmetricProduct (const double &alpha, const double &beta, const tBoolean &isTrans, const LAP_DoubleFullGeneralMatrix &A) |
compute the symmetric matrix S:=beta.S+ alpha op(A).t(op(A)) only the upper symmetric matric is set. (lapack method dsyrk called) More... | |
virtual void | rankSymmetricProduct (const double &alpha, const double &beta, const tLVectorIndex &nARows, const tLVectorIndex &nACols, const tLVectorIncrement &incA, const tLVectorIndex &ldA, const tBoolean &isTransA, const double *A) |
compute the symmetric matrix S:=beta.S+ alpha op(A).t(op(A)) only the upper symmetric matric is set. (lapack method dsyrk called) More... | |
void | rankSymmetricProduct (const LAP_DoubleVector &D, const LAP_DoubleFullGeneralMatrix &A) |
compute the symmetric matrix S:=alpha op(A).t(op(A)) More... | |
void | rankSymmetricProduct (const LAP_DoubleVector &D, const double &alpha, const tBoolean &isTrans, const LAP_DoubleFullGeneralMatrix &A) |
compute the symmetric matrix S:=alpha op(A).t(op(A)) More... | |
virtual void | rankSymmetricProduct (const LAP_DoubleVector &D, const double &alpha, const double &beta, const tBoolean &isTrans, const LAP_DoubleFullGeneralMatrix &A) |
compute the symmetric matrix S:=beta.S+ alpha op(A).t(op(A)) only the upper symmetric matric is set. (lapack method dsyrk called) More... | |
virtual SP::LAP_DoubleMatrix | matrixProduct (const LAP_DoubleMatrix &B) const |
return C=(This) . B More... | |
void | matrixProduct (const LAP_DoubleFullSymmetricMatrix &B, LAP_DoubleFullGeneralMatrix &C) const |
return C=(This) . B More... | |
void | matrixProduct (const LAP_DoubleFullGeneralMatrix &B, LAP_DoubleFullGeneralMatrix &C) const |
return C=(This) . B More... | |
virtual void | matrixProduct (const LAP_DoubleFullGeneralMatrix &B, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleFullGeneralMatrix &C) const |
return C=(This) . B (lefside=true) or B. (this) (lefside=false) More... | |
virtual void | matrixProduct (const tBoolean &leftSide, const LAP_DoubleFullGeneralMatrix &B, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleFullGeneralMatrix &C) const |
make the product C = alpha. This . B +beta C if leftSide=true C = alpha. B . This +beta C if leftSide=false More... | |
virtual void | matrixProduct (const tBoolean &leftSide, const tLVectorIndex &nBRows, const tLVectorIndex &nBCols, const tLVectorIncrement &incB, const tLVectorIndex &ldB, const double *B, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleFullGeneralMatrix &C) const |
make the product: More... | |
virtual tBoolean | computeEigenValues (LAP_DoubleVector &U) const |
compute the eigen values of This: A is copied in ascending order More... | |
tBoolean | computeEigenValueDecomposition (LAP_DoubleVector &U) |
compute the eigen elements in ascending order of This the eigen vectors are set in This: This is destroyed IN : only the upper part of This is considered (So A is considered to be symmetric) OUT: This contains its eigen vectors and it is considered as symmetric dsyev lapack method called More... | |
tBoolean | computeEigenValueDecomposition (LAP_DoubleVector &U, LAP_DoubleFullGeneralMatrix &VR) const |
compute the eigen values in ascending order decomposition on this: More... | |
virtual tBoolean | computeEigenValueDecomposition (LAP_DoubleVector &U, LAP_DoubleMatrix &VR) const |
compute the eigen values decomposition in acending order on This More... | |
tBoolean | computeEigenValueDecomposition (LAP_DoubleVector &U, LAP_DoubleFullGeneralMatrix &VR, const int &il, const int &iu) const |
compute the eigen elements in ascending order of This supposed to be symmetric, the eigen vectors are set in Z, A must be symmetric and is copied only the eigen values & vectors are computed in index il and iu when the iegen values are ordering in an ascent order. More... | |
tBoolean | inverse () |
inverse the matrix More... | |
virtual SP::LAP_DoubleUpperMatrix | choleskyFactorization () |
compute the choleskey factorization of the full symmetric matrix A is modified such that the upper matrix of A is the matrix upper triangular matrix U : A = tU. U More... | |
virtual tBoolean | BunchKaufmanFactorization (LAP_IntegerVector &ipiv) |
compute the Bunch Kaufman factorization of the full symmetric matrix A is modified such that the upper matrix of A is the matrix upper triangular uniy diagonal matrix U : A = U. D. tU More... | |
virtual tBoolean | isSymmetric () const |
return true if the matrix is symmetric More... | |
virtual tBoolean | isUpper () const |
return true if the matrix is upper More... | |
const double & | operator[] (const tLVectorIndex &index) const |
get the element at index More... | |
double & | operator[] (const tLVectorIndex &index) |
get the element at index More... | |
virtual tBoolean | copy (const LAP_DoubleMatrix &x) |
copy a matrix More... | |
tBoolean | copy (SPC::LAP_DoubleMatrix x) |
copy a matrix More... | |
tBoolean | copy (LAP_DoubleMatrix *x) |
copy a matrix More... | |
virtual tBoolean | copy (const LAP_Matrix &matrix) |
copy operator More... | |
void | init (const double v) |
init the values to v More... | |
void | set (const tLVectorIndex &i, const tLVectorIndex &j, const double &v) |
set the value of the element at row i and column j More... | |
void | add (const tLVectorIndex &i, const tLVectorIndex &j, const double &v) |
add v to the view term (i,j) of the matrix More... | |
void | setStorage (SP::LAP_DoubleMatrixStorage s) |
set the storage More... | |
double | get (const tLVectorIndex &i, const tLVectorIndex &j) const |
get the value taking into account the view More... | |
LAP_DoubleMatrixStorage & | getStorage () |
set the storage More... | |
const LAP_DoubleMatrixStorage & | getStorage () const |
set the storage More... | |
double | trace () const |
return trace More... | |
void | addDiagonal (const double &alpha) |
This +=alpha.I. More... | |
pair< tLVectorIndex, tLVectorIndex > | computeBandsNumber () const |
double | getFillRate () const |
get the fill rate of the matrix More... | |
tLVectorIndex | getNullValuesNumber () const |
get the number of null values More... | |
tLVectorIndex | getValuesNumber () const |
get the number of values More... | |
virtual SP::LAP_DoubleVector | vectorProduct (const LAP_DoubleVector &X) const |
compute This. X More... | |
virtual void | vectorProduct (const LAP_DoubleVector &X, LAP_DoubleVector &Y) const |
compute Y= This. X More... | |
virtual void | vectorProduct (SPC::LAP_DoubleVector &X, SP::LAP_DoubleVector &Y) const |
rcompute Y= This X More... | |
virtual void | vectorProduct (const tBoolean &isTrans, const LAP_DoubleVector &X, LAP_DoubleVector &Y) const |
compute Y= op(This). X More... | |
virtual void | vectorProduct (const tBoolean &isTrans, const tLVectorIndex &nX, const tLVectorIncrement &incX, const double *X, const double &alpha, const double &beta, const tLVectorIndex &nY, const tLVectorIncrement &incY, double *Y) const =0 |
compute Y= beta Y + alpha op(This). X with op(A)=A or tA depending on isTrans value More... | |
virtual tString | toString () const |
print the matrix taking into account the view More... | |
const tLVectorIndex & | getSize (const tFlag &direction) const |
get the size in direction More... | |
double & | getNullValue () |
get a null value More... | |
const double & | getNullValue () const |
get a const null value More... | |
tBoolean | isNullValue (const double &v) const |
return true if the value is a null More... | |
void | getSharedPointer (SP::CORE_Object &p) |
get the shared pointer of this class into p More... | |
void | getSharedPointer (SPC::CORE_Object &p) const |
get the shared pointer of this class into p More... | |
tString | getClassName () const |
return the class name of the object More... | |
tString | getIdentityString () const |
return the identity string of the object of the form className_at_address More... | |
tString | getPointerAddress () const |
return the identity string of the object More... | |
template<class T > | |
tBoolean | isInstanceOf () const |
return true if the object is an instance of T More... | |
virtual void | print () |
print the class More... | |
virtual ostream & | print (ostream &out) const |
print the class More... | |
virtual void | print (const tString &message) |
print the class More... | |
virtual void | print (const tInteger &str) |
print More... | |
virtual void | print (const tRelativeInteger &str) |
print More... | |
virtual void | print (const tReal &str) |
print More... | |
virtual void | print (const int &str) |
print More... | |
Static Public Member Functions | |
static SP::LAP_DoubleFullSymmetricMatrix | New () |
static SP::LAP_DoubleFullSymmetricMatrix | New (const tLVectorIndex &n) |
static SP::LAP_DoubleFullSymmetricMatrix | Identity (const tLVectorIndex &nRows) |
create an identity matrix More... | |
static void | matrixProduct (const tBoolean &leftSide, const LAP_DoubleFullSymmetricMatrix &S, const LAP_DoubleFullGeneralMatrix &B, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleFullGeneralMatrix &C) |
make the product C = alpha. S . B +beta C if leftSide=true C = alpha. B . S +beta C if leftSide=false dsymm lapack method called More... | |
static void | matrixProduct (const tBoolean &leftSide, const LAP_DoubleFullSymmetricMatrix &S1, const LAP_DoubleFullSymmetricMatrix &S2, const lapack_real &alpha, const lapack_real &beta, LAP_DoubleFullGeneralMatrix &C) |
make the product C = alpha. S1 . S2 +beta C if leftSide=true C = alpha. S2 . S1 +beta C if leftSide=false dsymm C-lapack method called More... | |
static tBoolean | computeEigenValues (LAP_DoubleFullSymmetricMatrix &A, LAP_DoubleVector &U) |
compute the eigen values of A in ascending order and A is destroyed after method lapack method dsyev called More... | |
static tBoolean | computeEigenValueDecomposition (LAP_DoubleFullSymmetricMatrix &A, LAP_DoubleVector &U, LAP_DoubleFullGeneralMatrix &VR) |
compute the eigen elements of A in ascedning order the eigen vectors are set in A: A is destroyed IN : only the upper part of A is considered (So A is considered to be symmetric) OUT: A & VR contains its eigen vectors dsyev lapack method called More... | |
static tBoolean | computeEigenValueDecomposition (LAP_DoubleFullSymmetricMatrix &A, LAP_DoubleVector &U, LAP_DoubleFullGeneralMatrix &Z, const lapack_int &il, const lapack_int &ul) |
compute the eigen elements of A in ascending order . A is supposed to be symmetric, the eigen vectors are set in Z, A must be symmetric. only the eigen values & vectors are computed in index il and iu when the iegen values are ordering in an ascent order. More... | |
static tBoolean | inverse (LAP_DoubleFullSymmetricMatrix &A) |
inverse a symmetric matrix dsytrf & dsytri lapack methods called More... | |
static tBoolean | inverse (LAP_DoubleFullSymmetricMatrix &A, const LAP_IntegerVector &ipiv) |
inverse a symmetric matrix dsytrf & dsytri lapack methods called More... | |
static double | zpow (const double &f, const int &n) |
compute the value of pow(f,n)=f^n More... | |
static tString | getClassName (const tString &identityString) |
return the class name of the object using only the identity string More... | |
template<class T > | |
static tString | getTypeName () |
get type name More... | |
static tBoolean | is64Architecture () |
return true if the machine is a 64 bits machine More... | |
static tBoolean | is32Architecture () |
return true if the machine is a 32 bits machine More... | |
static tString | pointer2String (const void *obj) |
return the string represantation of a pointer More... | |
static void | setOutput (ostream &out) |
set output More... | |
static ostream & | getOutput () |
get output More... | |
static void | printObjectsInMemory () |
print object in memory More... | |
static ostream & | print (ostream &out, const tString &message) |
print the class More... | |
static void | outputPrint (const tString &message) |
Static Public Attributes | |
static const tFlag | ROW =0 |
static const tFlag | COL =1 |
static double | ZERO_EPSILON =1.e-18 |
static tBoolean | mIsMemoryTesting =false |
indicator to store all classes created and deleted only for debuging version More... | |
Protected Member Functions | |
void | setThis (SP::CORE_Object p) |
set this weak shared pointer called toDoAfterThis setting method More... | |
virtual void | setType (tString type) |
set the type of the object More... | |
virtual void | toDoAfterThisSetting () |
method called after setThis() method this method can oly be called once. More... | |
this class describes a full symmetric matrix for lapack used
This class describes a matrix
LAP_DoubleFullSymmetricMatrix::LAP_DoubleFullSymmetricMatrix | ( | ) |
build a matrix
References LAP_DoubleFullStorage::New(), and LAP_DoubleMatrix::setStorage().
Referenced by New().
LAP_DoubleFullSymmetricMatrix::LAP_DoubleFullSymmetricMatrix | ( | const LAP_DoubleFullSymmetricMatrix & | mat | ) |
build a matrix for equality operator in construction
References LAP_DoubleMatrix::copy(), LAP_DoubleFullStorage::New(), and LAP_DoubleMatrix::setStorage().
|
virtual |
destroy a matrix
|
inlineinherited |
add v to the view term (i,j) of the matrix
i | : row of the element |
j | column of the element |
v | value to add |
|
inlineinherited |
This +=alpha.I.
Referenced by MATH_StiefelOptimizer::minimize().
|
inlinevirtual |
compute the Bunch Kaufman factorization of the full symmetric matrix A is modified such that the upper matrix of A is the matrix upper triangular uniy diagonal matrix U : A = U. D. tU
|
inlinevirtual |
compute the choleskey factorization of the full symmetric matrix A is modified such that the upper matrix of A is the matrix upper triangular matrix U : A = tU. U
Implements LAP_DoubleSymmetricMatrix.
|
inlineinherited |
|
inline |
compute the eigen elements in ascending order of This the eigen vectors are set in This: This is destroyed IN : only the upper part of This is considered (So A is considered to be symmetric) OUT: This contains its eigen vectors and it is considered as symmetric dsyev lapack method called
|
inline |
compute the eigen values in ascending order decomposition on this:
U | the eigen values |
VR | the eigen vectors matrix Note that This is copied dsyev lapack method called |
References LAP_DoubleMatrix::copy(), getRowsNumber(), LAP_DoubleMatrix::getStorage(), LAP_DoubleMatrixStorage::getValuesPointer(), LAP_DoubleFullGeneralMatrix::setValues(), tBoolean, and tLVectorIndex.
|
inlinestatic |
compute the eigen elements of A in ascedning order the eigen vectors are set in A: A is destroyed IN : only the upper part of A is considered (So A is considered to be symmetric) OUT: A & VR contains its eigen vectors dsyev lapack method called
References getRowsNumber(), LAP_DoubleMatrix::getStorage(), LAP_DoubleMatrixStorage::getValuesPointer(), LAP_DoubleFullGeneralMatrix::setValues(), and tBoolean.
|
inlinevirtual |
compute the eigen values decomposition in acending order on This
U | the eigen values |
VR | the eigen vectors |
References LAP_DoubleMatrix::copy(), and null.
|
inline |
compute the eigen elements in ascending order of This supposed to be symmetric, the eigen vectors are set in Z, A must be symmetric and is copied only the eigen values & vectors are computed in index il and iu when the iegen values are ordering in an ascent order.
|
inlinestatic |
compute the eigen elements of A in ascending order . A is supposed to be symmetric, the eigen vectors are set in Z, A must be symmetric. only the eigen values & vectors are computed in index il and iu when the iegen values are ordering in an ascent order.
A | (IN/OUT) symmetric Matrix |
U | eigen values (OUT) |
Z | eigen vectors (OUT) |
il | min eigen values index >= 1 |
ul | : max eigen values index <= A.getSize(ROW) dsyevx lapack method called |
References DoubleFullSymmetricMatrixBoundedEigenValues(), getColumnsNumber(), getLeadingDimension(), LAP_DoubleFullGeneralMatrix::getLeadingDimension(), getRowIncrement(), getRowsNumber(), lapack_int, LAP_Vector< T >::resetView(), LAP_DoubleFullGeneralMatrix::setSize(), LAP_Vector< T >::setSize(), and tLVectorIndex.
|
inlinestatic |
compute the eigen values of A in ascending order and A is destroyed after method lapack method dsyev called
References DoubleFullSymmetricMatrixEigenValues(), getColumnsNumber(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), lapack_int, LAP_Vector< T >::resetView(), LAP_Vector< T >::setSize(), and tLVectorIndex.
Referenced by MMSD_DoubleSymmetricMatrix::computeEigenValues(), and computeEigenValues().
|
inlinevirtual |
compute the eigen values of This: A is copied in ascending order
Implements LAP_DoubleMatrix.
References computeEigenValues().
|
inlinevirtualinherited |
copy operator
m | matrix to copy |
References LAP_Matrix::COL, LAP_Matrix::getSize(), and LAP_Matrix::ROW.
Referenced by LAP_DoubleMatrix::copy().
|
virtualinherited |
copy a matrix
x | the matrix to copy |
References LAP_Matrix::copy(), LAP_DoubleMatrixStorage::copy(), LAP_DoubleMatrix::getStorage(), LAP_DoubleMatrix::isSymmetric(), LAP_DoubleFullGeneralMatrix::isTransposed(), LAP_DoubleMatrix::isUpper(), null, and tBoolean.
Referenced by LAP_DoubleBandedSymmetricMatrix::computeEigenValueDecomposition(), LAP_DoubleFullUpperMatrix::computeEigenValueDecomposition(), LAP_DoubleFullGeneralMatrix::computeEigenValueDecomposition(), LAP_DoublePackedSymmetricMatrix::computeEigenValueDecomposition(), computeEigenValueDecomposition(), LAP_DoubleMatrix::copy(), MMSD_DoubleSymmetricMatrix::copy(), LAP_DoubleBandedSymmetricMatrix::LAP_DoubleBandedSymmetricMatrix(), LAP_DoubleBandedUpperMatrix::LAP_DoubleBandedUpperMatrix(), LAP_DoubleFullGeneralMatrix::LAP_DoubleFullGeneralMatrix(), LAP_DoubleFullSymmetricMatrix(), LAP_DoubleFullUpperMatrix::LAP_DoubleFullUpperMatrix(), LAP_DoublePackedSymmetricMatrix::LAP_DoublePackedSymmetricMatrix(), LAP_DoublePackedUpperMatrix::LAP_DoublePackedUpperMatrix(), LAP_DoublePackedUpperMatrix::matrixProduct(), LAP_DoubleBandedUpperMatrix::matrixProduct(), LAP_DoubleFullUpperMatrix::matrixProduct(), LAP_DoubleFullGeneralMatrix::matrixProduct(), MATH_StiefelOptimizer::minimize(), LAP_DoubleBandedUpperMatrix::operator=(), LAP_DoubleBandedSymmetricMatrix::operator=(), LAP_DoublePackedSymmetricMatrix::operator=(), LAP_DoubleFullUpperMatrix::operator=(), operator=(), LAP_DoubleFullGeneralMatrix::operator=(), LAP_DoublePackedUpperMatrix::operator=(), and LAP_DoubleFullGeneralMatrix::solve().
|
inlineinherited |
copy a matrix
x | the matrix to copy |
References LAP_DoubleMatrix::copy(), and null.
|
inlineinherited |
copy a matrix
x | the matrix to copy |
References LAP_DoubleMatrix::copy(), and null.
void LAP_DoubleFullSymmetricMatrix::copyUpperToLowerSubMatrix | ( | ) |
copy the upper part to the lower part of the matrix
References getColumnsNumber(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), tLVectorIncrement, and tLVectorIndex.
|
inlinevirtual |
compute the symmetric matrix S= X.tX only the upper symmetric matric is set. (lapack method dsyr called)
|
inlinevirtual |
compute the symmetric matrix S:= alpha X.tX only the upper symmetric matric is set. (lapack method dsyr called)
References DoubleFullSymmetricMatrixRankSymmetricProduct(), LAP_Vector< T >::getIncrement(), getLeadingDimension(), LAP_Vector< T >::getSize(), setSize(), and tLVectorIndex.
|
inlineinherited |
get the value taking into account the view
Referenced by MMSD_DataSet::getProperties(), LAP_DoubleBandedSymmetricMatrix::matrixProduct(), LAP_DoublePackedUpperMatrix::matrixProduct(), LAP_DoublePackedSymmetricMatrix::matrixProduct(), LAP_DoubleBandedUpperMatrix::matrixProduct(), matrixProduct(), LAP_DoubleFullUpperMatrix::matrixProduct(), LAP_DoubleFullGeneralMatrix::matrixProduct(), testEigenFunction(), testOptimize(), testOptimizerGProject1(), testOptimizerGProject2(), and testOptimizerHInverse().
return the class name of the object using only the identity string
Referenced by UI_Class::createVector2D(), LAP_DoublePackedUpperMatrix::matrixProduct(), LAP_DoubleBandedUpperMatrix::matrixProduct(), LAP_DoubleFullUpperMatrix::matrixProduct(), and CORE_Object::printObjectsInMemory().
|
inherited |
return the class name of the object
References tString.
Referenced by CORE_Object::getIdentityString().
|
virtual |
get the j-th column of this symmetric matrix in a vector
Implements LAP_DoubleMatrix.
References getColumnsNumber(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), LAP_Vector< T >::resetView(), LAP_Vector< T >::setSize(), tLVectorIncrement, and tLVectorIndex.
Referenced by getColumn().
|
inlinevirtual |
get the j-th column of this symmetric matrix in a vector
Reimplemented from LAP_DoubleMatrix.
References ASSERT_IN, getColumn(), and null.
|
inline |
get the column by reference the values of v pointer to the values of the column j of this
References LAP_DoubleFullStorage::getColumnByReference(), and getFullStorage().
|
inline |
get the column by reference the values of v pointer to the values of the column j of this
References LAP_DoubleFullStorage::getColumnByReference(), and getFullStorage().
|
inlinevirtual |
get the columns number of the matrix from view
Reimplemented from LAP_Matrix.
References getFullStorage(), and LAP_DoubleFullStorage::getViewedColumnsNumber().
Referenced by computeEigenValueDecomposition(), computeEigenValues(), copyUpperToLowerSubMatrix(), getColumn(), getRow(), indexMin(), matrixProduct(), LAP_DoublePackedSymmetricMatrix::matrixProduct(), and sum().
|
inlineinherited |
get the fill rate of the matrix
|
inline |
GET.
get the full storage
References LAP_DoubleMatrix::getStorage().
Referenced by getColumnByReference(), getColumnsNumber(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), indexMin(), operator()(), LAP_DoublePackedSymmetricMatrix::operator*=(), operator*=(), LAP_DoublePackedSymmetricMatrix::operator+=(), operator+=(), LAP_DoublePackedSymmetricMatrix::operator-=(), operator-=(), LAP_DoublePackedSymmetricMatrix::operator/=(), operator/=(), operator^=(), setSize(), and setValues().
|
inline |
get the full storage
References LAP_DoubleMatrix::getStorage().
|
inlineinherited |
return the identity string of the object of the form className_at_address
References CORE_Object::getClassName(), CORE_Object::pointer2String(), and tString.
Referenced by UI_Class::createPrimitiveMap(), UI_Class::saveAssociation(), UI_Class::saveClass(), UI_ClassFactory::saveIntoClass(), MATH_StiefelFunction::toString(), LAP_2DView::toString(), CORE_Object::toString(), MATH_StiefelOptimizer::toString(), and MM_Class::toString().
|
inline |
get the memory distance between (*this)(i,j) & (*this)(i,j+1)
References getFullStorage(), and LAP_DoubleFullStorage::getLeadingDimension().
Referenced by computeEigenValueDecomposition(), computeEigenValues(), copyUpperToLowerSubMatrix(), dotProduct(), getColumn(), getRow(), indexMin(), inverse(), matrixProduct(), max(), norm2(), rankSymmetricProduct(), sum(), and vectorProduct().
|
inlineinherited |
get a null value
Referenced by LAP_DoubleBandedStorage::operator()(), LAP_DoubleBandedUpperMatrix::operator()(), LAP_DoublePackedUpperMatrix::operator()(), and LAP_DoubleFullUpperMatrix::operator()().
|
inlineinherited |
get a const null value
|
inlineinherited |
get the number of null values
|
inlinestaticinherited |
get output
|
inlineinherited |
return the identity string of the object
References CORE_Object::pointer2String().
|
virtual |
get the i-th row in a vector
Implements LAP_DoubleMatrix.
References getColumnsNumber(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), LAP_Vector< T >::resetView(), LAP_Vector< T >::setSize(), tLVectorIncrement, and tLVectorIndex.
Referenced by getRow().
|
inlinevirtual |
get the i-th row in a vector
Reimplemented from LAP_DoubleMatrix.
References ASSERT_IN, getRow(), and null.
|
inline |
get the memory distance between (*this)(i,j) & (*this)(i+1,j)
References getFullStorage(), and LAP_DoubleFullStorage::getRowIncrement().
Referenced by computeEigenValueDecomposition(), computeEigenValues(), copyUpperToLowerSubMatrix(), getColumn(), getRow(), indexMin(), inverse(), max(), norm2(), rankSymmetricProduct(), sum(), and vectorProduct().
|
inlinevirtual |
get the lines number of the matrix from view
Reimplemented from LAP_Matrix.
References getFullStorage(), and LAP_DoubleFullStorage::getViewedRowsNumber().
Referenced by computeEigenValueDecomposition(), computeEigenValues(), copyUpperToLowerSubMatrix(), getColumn(), getRow(), inverse(), matrixProduct(), LAP_DoublePackedSymmetricMatrix::matrixProduct(), max(), norm2(), rankSymmetricProduct(), sum(), and vectorProduct().
|
inlineinherited |
get the shared pointer of this class into p
Referenced by CORE_Map< Key, Value >::getSharedPointer(), CORE_Array< tFlag >::getSharedPointer(), LAP_ConstVector< lapack_real >::getSharedPointer(), STAT_Combinatorial< T >::getSharedPointer(), LAP_Vector< lapack_int >::getSharedPointer(), CORE_Vector< T >::getSharedPointer(), CORE_Matrix< T >::getSharedPointer(), and CORE_Object::printObjectsInMemory().
|
inlineinherited |
get the shared pointer of this class into p
|
inlineinherited |
get the size in direction
Referenced by LAP_DoubleFullGeneralMatrix::concat(), LAP_Matrix::copy(), LAP_Matrix::getColumnsNumber(), LAP_Matrix::getRowsNumber(), MMSD_DoubleSymmetricMatrix::getSize(), indexMin(), LAP_DoubleFullUpperMatrix::indexMin(), LAP_DoubleFullGeneralMatrix::indexMin(), LAP_DoubleFullGeneralMatrix::removeColumn(), and LAP_DoubleFullGeneralMatrix::solve().
|
inlineinherited |
set the storage
References null.
Referenced by computeEigenValueDecomposition(), LAP_DoubleMatrix::copy(), LAP_DoubleBandedUpperMatrix::getBandedStorage(), LAP_DoubleBandedSymmetricMatrix::getBandedStorage(), getFullStorage(), LAP_DoublePackedSymmetricMatrix::getPackedStorage(), MMSD_DoubleSymmetricMatrix::getValues(), LAP_DoubleMatrix::init(), MMSD_Cluster::initialize(), MATH_StiefelOptimizer::minimize(), LAP_DoubleBandedUpperMatrix::operator=(), LAP_DoubleBandedSymmetricMatrix::operator=(), LAP_DoublePackedSymmetricMatrix::operator=(), LAP_DoubleFullUpperMatrix::operator=(), operator=(), LAP_DoubleFullGeneralMatrix::operator=(), LAP_DoublePackedUpperMatrix::operator=(), LAP_DoubleMatrix::operator[](), MMSD_Law::saveToUIClass(), MMSD_Cluster::saveToUIClass(), MMSD_Model::saveToUIClass(), LAP_DoubleBandedSymmetricMatrix::setSize(), LAP_DoublePackedUpperMatrix::setSize(), LAP_DoubleBandedUpperMatrix::setSize(), LAP_DoublePackedSymmetricMatrix::setSize(), LAP_DoublePackedUpperMatrix::setValues(), LAP_DoublePackedSymmetricMatrix::setValues(), LAP_DoubleBandedSymmetricMatrix::setValues(), LAP_DoubleBandedUpperMatrix::setValues(), testGaussianLaw11N(), testGaussianLaw1PN(), testStiefelGaussianLawFunction(), LAP_DoubleMatrix::trace(), MMSD_ConstraintGaussianCluster::updateFreedomDegrees(), and MMSD_GaussianCluster::updateFreedomDegrees().
|
inlineinherited |
set the storage
References null.
|
inlinestaticinherited |
get type name
References tString.
|
inlineinherited |
get the number of values
Referenced by MMSD_DoubleSymmetricMatrix::getValuesNumber(), and MMSD_Model::saveToUIClass().
|
inlinestatic |
create an identity matrix
References New(), and tLVectorIndex.
void LAP_DoubleFullSymmetricMatrix::indexMin | ( | tLVectorIndex & | i, |
tLVectorIndex & | j | ||
) | const |
get the index of the min view element in absolute value
i | return the row index of the min element |
j | return the column index of the min element |
References getColumnsNumber(), getFullStorage(), getLeadingDimension(), getRowIncrement(), LAP_Matrix::getSize(), LAP_DoubleFullStorage::getStart(), REAL_INFINITY, LAP_Matrix::ROW, tLVectorIncrement, tLVectorIndex, and tReal.
|
inlineinherited |
init the values to v
v | init value |
References LAP_DoubleMatrix::getStorage(), and LAP_DoubleMatrixStorage::init().
Referenced by MMSD_DoubleFullMatrix::operator=().
|
inline |
inverse the matrix
|
inlinestatic |
inverse a symmetric matrix dsytrf & dsytri lapack methods called
References DoubleFullSymmetricMatrixInverse(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), LAP_Vector< T >::setSize(), and tLVectorIndex.
|
inlinestatic |
inverse a symmetric matrix dsytrf & dsytri lapack methods called
References DoubleFullSymmetricMatrixInverse(), getLeadingDimension(), getRowIncrement(), and getRowsNumber().
|
inlinestaticinherited |
return true if the machine is a 32 bits machine
References CORE_Object::is64Architecture().
|
staticinherited |
return true if the machine is a 64 bits machine
Referenced by CORE_Object::is32Architecture().
|
inlineinherited |
return true if the object is an instance of T
References null.
|
inlineinherited |
return true if the value is a null
|
inlinevirtualinherited |
return true if the matrix is symmetric
Implements LAP_DoubleMatrix.
|
inlinevirtualinherited |
return true if the matrix is upper
Implements LAP_DoubleMatrix.
|
inlinevirtual |
return C=(This) . B
Implements LAP_DoubleMatrix.
References LAP_DoubleMatrix::get(), LAP_DoubleFullGeneralMatrix::New(), and null.
Referenced by matrixProduct(), and MMSD_DoubleSymmetricMatrix::product().
|
inline |
return C=(This) . B
References getColumnsNumber(), getRowsNumber(), matrixProduct(), and LAP_DoubleFullGeneralMatrix::setSize().
|
inline |
return C=(This) . B
References LAP_DoubleFullGeneralMatrix::getColumnsNumber(), getRowsNumber(), matrixProduct(), and LAP_DoubleFullGeneralMatrix::setSize().
|
inlinevirtual |
return C=(This) . B (lefside=true) or B. (this) (lefside=false)
References matrixProduct().
|
inlinevirtual |
make the product C = alpha. This . B +beta C if leftSide=true C = alpha. B . This +beta C if leftSide=false
Implements LAP_DoubleSymmetricMatrix.
References matrixProduct().
|
inlinevirtual |
make the product:
leftside | : the side of product |
nBRows | number of rows of B |
nBcols | number of columns of B |
incB | memory distance between B(i,j) && B(i+1,j) |
ldB | memory distance between B(i,j) && B(i,j+1) |
alpha | the alpha value |
beta | the beta value |
C | the output full matrix |
Implements LAP_DoubleSymmetricMatrix.
References ASSERT_IN, DoubleFullSymmetricMatrixMatrixProduct(), LAP_DoubleFullGeneralMatrix::getColumnsNumber(), getLeadingDimension(), LAP_DoubleFullGeneralMatrix::getLeadingDimension(), getRowsNumber(), LAP_DoubleFullGeneralMatrix::getRowsNumber(), LAP_DoubleFullGeneralMatrix::setSize(), and tLVectorIndex.
|
inlinestatic |
make the product C = alpha. S . B +beta C if leftSide=true C = alpha. B . S +beta C if leftSide=false dsymm lapack method called
References ASSERT_IN, DoubleFullSymmetricMatrixMatrixProduct(), LAP_DoubleFullGeneralMatrix::getColumnsNumber(), getLeadingDimension(), LAP_DoubleFullGeneralMatrix::getLeadingDimension(), getRowsNumber(), LAP_DoubleFullGeneralMatrix::getRowsNumber(), LAP_DoubleFullGeneralMatrix::setSize(), and tLVectorIndex.
|
inlinestatic |
make the product C = alpha. S1 . S2 +beta C if leftSide=true C = alpha. S2 . S1 +beta C if leftSide=false dsymm C-lapack method called
References DoubleFullSymmetricMatrixMatrixProduct(), getColumnsNumber(), LAP_DoubleFullGeneralMatrix::getColumnsNumber(), getLeadingDimension(), LAP_DoubleFullGeneralMatrix::getLeadingDimension(), getRowsNumber(), LAP_DoubleFullGeneralMatrix::getRowsNumber(), LAP_DoubleFullGeneralMatrix::setSize(), and tLVectorIndex.
|
virtual |
make get max among the direction if (d==ROW) max of all the columns of row index if (d==COL) max of all the rows of column at index
References getLeadingDimension(), getRowIncrement(), getRowsNumber(), REAL_INFINITY, tLVectorIncrement, tLVectorIndex, and tReal.
|
inlinestatic |
References LAP_DoubleFullSymmetricMatrix().
Referenced by Identity(), New(), NewInstance(), MMSD_DoubleSymmetricMatrix::setStorage(), testEigenFunction(), testOptimize(), testOptimizerGProject1(), testOptimizerGProject2(), and testOptimizerHInverse().
|
inlinestatic |
|
inlinevirtual |
create a New instance of this
Implements LAP_DoubleMatrix.
References New().
|
virtual |
return norm2 sqrt(sum_ij(aij^2))=sqrt(tr(AtA));
Implements LAP_DoubleMatrix.
References getLeadingDimension(), getRowIncrement(), getRowsNumber(), sum(), tLVectorIncrement, and tLVectorIndex.
Referenced by MATH_StiefelOptimizer::minimize().
|
virtual |
return norm2 of the matrix and for each row;
Implements LAP_DoubleMatrix.
References getLeadingDimension(), getRowIncrement(), getRowsNumber(), LAP_Vector< T >::resetView(), LAP_Vector< T >::setSize(), sum(), tLVectorIncrement, and tLVectorIndex.
|
inlinevirtual |
accessor of element at row i and column j taking into account the view only use the upper diagonal
Implements LAP_DoubleMatrix.
References getFullStorage().
|
inlinevirtual |
accessor of element at row i and column j taking into account the view only use the upper diagonal
Implements LAP_DoubleMatrix.
References getFullStorage().
|
inline |
|
inline |
multiply the viewed matrices term by term
References getFullStorage().
LAP_DoubleFullSymmetricMatrix & LAP_DoubleFullSymmetricMatrix::operator*= | ( | const LAP_DoublePackedSymmetricMatrix & | s | ) |
multiply the viewed matrices term by term
References getFullStorage(), LAP_DoublePackedSymmetricMatrix::getPackedStorage(), and LAP_DoubleFullStorage::multiplyBy().
|
inline |
|
inline |
LAP_DoubleFullSymmetricMatrix & LAP_DoubleFullSymmetricMatrix::operator+= | ( | const LAP_DoublePackedSymmetricMatrix & | s | ) |
add the viewed matrix
References LAP_DoubleFullStorage::add(), getFullStorage(), and LAP_DoublePackedSymmetricMatrix::getPackedStorage().
|
inline |
|
inline |
LAP_DoubleFullSymmetricMatrix & LAP_DoubleFullSymmetricMatrix::operator-= | ( | const LAP_DoublePackedSymmetricMatrix & | s | ) |
sub the viewed matrix
References getFullStorage(), LAP_DoublePackedSymmetricMatrix::getPackedStorage(), and LAP_DoubleFullStorage::sub().
|
inline |
|
inline |
divide the viewed matrices term by term
References getFullStorage().
LAP_DoubleFullSymmetricMatrix & LAP_DoubleFullSymmetricMatrix::operator/= | ( | const LAP_DoublePackedSymmetricMatrix & | s | ) |
divide the viewed matrices term by term
References LAP_DoubleFullStorage::divideBy(), getFullStorage(), and LAP_DoublePackedSymmetricMatrix::getPackedStorage().
|
inline |
init all the matrix to s
References LAP_DoubleMatrix::getStorage(), and LAP_DoubleMatrixStorage::init().
|
inline |
init all the matrix to s
References LAP_DoubleMatrix::copy().
|
inlineinherited |
get the element at index
index | index of the element in [0,getStorage().getValuesNumber()[ return the value of the element at index for reading |
References LAP_DoubleMatrix::getStorage().
|
inlineinherited |
get the element at index
index | index of the element in [0,getValuesNumber()[ return the value of the element at index for writing |
References LAP_DoubleMatrix::getStorage().
|
inline |
|
staticinherited |
print on output
References null, and CORE_Object::print().
Referenced by CORE_Exception::CORE_Exception().
|
staticinherited |
return the string represantation of a pointer
References tString.
Referenced by CORE_Object::CORE_Object(), CORE_Object::getIdentityString(), CORE_Object::getPointerAddress(), and CORE_Object::~CORE_Object().
|
inlinevirtualinherited |
print the class
References CORE_Object::toString().
Referenced by CORE_Object::outputPrint(), CORE_Out::print(), CORE_Object::print(), CORE_Out::printInt(), CORE_Out::println(), CORE_Out::printReal(), CORE_Out::printString(), and CORE_Out::setAction().
|
inlinevirtualinherited |
print the class
References CORE_Object::print(), and CORE_Object::toString().
|
virtualinherited |
print the class
Reimplemented in CORE_Out.
References null, and CORE_Object::print().
|
virtualinherited |
References null.
|
virtualinherited |
References null.
|
inlinestaticinherited |
print the class
|
staticinherited |
print object in memory
References CORE_Object::getClassName(), CORE_Object::getSharedPointer(), and CORE_Object::mIsMemoryTesting.
Referenced by main().
|
inline |
compute the symmetric matrix S:=alpha op(A).t(op(A))
Referenced by MATH_StiefelOptimizer::minimize(), and rankSymmetricProduct().
|
inline |
compute the symmetric matrix S:=alpha op(A).t(op(A))
References rankSymmetricProduct().
|
inlinevirtual |
compute the symmetric matrix S:=beta.S+ alpha op(A).t(op(A)) only the upper symmetric matric is set. (lapack method dsyrk called)
References LAP_DoubleFullGeneralMatrix::getColumnsNumber(), LAP_DoubleFullGeneralMatrix::getLeadingDimension(), LAP_DoubleFullGeneralMatrix::getRowIncrement(), LAP_DoubleFullGeneralMatrix::getRowsNumber(), rankSymmetricProduct(), tLVectorIncrement, and tLVectorIndex.
|
inlinevirtual |
compute the symmetric matrix S:=beta.S+ alpha op(A).t(op(A)) only the upper symmetric matric is set. (lapack method dsyrk called)
Implements LAP_DoubleSymmetricMatrix.
References DoubleFullSymmetricMatrixKRankSymmetricProduct(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), null, setSize(), and tLVectorIndex.
|
inline |
compute the symmetric matrix S:=alpha op(A).t(op(A))
References rankSymmetricProduct().
|
inline |
compute the symmetric matrix S:=alpha op(A).t(op(A))
References rankSymmetricProduct().
|
inlinevirtual |
compute the symmetric matrix S:=beta.S+ alpha op(A).t(op(A)) only the upper symmetric matric is set. (lapack method dsyrk called)
References DoubleFullSymmetricMatrixKRankSymmetricProduct(), LAP_DoubleFullGeneralMatrix::getColumnsNumber(), LAP_Vector< T >::getIncrement(), getLeadingDimension(), LAP_DoubleFullGeneralMatrix::getLeadingDimension(), getRowIncrement(), LAP_DoubleFullGeneralMatrix::getRowIncrement(), getRowsNumber(), LAP_DoubleFullGeneralMatrix::getRowsNumber(), LAP_Vector< T >::getSize(), setSize(), and tLVectorIndex.
|
inlineinherited |
set the value of the element at row i and column j
i | : row of the element |
j | column of the element |
v | value to set |
|
inlinestaticinherited |
set output
|
inlinevirtual |
set the dimension of the matrix and allocate the values array
Reimplemented from LAP_Matrix.
References getFullStorage(), LAP_Matrix::setSize(), LAP_DoubleFullStorage::setValuesNumber(), and tLVectorIndex.
Referenced by computeAMatrix(), dotProduct(), MATH_StiefelOptimizer::minimize(), rankSymmetricProduct(), and setSize().
|
inlinevirtual |
set the dimension of the matrix and alocate the values array
Reimplemented from LAP_Matrix.
References setSize().
|
inlineinherited |
set the storage
Referenced by LAP_DoubleBandedSymmetricMatrix::LAP_DoubleBandedSymmetricMatrix(), LAP_DoubleBandedUpperMatrix::LAP_DoubleBandedUpperMatrix(), LAP_DoubleFullGeneralMatrix::LAP_DoubleFullGeneralMatrix(), LAP_DoubleFullSymmetricMatrix(), LAP_DoubleFullUpperMatrix::LAP_DoubleFullUpperMatrix(), LAP_DoublePackedSymmetricMatrix::LAP_DoublePackedSymmetricMatrix(), and LAP_DoublePackedUpperMatrix::LAP_DoublePackedUpperMatrix().
|
inlineprotectedinherited |
set this weak shared pointer called toDoAfterThis setting method
References CORE_Object::toDoAfterThisSetting().
|
inlineprotectedvirtualinherited |
set the type of the object
Referenced by LAP_IntegerVector::LAP_IntegerVector(), MATH_BetaFunction::MATH_BetaFunction(), MATH_C1Function::MATH_C1Function(), MATH_DigammaFunction::MATH_DigammaFunction(), MATH_EigenFunction::MATH_EigenFunction(), MATH_Equation::MATH_Equation(), MATH_Function::MATH_Function(), MATH_GammaFunction::MATH_GammaFunction(), MATH_KeplerFunction::MATH_KeplerFunction(), MATH_LogGammaFunction::MATH_LogGammaFunction(), MATH_NewtonEquation::MATH_NewtonEquation(), MATH_StiefelFunction::MATH_StiefelFunction(), MATH_StiefelOptimizer::MATH_StiefelOptimizer(), MATH_TranscendentEquation::MATH_TranscendentEquation(), MATH_TrigammaFunction::MATH_TrigammaFunction(), MATH_ZeroEquation::MATH_ZeroEquation(), MATH_ZKeplerFunction::MATH_ZKeplerFunction(), MM_Attribute::MM_Attribute(), MM_Class::MM_Class(), MM_ClassFactory::MM_ClassFactory(), MM_Data::MM_Data(), MM_Structure::MM_Structure(), MMSD_ClassFactory::MMSD_ClassFactory(), MMSD_Cluster::MMSD_Cluster(), MMSD_ConstDoubleVector::MMSD_ConstDoubleVector(), MMSD_ConstraintGaussianCluster::MMSD_ConstraintGaussianCluster(), MMSD_ConstraintGaussianModel::MMSD_ConstraintGaussianModel(), MMSD_DataSet::MMSD_DataSet(), MMSD_DataSetClassFactory::MMSD_DataSetClassFactory(), MMSD_DoubleFullMatrix::MMSD_DoubleFullMatrix(), MMSD_DoubleSymmetricMatrix::MMSD_DoubleSymmetricMatrix(), MMSD_DoubleVector::MMSD_DoubleVector(), MMSD_FluryGautschiGaussianLaw::MMSD_FluryGautschiGaussianLaw(), MMSD_GaussianCluster::MMSD_GaussianCluster(), MMSD_GaussianFDFunction::MMSD_GaussianFDFunction(), MMSD_GaussianLaw::MMSD_GaussianLaw(), MMSD_GaussianModel::MMSD_GaussianModel(), MMSD_Law::MMSD_Law(), MMSD_Model::MMSD_Model(), MMSD_ModelClassFactory::MMSD_ModelClassFactory(), MMSD_Object::MMSD_Object(), MMSD_StiefelFunction::MMSD_StiefelFunction(), MMSD_StiefelGaussianLaw::MMSD_StiefelGaussianLaw(), STAT_BernoulliDistribution::STAT_BernoulliDistribution(), STAT_BinomialDistribution::STAT_BinomialDistribution(), STAT_Combinatorial< T >::STAT_Combinatorial(), STAT_DiracDistribution::STAT_DiracDistribution(), STAT_Distribution::STAT_Distribution(), STAT_ExponentialDistribution::STAT_ExponentialDistribution(), STAT_GammaDistribution::STAT_GammaDistribution(), STAT_GeometricDistribution::STAT_GeometricDistribution(), STAT_InverseNormalDistribution::STAT_InverseNormalDistribution(), STAT_NormalDistribution::STAT_NormalDistribution(), STAT_Object::STAT_Object(), STAT_PoissonDistribution::STAT_PoissonDistribution(), STAT_UniformDistribution::STAT_UniformDistribution(), and STAT_UniformLaplaceTransform::STAT_UniformLaplaceTransform().
|
inlinevirtual |
set the values of the matrix to V without allocation the values array
n | number of rows |
value | values ordered by columns |
Reimplemented from LAP_DoubleMatrix.
References getFullStorage(), LAP_Matrix::setSize(), LAP_DoubleFullStorage::setValuesPointer(), and tLVectorIndex.
|
inlinevirtual |
set the values
n | number of values |
values | values ordered by columns |
Reimplemented from LAP_DoubleMatrix.
References getFullStorage(), LAP_Matrix::setSize(), LAP_DoubleFullStorage::setValues(), and tLVectorIndex.
|
virtual |
make the sum among the direction if (d==ROW) sum all the columns of each row and size of s is the number of rows if (d==COL) sum all the rows of each column and size of s is the number of columns ^return the sum of all the element of the matrix
Implements LAP_DoubleMatrix.
References getColumnsNumber(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), null, LAP_Vector< T >::setSize(), tLVectorIncrement, and tLVectorIndex.
Referenced by norm2(), and sum().
|
virtual |
make the sum among the direction if (d==ROW) sum all the columns of row index if (d==COL) sum all the rows of coluln at index
Implements LAP_DoubleMatrix.
References getLeadingDimension(), getRowIncrement(), getRowsNumber(), sum(), tLVectorIncrement, and tLVectorIndex.
|
inlineprotectedvirtualinherited |
method called after setThis() method this method can oly be called once.
Reimplemented in STAT_UniformLaplaceTransform.
Referenced by CORE_Object::setThis(), and STAT_UniformLaplaceTransform::toDoAfterThisSetting().
|
virtualinherited |
print the matrix taking into account the view
Reimplemented from CORE_Object.
References LAP_Matrix::getColumnsNumber(), LAP_Matrix::getRowsNumber(), tLVectorIndex, CORE_String::toString(), and tString.
|
inlineinherited |
return trace
References LAP_DoubleMatrix::getStorage(), and LAP_DoubleMatrixStorage::trace().
|
inlinevirtualinherited |
compute This. X
X | input vector |
References LAP_Vector< T >::get(), and LAP_DoubleVector::New().
Referenced by LAP_DoubleMatrix::vectorProduct(), LAP_DoublePackedSymmetricMatrix::vectorProduct(), LAP_DoubleBandedSymmetricMatrix::vectorProduct(), vectorProduct(), and LAP_DoubleFullGeneralMatrix::vectorProduct().
|
inlinevirtualinherited |
compute Y= This. X
X | input vector |
Y | output vector |
Reimplemented in LAP_DoubleFullGeneralMatrix, and LAP_DoubleFullUpperMatrix.
References LAP_DoubleMatrix::vectorProduct().
|
inlinevirtualinherited |
rcompute Y= This X
X | input vector |
Y | output vector |
References null, and LAP_DoubleMatrix::vectorProduct().
|
inlinevirtualinherited |
compute Y= op(This). X
isTrans | : if (isTrans) op(A)=A else pop(A)=tA |
X | : input vector |
Y | : output vector |
Reimplemented in LAP_DoubleFullUpperMatrix, and LAP_DoublePackedUpperMatrix.
References LAP_Matrix::getColumnsNumber(), LAP_Vector< T >::getIncrement(), LAP_Matrix::getRowsNumber(), LAP_Vector< T >::getSize(), LAP_Vector< T >::setSize(), tLVectorIndex, and LAP_DoubleMatrix::vectorProduct().
|
pure virtualinherited |
compute Y= beta Y + alpha op(This). X with op(A)=A or tA depending on isTrans value
isTrans | : if (isTrans) op(A)=A else pop(A)=tA |
nX | size of X |
incX | increment of X (memory distance between X(i) & X(i+1) |
X | X values of minimum size nX*incX |
nY | size of Y |
incY | increment of Y (memory distance between Y(i) & Y(i+1) |
Y | Y values of minimum size nY*incY |
Implemented in LAP_DoubleFullUpperMatrix, LAP_DoubleBandedUpperMatrix, and LAP_DoublePackedUpperMatrix.
|
inlinevirtual |
compute Y=A.X
References LAP_DoubleMatrix::vectorProduct().
Referenced by vectorProduct().
|
inlinevirtual |
compute Y:=betaY+alpha.This.X
X | vector X of size number of cols of this |
alpha | value of alpha |
beta | : value of beta |
Y | : vector Y of size number of rows of this |
References LAP_Vector< T >::getIncrement(), getRowsNumber(), LAP_Vector< T >::getSize(), LAP_Vector< T >::setSize(), tLVectorIndex, and vectorProduct().
|
inlinevirtual |
compute Y:=betaY+alpha.This.X
X | vector X of size number of cols of this |
alpha | value of alpha |
beta | : value of beta |
Y | : vector Y of size number of rows of this |
References LAP_ConstVector< T >::getIncrement(), LAP_Vector< T >::getIncrement(), getRowsNumber(), LAP_ConstVector< T >::getSize(), LAP_Vector< T >::getSize(), LAP_Vector< T >::setSize(), tLVectorIndex, and vectorProduct().
|
inlinevirtual |
compute Y= op(This). X with op(A)=A or tA depending on isTrans value
isTrans | : if (isTrans) op(A)=A else pop(A)=tA |
nX | size of X |
incX | increment of X (memory distance between X(i) & X(i+1) |
X | X values of minimum size nX*incX |
nY | size of Y |
incY | increment of Y (memory distance between Y(i) & Y(i+1) |
Y | Y values of minimum size nY*incY |
References vectorProduct().
|
inlinevirtual |
compute Y= betaY + alpha. This. X
nX | size of X |
incX | increment of X (memory distance between X(i) & X(i+1) |
X | X values of minimum size nX*incX |
alpha | alpha value |
beta:beta | value |
nY | size of Y |
incY | increment of Y (memory distance between Y(i) & Y(i+1) |
Y | Y values of minimum size nY*incY |
References DoubleFullSymmetricMatrixVectorProduct(), getLeadingDimension(), getRowIncrement(), getRowsNumber(), and tLVectorIndex.
|
inlinestaticinherited |
compute the value of pow(f,n)=f^n
f | real value |
n | exponent relative value |
return
|
staticinherited |
Referenced by LAP_DoubleFullGeneralMatrix::concat(), LAP_Matrix::copy(), LAP_DoubleFullStorage::getColumnByReference(), LAP_DoubleFullStorage::getLeadingDimension(), LAP_DoubleFullStorage::getRowByReference(), LAP_DoubleFullStorage::getViewedColumnsNumber(), LAP_DoubleFullStorage::isSubmatrixView(), LAP_Matrix::LAP_Matrix(), LAP_DoublePackedStorage::max(), LAP_DoubleBandedStorage::max(), LAP_DoubleFullStorage::operator()(), LAP_DoubleFullGeneralMatrix::removeColumn(), LAP_DoubleFullStorage::resetView(), LAP_Matrix::setSize(), LAP_DoubleFullGeneralMatrix::solve(), LAP_DoublePackedUpperMatrix::sum(), and LAP_DoubleBandedUpperMatrix::sum().
|
staticinherited |
indicator to store all classes created and deleted only for debuging version
Referenced by CORE_Object::CORE_Object(), main(), CORE_Object::printObjectsInMemory(), and CORE_Object::~CORE_Object().
|
staticinherited |
Referenced by LAP_DoubleFullGeneralMatrix::concat(), LAP_Matrix::copy(), LAP_DoubleFullStorage::getColumnByReference(), LAP_DoubleFullStorage::getRowByReference(), LAP_DoubleFullStorage::getRowIncrement(), MMSD_DoubleSymmetricMatrix::getSize(), LAP_DoubleFullStorage::getViewedRowsNumber(), indexMin(), LAP_DoubleFullUpperMatrix::indexMin(), LAP_DoubleFullGeneralMatrix::indexMin(), LAP_DoubleFullStorage::isSubmatrixView(), LAP_Matrix::LAP_Matrix(), LAP_DoublePackedStorage::max(), LAP_DoubleFullUpperMatrix::max(), LAP_DoubleFullGeneralMatrix::max(), LAP_DoubleFullStorage::operator()(), LAP_DoubleFullGeneralMatrix::removeColumn(), LAP_DoubleFullStorage::resetView(), LAP_Matrix::setSize(), LAP_DoubleFullGeneralMatrix::solve(), LAP_DoublePackedUpperMatrix::sum(), LAP_DoubleFullUpperMatrix::sum(), and LAP_DoubleFullGeneralMatrix::sum().
|
staticinherited |
Referenced by LAP_DoublePackedStorage::computeBandsNumber(), LAP_DoubleBandedStorage::computeBandsNumber(), LAP_DoubleFullStorage::computeBandsNumber(), LAP_DoubleBandedStorage::copyFullStorage(), LAP_DoubleBandedStorage::copyPackStorage(), LAP_DoubleMatrixStorage::getNullValuesNumber(), LAP_DoubleFullGeneralMatrix::lowerTest(), LAP_DoubleFullGeneralMatrix::symmetricTest(), and LAP_DoubleFullGeneralMatrix::upperTest().