PIPS-NLP
Public Member Functions | Public Attributes | Protected Attributes | List of all members
StochSymMatrix Class Reference

#include <StochSymMatrix.h>

Inheritance diagram for StochSymMatrix:
SymMatrix DoubleMatrix IotrRefCount StochSymDummyMatrix

Public Member Functions

 StochSymMatrix (int id, long long global_n, int local_n, int local_nnz, MPI_Comm mpiComm)
 
 StochSymMatrix (int id, long long global_n, int diag_n, int diag_nnz, int border_n, int border_nnz, MPI_Comm mpiComm_)
 
virtual ~StochSymMatrix ()
 
virtual void AddChild (StochSymMatrix *child)
 
virtual int isKindOf (int type)
 
virtual void atPutDense (int row, int col, double *A, int lda, int rowExtent, int colExtent)
 
virtual void fromGetDense (int row, int col, double *A, int lda, int rowExtent, int colExtent)
 
virtual void symAtPutSpRow (int row, double A[], int lenA, int jcolA[], int &info)
 
virtual void fsymAtPutSpRow (int row, double A[], int lenA, int jcolA[], int &info)
 
virtual void getSize (long long &m, long long &n)
 
virtual void getSize (int &m, int &n)
 
virtual long long size ()
 
virtual void symAtPutSubmatrix (int destRow, int destCol, DoubleMatrix &M, int srcRow, int srcCol, int rowExtent, int colExtent)
 
virtual void fromGetSpRow (int row, int col, double A[], int lenA, int irowA[], int &nnz, int rowExtent, int &info)
 
virtual void atPutZeros (int row, int col, int rowExtent, int colExtent)
 
virtual void mult (double beta, OoqpVector &y, double alpha, OoqpVector &x)
 
virtual void transMult (double beta, OoqpVector &y, double alpha, OoqpVector &x)
 
virtual double abmaxnorm ()
 
virtual void writeToStream (std::ostream &out) const
 
virtual void randomizePSD (double *seed)
 
virtual void getDiagonal (OoqpVector &vec)
 
virtual void setToDiagonal (OoqpVector &vec)
 
virtual void atPutDiagonal (int idiag, OoqpVector &v)
 
virtual void fromGetDiagonal (int idiag, OoqpVector &x)
 
virtual void putSparseTriple (int irow[], int len, int jcol[], double A[], int &info)
 
virtual void SymmetricScale (OoqpVector &vec)
 
virtual void ColumnScale (OoqpVector &vec)
 
virtual void RowScale (OoqpVector &vec)
 
virtual void scalarMult (double num)
 
virtual void copyMtxFromDouble (int copyLength, double *values)
 
virtual void copyDiagonalVal_FromcopyDiagonalVal_From (int idiag, OoqpVector &v, bool firstCall, std::map< int, int > &ValIdxMap)
 
- Public Member Functions inherited from SymMatrix
virtual void symAtSetSubmatrix (int destRow, int destCol, DoubleMatrix &M, int srcRow, int srcCol, int rowExtent, int colExtent, bool firstCall, std::map< int, int > &ValIdxMap)
 
- Public Member Functions inherited from DoubleMatrix
 DoubleMatrix ()
 
virtual void fromAddDense (int row, int col, double *A, int lda, int rowExtent, int colExtent)
 
virtual ~DoubleMatrix ()
 
virtual void setAdditiveDiagonal (OoqpVector &additiveDiag_)
 
virtual void copyDiagonalVal_From (int idiag, OoqpVector &x, bool firstCall, std::map< int, int > &ValIdxMap)
 
virtual void fromGetSpRow_WithRowStart (int row, int col, double A[], int lenA, int jcolA[], int &nnz, int colExtent, int &info, int &rowStart)
 
virtual void fromGetDense_withMap (int row, int col, double *A, int lda, int rowExtent, int colExtent, int const FirstCall, std::map< int, int > &ValIdxMap)
 
virtual double * getMatVal ()
 
virtual int * krowM ()
 
virtual int * jcolM ()
 
virtual double * M ()
 
- Public Member Functions inherited from IotrRefCount
int refs ()
 
 IotrRefCount ()
 

Public Attributes

std::vector< StochSymMatrix * > children
 
SparseSymMatrixdiag
 
SparseGenMatrixborder
 
int id
 
long long n
 
MPI_Comm mpiComm
 
int iAmDistrib
 

Protected Attributes

StochSymMatrixparent
 

Additional Inherited Members

- Static Public Member Functions inherited from IotrRefCount
static void release (IotrRefCount **obj)
 
static void addRef (IotrRefCount *const *obj)
 
- Static Public Attributes inherited from IotrRefCount
static int instances = 0
 
- Protected Member Functions inherited from IotrRefCount
virtual ~IotrRefCount ()
 

Constructor & Destructor Documentation

StochSymMatrix::StochSymMatrix ( int  id,
long long  global_n,
int  local_n,
int  local_nnz,
MPI_Comm  mpiComm_ 
)

Constructs a matrix with local size 'local_n' having 'local_nnz' local nonzeros and set the global size and the id to to 'global_n' and 'id', respectively. The parameter 'id' is used for output/debug purposes only. The created matrix will have no children.

This the constructor is usually called for the root node. In this case parent is set to NULL; the cross Hessian does not exist, so border is set up to be an empty matrix.

If it is called to create a child, the calling code should call this->AddChild(c) 'AddChild' method correctly sets the parent and (re)creates an EMPTY border with correct sizes.

StochSymMatrix::StochSymMatrix ( int  id,
long long  global_n,
int  diag_n,
int  diag_nnz,
int  border_n,
int  border_nnz,
MPI_Comm  mpiComm_ 
)
StochSymMatrix::~StochSymMatrix ( )
virtual

Member Function Documentation

double StochSymMatrix::abmaxnorm ( )
virtual

the magnitude of the element in this matrix with largest absolute value.

parallel stuff needed

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::AddChild ( StochSymMatrix child)
virtual

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::atPutDense ( int  row,
int  col,
double *  A,
int  lda,
int  rowExtent,
int  colExtent 
)
virtual

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::atPutDiagonal ( int  idiag,
OoqpVector x 
)
virtual

Set some of the diagonal elements of this matrix.

Parameters
idiagthe index of the first diagonal element to be modified.
xthe new values for the diagonal elements.

The length of x is the number of diagonal elements to be modified. Typically x will have length less than the length of the diagonal.

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::atPutZeros ( int  row,
int  col,
int  rowExtent,
int  colExtent 
)
virtual

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::ColumnScale ( OoqpVector vec)
virtual

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::copyDiagonalVal_FromcopyDiagonalVal_From ( int  idiag,
OoqpVector v,
bool  firstCall,
std::map< int, int > &  ValIdxMap 
)
virtual
void StochSymMatrix::copyMtxFromDouble ( int  copyLength,
double *  values 
)
virtual

Reimplemented from DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::fromGetDense ( int  row,
int  col,
double *  A,
int  lda,
int  rowExtent,
int  colExtent 
)
virtual

Get the value of some of the elements of this matrix.

Parameters
rowstart reading the elements of this matrix from row number "row".
colstart reading the elements of this matrix from column number "col".
AAny array to hold the values from this matrix.
ldAthe leading dimension of A.
rowExtentget rowExtent rows from this matrix.
colExtentget colExtent columns from this matrix.

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::fromGetDiagonal ( int  idiag,
OoqpVector x 
)
virtual

Get some of the diagonal elements of this matrix.

Parameters
idiagthe index of the first diagonal element to be read.
xa vector to hold the diagonal elements

The length of x is the number of diagonal elements to be gotten. Typically x will have length less than the length of the diagonal.

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::fromGetSpRow ( int  row,
int  col,
double  A[],
int  lenA,
int  jcolA[],
int &  nnz,
int  colExtent,
int &  info 
)
virtual

Get one sparse row from this matrix.

Parameters
rowget row number "row"
colignore all elements of the row before column "col"
Astore the values of the sparse row in A
lenAthe length of A
jcolAan array of length lenA containing the column index of each element in the sparse row
colExtentignore all elements of the row that have column indices greater than or equal to col + colExtent
infoinfo is 0 if and only if the sparse row can fit into A.

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::fsymAtPutSpRow ( int  row,
double  A[],
int  lenA,
int  jcolA[],
int &  info 
)
virtual

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::getDiagonal ( OoqpVector vec)
virtual

Place the diagonal elements of this matrix in the vector vec

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::getSize ( long long &  m,
long long &  n 
)
virtual

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::getSize ( int &  m,
int &  n 
)
virtual

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

int StochSymMatrix::isKindOf ( int  matrixType)
virtual

True if this matrix identifies itself to be of type matrixType.

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::mult ( double  beta,
OoqpVector y_,
double  alpha,
OoqpVector x_ 
)
virtual

y = beta * y + alpha * this * x

     [ Q0*x0+ sum(Ri^T*xi) ]
     [        .            ]

this * x =[ . ] [ . ] [ Ri*x0 + Qi*xi ]

Here Qi are diagonal blocks, Ri are left bordering blocks

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::putSparseTriple ( int  irow[],
int  len,
int  jcol[],
double  A[],
int &  info 
)
virtual

Copy elements from sparse triple format into this matrix

Parameters
lenthe number of elements
irowan array containing the row number of the elements
jcolan array containing the column number of the elements
Aan array containing the values for the elements.
infoon return, info will be zero if and only if the insertion was successful.

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::randomizePSD ( double *  seed)
virtual

Randomize the elements of this matrix in a manner that makes the matrix positive semi-definite.

Implements SymMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::RowScale ( OoqpVector vec)
virtual

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::scalarMult ( double  num)
virtual

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::setToDiagonal ( OoqpVector vec)
virtual

Set the matrix to the diagoanl matrix whose diagonal is vec

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

long long StochSymMatrix::size ( )
virtual

the size of this square matrix

Implements SymMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::symAtPutSpRow ( int  col,
double  A[],
int  lenA,
int  irowA[],
int &  info 
)
virtual

Put a sparse row into this matrix symmetrically.

Elements of the row that would lie above the diagonal are ignored. The matrix is symmetrized by reflection across the diagonal.

The meaning of the parmameters is the same as in fromGetSpRow.

See also
DoubleMatrix::fromGetSpRow

Implements SymMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::symAtPutSubmatrix ( int  destRow,
int  destCol,
DoubleMatrix M,
int  srcRow,
int  srcCol,
int  rowExtent,
int  colExtent 
)
virtual

Put a submatrix of M into this matrix.

The submatrix is placed into this matrix in a manner that preserves the symmetry of this matrix. The element of M whose destination is in the lower triangle of this matrix are placed there without change, and the upper triangle is taken to be the reflection across the diagonal.

Parameters
destRowThe top row of the submatrix of M is placed at destRow.
destColThe leftmost column of the submatrix of M is placed at destCol.
srcRowThe first row of the submatrix of M is srcRow.
srcColThe first column of the submatrix of M is srcCol.
rowExtentrowExtent rows are copied from M.
colExtentcolExtent columns are copied from M.

Implements SymMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::SymmetricScale ( OoqpVector vec)
virtual

Get the number of rows and columns in the matrix

Parameters
mthe number of rows
nthe number of columns

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::transMult ( double  beta,
OoqpVector y_,
double  alpha,
OoqpVector x_ 
)
virtual

y = beta * y + alpha * this^T * x

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

void StochSymMatrix::writeToStream ( std::ostream &  out) const
virtual

Write this element to a C++ stream

Implements DoubleMatrix.

Reimplemented in StochSymDummyMatrix.

Member Data Documentation

SparseGenMatrix* StochSymMatrix::border
std::vector<StochSymMatrix*> StochSymMatrix::children
SparseSymMatrix* StochSymMatrix::diag
int StochSymMatrix::iAmDistrib
int StochSymMatrix::id
MPI_Comm StochSymMatrix::mpiComm
long long StochSymMatrix::n
StochSymMatrix* StochSymMatrix::parent
protected

The documentation for this class was generated from the following files: