186 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
304 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
395 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
435 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
487 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
548 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
588 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
625 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
661 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
697 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
735 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
820 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
903 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
991 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1076 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1162 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1248 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1343 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1432 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1521 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1639 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
1752 bool display(
int secondaryDim);
1867 bool display(
int secondaryDim);
1919 int* m_miRowPartition;
1924 int m_iRowPartitionSize;
1929 int* m_miColumnPartition;
1934 int m_iColumnPartitionSize;
1939 bool m_bHaveRowPartition;
1944 bool m_bHaveColumnPartition;
2091 virtual bool processBlocks(
int* rowOffset,
int rowOffsetSize,
int* colOffset,
2137 int* colPartition,
int colPartitionSize,
2138 bool rowMajor,
bool appendToBlockArray);
2153 int* colPartition,
int colPartitionSize,
2169 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
2321 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
2376 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
2431 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
2485 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
2578 bool setRandom(
double density,
bool conformant,
int iMin,
int iMax);
GeneralSparseMatrix * extractBlock(int firstrow, int firstcol, int lastrow, int lastcol, bool rowMajor, ENUM_MATRIX_SYMMETRY symmetry)
A method to extract a block from a larger matrix The result is a sparse matrix object,...
bool deepCopyFrom(MatrixBlocks *that)
A function to make a deep copy of an instance of this class.
bool deepCopyFrom(OSMatrixWithMatrixConIdx *that)
A function to make a deep copy of an instance of this class.
virtual ENUM_MATRIX_TYPE getMatrixType()=0
virtual ENUM_MATRIX_TYPE getMatrixType()
virtual ENUM_MATRIX_TYPE getMatrixType()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
int baseMatrixIdx
the index of the base matrix
int * index
index holds an integer array of rowIdx (or colIdx) elements in coefMatrix (AMatrix).
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
ScalarExpressionTree ** el
double value
This element contains the value.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
bool IsEqual(MatrixBlocks *that)
A function to check for the equality of two objects.
ENUM_CONREFERENCE_VALUETYPE valueType
Several different types of values can be derived from a problem constraint.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
bool deepCopyFrom(MatrixNode *that)
A function to make a deep copy of an instance of this class.
int numberOfEl
each type of value is stored as an array named "el".
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
int getColumnPartitionSize()
get the size of the column partition of a matrix
virtual ConReferenceMatrixElements * cloneMatrixNode()
int getNumberOfBlocksConstructors()
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
an abstract class to help represent the elements in a MatrixType object From this we derive concrete ...
virtual ENUM_MATRIX_TYPE getMatrixType()
virtual ObjReferenceMatrixElements * cloneMatrixNode()
The OSnLMNode Class for nonlinear expressions involving matrices.
double scalarMultiplier
to allow the base matrix to be scaled before it is attached to the target matrix
int conReference
contains a reference to a row of the problem (objective if negative, constraint otherwise)
a data structure to represent a MatrixType object (from which we derive OSMatrix and MatrixBlock)
bool isBlockDiagonal()
A method to check whether a matrix is block-diagonal.
virtual ~MatrixNode()
destructor
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
virtual std::string getMatrixNodeInXML()
ConstantMatrixValues * value
The value array of the (nonzero) constant elements.
MixedRowReferenceMatrixElements()
bool IsEqual(OSMatrixWithMatrixConIdx *that)
A function to check for the equality of two objects.
int * el
Each el is a reference to a constraint defined in the <constraints> section of the OSiL file.
MatrixElementValues * value
value holds a general array of value elements in the matrix, which could be constants,...
int rowOffsetSize
These two parameters give the size of the rowOffset and colOffset arrays, respectively.
virtual ENUM_MATRIX_TYPE getMatrixType()
a sparse matrix data structure for matrices that can hold nonconstant values
bool isRowMajor
isRowMajor holds whether the (nonzero) values holding the data are stored by columnrow.
int baseMatrixStartRow
to select the position of the upper left corner of the portion of the base matrix that is to be selec...
int * start
start holds an integer array of start elements in the matrix, which points to the start of a column (...
GeneralSparseMatrix * getBlock(int rowIdx, int colIdx)
a method to retrieve a particular block from a collection
bool setMatrix(std::string name, int numberOfRows, int numberOfColumns, ENUM_MATRIX_SYMMETRY symmetry, ENUM_MATRIX_TYPE matrixType, unsigned int inumberOfChildren, MatrixNode **m_mChildren)
add values to this matrix.
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
IntVector * index
The index array of the (nonzero) elements.
a data structure to represent the linear expressions in a LinearMatrixElement object
bool display(int secondaryDim)
This method displays data structure in the matrix format.
virtual bool deepCopyFrom(VarReferenceMatrixValues *that)
A function to make a deep copy of an instance of this class.
ConReferenceMatrixElement * convertToConReferenceMatrixElement(int objref)
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
IntVector * start
A vector listing the row or column starts.
ScalarExpressionTree * convertToGeneralMatrixElement(double val)
to represent the nonzeros in an objReferenceMatrix element
virtual bool deepCopyFrom(MatrixElementValues *that)
A function to check for the equality of two objects.
bool IsEqual(OSMatrixWithMatrixVarIdx *that)
A function to check for the equality of two objects.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
VarReferenceMatrixValues * value
The variable references (indexes of core variables) of the elements.
bool IsEqual(ConstantMatrixValues *that)
A function to check for the equality of two objects.
MatrixNode()
default constructor
virtual LinearMatrixElements * cloneMatrixNode()
bool deepCopyFrom(ConReferenceMatrixElement *that)
A function to make a deep copy of an instance of this class.
virtual bool deepCopyFrom(ConReferenceMatrixValues *that)
A function to make a deep copy of an instance of this class.
bool deepCopyFrom(MatrixBlock *that)
A function to make a deep copy of an instance of this class.
GeneralSparseMatrix * getMatrixBlockInColumnMajorForm(int columnIdx, int rowIdx)
to represent the nonzeros in a constantMatrix element
bool matrixHasBase()
Several tools to parse the constructor list of a matrix.
A concrete class that is used to store a specific type of matrix values, references to variable index...
an abstract class to help represent the elements in a MatrixType object From this we derive concrete ...
virtual MixedRowReferenceMatrixElements * cloneMatrixNode()
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)=0
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
~ExpandedMatrixBlocks()
Default destructor.
virtual std::string getMatrixNodeInXML()
bool IsEqual(ConReferenceMatrixElement *that)
A function to check for the equality of two objects.
bool IsEqual(BaseMatrix *that)
A function to check for the equality of two objects.
virtual ENUM_MATRIX_TYPE getMatrixType()
bool deepCopyFrom(VarReferenceMatrixElements *that)
A function to make a deep copy of an instance of this class.
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
virtual OSMatrix * cloneMatrixNode()
The implementation of the virtual functions.
ENUM_MATRIX_SYMMETRY symmetry
To track the type of symmetry present in the matrix or block.
bool display(int secondaryDim)
This method displays the data contained in the matrix.
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
bool deepCopyFrom(OSMatrix *that)
A function to make a deep copy of an instance of this class.
ConReferenceMatrixValues * value
The row references (indexes of core rows plus value type) of the elements.
virtual ENUM_MATRIX_TYPE getMatrixType()
this class extends OSMatrix for use, e.g., in the matrixObj section of OSoL and OSrL
virtual ~MatrixConstructor()
destructor
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
virtual ENUM_MATRIX_TYPE getMatrixType()
GeneralSparseMatrix * getMatrixCoefficientsInRowMajor()
VarReferenceMatrixValues()
bool IsEqual(ConReferenceMatrixValues *that)
A function to check for the equality of two objects.
ExpandedMatrixBlocks()
Default constructor.
ENUM_MATRIX_TYPE vType
vType holds the type of values found in the value array.
virtual bool expandElements(bool rowMajor)
A method to expand a matrix or block The result is a GeneralSparseMatrix object of constant matrix el...
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
ENUM_CONREFERENCE_VALUETYPE
An enum to track the type of value contained in a reference to a constraint.
bool b_deleteIndexArray
b_deleteIndexArray is true if we delete the index array in garbage collection — set to true by defaul...
int * rowOffset
rowOffset gives the row offsets of the block decomposition It does not have to correspond to the row ...
a data structure to represent the nonzero values in a linearMatrix element
virtual ~MatrixElementValues()
ConReferenceMatrixElement()
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
bool IsEqual(OSMatrixWithMatrixObjIdx *that)
A function to check for the equality of two objects.
ExpandedMatrixBlocks * getBlocks(int *rowPartition, int rowPartitionSize, int *colPartition, int colPartitionSize, bool rowMajor, bool appendToBlockArray)
A method to extract a block from a larger matrix The result is a sparse matrix object,...
std::vector< MatrixNode * > getPrefixFromNodeTree()
int startSize
startSize is the dimension of the starts array
~ObjReferenceMatrixElements()
this class extends OSMatrix for use, e.g., in the matrixVar section of OSoL and OSrL
a data structure to represent row reference elements in a MatrixType object Each nonzero element refe...
virtual MatrixBlock * cloneMatrixNode()
The implementation of the virtual functions.
int numberOfValues
numberOfValues records the number of entries in the arrays that make up the instance of nonzeros
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
ObjReferenceMatrixElements()
GeneralSparseMatrix * ExpandedMatrixInRowMajorForm
The matrix can be held in expanded form by rows or by columns and in a number of ways stored by block...
bool deepCopyFrom(MixedRowReferenceMatrixElements *that)
A function to make a deep copy of an instance of this class.
ObjReferenceMatrixValues()
OSMatrix * baseMatrix
a pointer to the base matrix
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
A method to check whether a matrix or block is diagonal.
bool deepCopyFrom(ObjReferenceMatrixElements *that)
A function to make a deep copy of an instance of this class.
LinearMatrixElementTerm ** varIdx
virtual std::string getNodeName()
~ConstantMatrixElements()
ConReferenceMatrixValues * value
The constraint references (indexes of core constraints and value types) of the elements.
virtual bool deepCopyFrom(GeneralMatrixValues *that)
A function to make a deep copy of an instance of this class.
virtual OSMatrixWithMatrixConIdx * cloneMatrixNode()
The implementation of the virtual functions.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
LinearMatrixElement ** el
bool IsEqual(MixedRowReferenceMatrixElements *that)
A function to check for the equality of two objects.
virtual std::string getNodeName()
int * getRowPartition()
get the row partition of the matrix
virtual std::string getMatrixNodeInXML()
~MixedRowReferenceMatrixElements()
ObjReferenceMatrixValues * value
The objective references (indexes of core objectives) of the elements.
virtual std::string getNodeName()
virtual std::string getNodeName()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
bool IsEqual(LinearMatrixElement *that)
A function to check for the equality of two objects.
bool deepCopyFrom(ConstantMatrixElements *that)
A function to make a deep copy of an instance of this class.
virtual std::string getNodeName()
~OSMatrixWithMatrixConIdx()
int valueSize
valueSize is the dimension of the index and value arrays
bool deepCopyFrom(LinearMatrixElementTerm *that)
A function to make a deep copy of an instance of this class.
Used to hold part of the instance in memory.
virtual std::string getNodeName()
virtual std::string getNodeName()=0
LinearMatrixValues * value
The values are expressions of the form a_0 + a_1 x_{i_1} * a_2 x_{i_2} + ...
MatrixConstructor()
constructor
OSMatrixWithMatrixObjIdx()
virtual std::string getMatrixNodeInXML()
a data structure to represent row reference elements in a MatrixType object Each nonzero element is o...
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual std::string getNodeName()
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
ENUM_MATRIX_TYPE vType
vType holds the type of all (nonzero) values in the collection of blocks contained in this set of blo...
bool IsEqual(MatrixType *that)
A function to check for the equality of two objects.
this class extends OSMatrix for use, e.g., in the matrixCon section of OSoL and OSrL
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
virtual std::string getNodeName()
virtual OSMatrixWithMatrixVarIdx * cloneMatrixNode()
The implementation of the virtual functions.
LinearMatrixElementTerm()
a data structure to represent the nonzeroes of a matrix in a blockwise fashion.
int * blockRows
blockRows holds an integer array of the row to which a block belongs.
unsigned int inumberOfChildren
inumberOfChildren is the number of MatrixNode child elements For the matrix types (OSMatrix and Matri...
GeneralSparseMatrix()
Default constructor.
~ObjReferenceMatrixValues()
virtual std::string getMatrixNodeInXML()
int blockNumber
blockNumber gives the number of blocks (which is the size of the blockRows and blockColumns arrays).
GeneralSparseMatrix * ExpandedMatrixInColumnMajorForm
int baseMatrixEndRow
to select the position of the lower right corner of the portion of the base matrix that is to be sele...
MatrixNode ** m_mChildren
m_mChildren holds all the children, that is, nodes used in the definition or construction of the curr...
virtual std::string getNodeName()
a data structure to represent the constant elements in a MatrixType object
a data structure to represent the nonzeros in a conReferenceMatrix element
virtual std::string getMatrixNodeInXML()
a data structure to represent variable reference elements in a MatrixType object Each nonzero element...
bool IsEqual(ObjReferenceMatrixElements *that)
A function to check for the equality of two objects.
OSMatrix * createConstructorTreeFromPrefix(std::vector< MatrixNode * > mtxConstructorVec)
a data structure to represent a point of departure for constructing a matrix by modifying parts of a ...
a data structure to represent the nonzeros in a generalMatrix element
virtual std::string getMatrixNodeInXML()
a data structure to represent an expression in a linearMatrix element A LinearMatrixElement is a (fin...
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
~OSMatrixWithMatrixObjIdx()
a data structure to represent an entry in a conReferenceMatrix element, which consists of a constrain...
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual std::string getMatrixNodeInXML()
bool IsEqual(GeneralMatrixElements *that)
A function to check for the equality of two objects.
bool IsEqual(VarReferenceMatrixValues *that)
A function to check for the equality of two objects.
virtual bool expandElements(bool rowMajor)
A method to expand a matrix or block The result is a GeneralSparseMatrix object of constant matrix el...
bool isBlockDiagonal()
a method to determine whether the collection is blockDiagonal
virtual bool IsEqual(MatrixNode *that)
A function to check for the equality of two objects.
ENUM_MATRIX_SYMMETRY symmetry
To track the type of symmetry present in the matrix or block.
~VarReferenceMatrixValues()
an integer Vector data structure
ExpandedMatrixBlocks * disassembleMatrix(int *rowPartition, int rowPartitionSize, int *colPartition, int colPartitionSize, bool rowMajor, ENUM_MATRIX_SYMMETRY symmetry)
A method to disassemble a MatrixType into individual blocks of specific structure.
a generic class from which we derive matrix constructors (BaseMatrix, MatrixElements,...
bool deepCopyFrom(LinearMatrixElements *that)
A function to make a deep copy of an instance of this class.
std::vector< ExpandedMatrixBlocks * > ExpandedMatrixByBlocks
~ConReferenceMatrixValues()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual ENUM_MATRIX_TYPE getMatrixType()
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
virtual std::string getMatrixNodeInXML()
bool printExpandedMatrix(bool rowMajor)
a utility routine to print the expanded matrix or block.
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
a data structure to represent objective reference elements in a MatrixType object Each nonzero elemen...
virtual std::string getMatrixNodeInXML()
virtual BaseMatrix * cloneMatrixNode()
The implementation of the virtual functions.
virtual std::string getMatrixNodeInXML()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual GeneralMatrixElements * cloneMatrixNode()
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
ENUM_MATRIX_TYPE matrixType
matrixType tracks the type of elements contained in this MatrixNode, which may be useful in solver se...
bool IsEqual(MatrixElements *that)
A function to check for the equality of two objects.
bool IsEqual(ObjReferenceMatrixValues *that)
A function to check for the equality of two objects.
virtual std::string getNodeName()
GeneralSparseMatrix * getMatrixCoefficientsInColumnMajor()
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
bool isDiagonal()
a method to determine whether the matrix is diagonal
~ConReferenceMatrixElement()
bool IsEqual(OSMatrix *that)
A function to check for the equality of two objects.
ConReferenceMatrixValues()
virtual std::string getMatrixNodeInXML()=0
a sparse matrix data structure for matrices that can hold nonconstant values and have block structure...
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
int * getColumnPartition()
get the column partition of the matrix
bool isRowMajor
isRowMajor holds whether the matrix is stored by row.
~GeneralSparseMatrix()
Default destructor.
int getNumberOfTransformationConstructors()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
ENUM_MATRIX_CONSTRUCTOR_TYPE
ENUM_MATRIX_TYPE
An enum to track the many different types of values that a matrix can contain Note that these types a...
bool deepCopyFrom(GeneralMatrixElements *that)
A function to make a deep copy of an instance of this class.
bool deepCopyFrom(MatrixType *that)
A function to make a deep copy of an instance of this class.
This file defines the OSnLNode class along with its derived classes.
virtual ENUM_MATRIX_TYPE getMatrixType()
int * colOffset
colOffset gives the column offsets of the block decomposition It does not have to correspond to the c...
LinearMatrixElement * convertToLinearMatrixElement(double val)
Some methods to convert one type of matrix element into another.
bool deepCopyFrom(ConReferenceMatrixElements *that)
A function to make a deep copy of an instance of this class.
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
OSMatrixWithMatrixConIdx()
bool b_deleteValueArray
b_deleteValueArray is true if we delete the value array in garbage collection — set to true by defaul...
bool rowMajor
To indicate whether the matrix elements are stored in row major form or column major form.
int * blockColumns
blockColumns holds an integer array of the column to which a block belongs.
IntVector * rowOffset
An array listing the top row of each block within the larger matrix.
bool b_deleteStartArray
b_deleteStartArray is true if we delete the start array in garbage collection — set to true by defaul...
VarReferenceMatrixElements()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual bool processBlocks(bool rowMajor, ENUM_MATRIX_SYMMETRY symmetry)
A method to process a matrixType into a block structure defined by the <blocks> element or elements.
std::vector< MatrixNode * > preOrderMatrixNodeTraversal(std::vector< MatrixNode * > *prefixVector)
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
virtual MatrixBlocks * cloneMatrixNode()
The implementation of the virtual functions.
bool IsEqual(ConReferenceMatrixElements *that)
A function to check for the equality of two objects.
virtual ENUM_MATRIX_CONSTRUCTOR_TYPE getNodeType()
IntVector * colOffset
An array listing the leftmost column of each block within the larger matrix It is assumed that the bl...
BaseMatrix()
Standard constructor and destructor methods.
GeneralSparseMatrix * convertToOtherMajor(bool isColumnMajor)
A method to convert a matrix to the other major.
bool processBlockPartition()
A method to determine the block structure of a matrixType as defined by the <blocks> element or eleme...
virtual bool deepCopyFrom(LinearMatrixValues *that)
A function to make a deep copy of an instance of this class.
bool deepCopyFrom(OSMatrixWithMatrixObjIdx *that)
A function to make a deep copy of an instance of this class.
virtual std::string getNodeName()
virtual ENUM_MATRIX_TYPE getMatrixType()
bool deepCopyFrom(LinearMatrixElement *that)
A function to make a deep copy of an instance of this class.
bool IsEqual(LinearMatrixValues *that)
A function to check for the equality of two objects.
~VarReferenceMatrixElements()
GeneralMatrixValues * value
The values are general nonlinear expressions.
virtual ConstantMatrixElements * cloneMatrixNode()
a data structure to represent the nonzero values in a generalMatrix element
a data structure to represent a MatrixBlock object (derived from MatrixType)
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
ENUM_MATRIX_TYPE type
To track the type of values present in the matrix or block.
bool IsEqual(GeneralMatrixValues *that)
A function to check for the equality of two objects.
bool IsEqual(LinearMatrixElementTerm *that)
A function to check for the equality of two objects.
std::vector< MatrixNode * > getPostfixFromNodeTree()
virtual VarReferenceMatrixElements * cloneMatrixNode()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
~LinearMatrixElementTerm()
~OSMatrixWithMatrixVarIdx()
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
a data structure to represent a matrix object (derived from MatrixType)
virtual ~MatrixElements()
virtual bool deepCopyFrom(ObjReferenceMatrixValues *that)
A function to make a deep copy of an instance of this class.
virtual OSMatrixWithMatrixObjIdx * cloneMatrixNode()
The implementation of the virtual functions.
bool IsEqual(ConstantMatrixElements *that)
A function to check for the equality of two objects.
bool baseTranspose
to allow the base matrix to be transposed before it is attached to the target matrix
bool deepCopyFrom(ConstantMatrixValues *that)
A function to make a deep copy of an instance of this class.
int getRowPartitionSize()
get the size of the row partition of a matrix
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
int getNumberOfElementConstructors()
virtual std::string getMatrixNodeInXML()
virtual std::string getMatrixNodeInXML()
a data structure to describe one step in the construction of a matrix.
bool getRowMajor()
Returns whether the matrix is stored row-wise or column-wise.
a data structure to represent a term in a linearMatrix element A term has the form c*x_{k},...
ENUM_MATRIX_CONSTRUCTOR_TYPE nType
nType is a unique integer assigned to each type of matrix node (see OSParameters.h)
GeneralSparseMatrix ** blocks
blocks holds the blocks that make up the matrix.
bool setRandom(double density, bool conformant, int iMin, int iMax)
A function to make a random instance of this class.
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
~ConReferenceMatrixElements()
OSMatrixWithMatrixVarIdx()
bool bDeleteArrays
bDeleteArrays is true if we delete the arrays in garbage collection set to true by default
ConReferenceMatrixElement ** el
el contains the indices of the matrix constraints along with the valueType.
std::vector< MatrixNode * > postOrderMatrixNodeTraversal(std::vector< MatrixNode * > *postfixVector)
ConReferenceMatrixElements()
bool IsEqual(VarReferenceMatrixElements *that)
A function to check for the equality of two objects.
virtual bool alignsOnBlockBoundary(int firstRow, int firstColumn, int nRows, int nCols)
Check whether a submatrix aligns with the block partition of a matrix or block or other constructor.
virtual MatrixNode * cloneMatrixNode()=0
int targetMatrixFirstRow
to pinpoint the position of the upper left corner of the base matrix within the target matrix
bool IsEqual(LinearMatrixElements *that)
A function to check for the equality of two objects.
The OSnLNode Class for nonlinear expressions.
bool matrixHasTransformations()
virtual std::string getMatrixNodeInXML()
bool deepCopyFrom(OSMatrixWithMatrixVarIdx *that)
A function to make a deep copy of an instance of this class.
bool IsEqual(MatrixBlock *that)
A function to check for the equality of two objects.
virtual bool expandElements(bool rowMajor)
A method to process a matrixType into a specific block structure.
virtual ENUM_MATRIX_TYPE getMatrixType()