10 #ifndef __RD_SQUARE_MATRIX_H__ 11 #define __RD_SQUARE_MATRIX_H__ 40 const TYPE *bData = B.
getData();
43 unsigned int idA, idAt, idC, idCt, idB;
44 TYPE* data = this->
d_data.get();
45 for (i = 0; i < this->
d_nRows; i++) {
48 for (j = 0; j < this->
d_nCols; j++) {
50 newData[idCt] = (TYPE)(0.0);
51 for (k = 0; k < this->
d_nCols; k++) {
53 idB = k*this->d_nRows + j;
54 newData[idCt] += (data[idAt]*bData[idB]);
58 boost::shared_array<TYPE> tsptr(newData);
66 unsigned int id1, id1t, id2;
68 TYPE *data = this->
d_data.get();
69 for (i = 1; i < this->
d_nRows; i++) {
71 for (j = 0; j < i; j++) {
74 id2 = j*this->d_nCols + i;
76 data[id1t] = data[id2];
SquareMatrix(unsigned int N, TYPE val)
unsigned int numRows() const
returns the number of rows
virtual SquareMatrix< TYPE > & operator*=(TYPE scale)
Multiplication by a scalar.
#define CHECK_INVARIANT(expr, mess)
virtual Matrix< TYPE > & operator*=(TYPE scale)
Multiplication by a scalar.
SquareMatrix()
brief Square matrix of size N
SquareMatrix< double > DoubleSquareMatrix
A matrix class for general, non-square matrices.
boost::shared_array< TYPE > DATA_SPTR
SquareMatrix(unsigned int N, typename Matrix< TYPE >::DATA_SPTR data)
virtual SquareMatrix< TYPE > & operator*=(const SquareMatrix< TYPE > &B)
In place matrix multiplication.
SquareMatrix(unsigned int N)
TYPE * getData()
returns a pointer to our data array
virtual SquareMatrix< TYPE > & transposeInplace()
In place matrix transpose.