linbox
Data Structures | Public Types | Public Member Functions | Protected Attributes
BlasSubmatrix< _Field > Class Template Reference

Dense Submatrix representation. More...

#include <blas-matrix.h>

+ Inheritance diagram for BlasSubmatrix< _Field >:

Data Structures

class  ConstIndexedIterator
 Raw Indexed Iterator (const version). More...
class  ConstIterator
 Raw Iterators (const version). More...
class  IndexedIterator
 Raw Indexed Iterator. More...
class  Iterator
 Raw Iterators. More...

Public Types

typedef Field::Element Element
 Element type.
typedef BlasSubmatrix< _Field > Self_t
 Self type.
typedef RawVector< Element >::Dense Rep
 Actually a std::vector<Element> (or alike.)
typedef Rep::pointer pointer
 pointer type to elements
typedef const pointer const_pointer
 const pointer type
typedef'd Row Iterators.

The row iterator gives the rows of the matrix in ascending order.

Dereferencing the iterator yields a row vector in dense format

typedef BlasMatrix< _Field >
::RowIterator 
RowIterator
typedef BlasMatrix< _Field >
::ConstRowIterator 
ConstRowIterator
typedef BlasMatrix< _Field >::Row Row
typedef BlasMatrix< _Field >
::ConstRow 
ConstRow
typedef'd Column Iterators.

The columns iterator gives the columns of the matrix in ascending order.

Dereferencing the iterator yields a column vector in dense format

typedef BlasMatrix< _Field >
::ColIterator 
ColIterator
typedef BlasMatrix< _Field >
::ConstColIterator 
ConstColIterator
typedef BlasMatrix< _Field >::Col Col
typedef BlasMatrix< _Field >
::Column 
Column
typedef BlasMatrix< _Field >
::ConstCol 
ConstCol

Public Member Functions

 BlasSubmatrix ()
 NULL constructor.
 BlasSubmatrix (const BlasMatrix< _Field > &M, size_t rowbeg, size_t colbeg, size_t Rowdim, size_t Coldim)
 Constructor from an existing BlasMatrix and dimensions.
 BlasSubmatrix (const BlasMatrix< _Field > &M)
 Constructor from an existing BlasMatrix.
 BlasSubmatrix (const BlasSubmatrix< _Field > &SM, size_t rowbeg, size_t colbeg, size_t Rowdim, size_t Coldim)
 Constructor from an existing submatrix and dimensions.
 BlasSubmatrix (const BlasSubmatrix< _Field > &SM)
 Copy constructor.
BlasSubmatrixoperator= (const BlasSubmatrix< _Field > &SM)
 Assignment operator.
size_t rowdim () const
 Get the number of rows in the matrix.
size_t coldim () const
 Get the number of columns in the matrix.
size_t getStride () const
  Get the stride of the matrix.
std::istream & read (std::istream &file)
 Read the matrix from an input stream.
std::ostream & write (std::ostream &os, enum LinBoxTag::Format f=LinBoxTag::FormatMaple) const
 Write the matrix to an output stream.
std::ostream & write (std::ostream &os, bool mapleFormat) const
pointer getPointer () const
  .
pointergetWritePointer ()
  .
void setEntry (size_t i, size_t j, const Element &a_ij)
 Set the entry at (i, j).
ElementrefEntry (size_t i, size_t j)
 Get a writeable reference to an entry in the matrix.
const ElementgetEntry (size_t i, size_t j) const
 Get a read-only individual entry from the matrix.
ElementgetEntry (Element &x, size_t i, size_t j) const
 Get an entry and store it in the given value.
RowIterator rowBegin ()
 iterator to the begining of a row
RowIterator rowEnd ()
 iterator to the end of a row
ConstRowIterator rowBegin () const
 const iterator to the begining of a row
ConstRowIterator rowEnd () const
 const iterator to the end of a row
Row operator[] (size_t i)
 operator[].
template<class Vector1 , class Vector2 >
Vector1 & apply (Vector1 &y, const Vector2 &x) const

Protected Attributes

BlasMatrix< _Field > * _Mat
 Parent BlasMatrix (ie raw vector)
size_t _row
 row dimension of Submatrix
size_t _col
 col dimension of Submatrix
size_t _r0
 upper left corner row of Submatrix in _Mat
size_t _c0
 upper left corner row of Submatrix in _Mat
size_t _stride
 number of columns in _Mat (or stride of _Mat)

Detailed Description

template<class _Field>
class LinBox::BlasSubmatrix< _Field >

Dense Submatrix representation.

A BlasSubmatrix is a matrix of _Field::Element, with the structure of BLAS matrices. It is basically a read/write view on a vector of _Field::Element. In the Mother model, a BlasSubmatrix is not allocated.

This matrix type conforms to the same interface as BlasMatrix, except that you cannot resize it. It represents a submatrix of a dense matrix. Upon construction, one can freely manipulate the entries in the DenseSubmatrix, and the corresponding entries in the underlying BlasMatrix will be modified.

Constructor & Destructor Documentation

NULL constructor.

BlasSubmatrix ( const BlasMatrix< _Field > &  M,
size_t  rowbeg,
size_t  colbeg,
size_t  Rowdim,
size_t  Coldim 
)

Constructor from an existing BlasMatrix and dimensions.

Parameters
MPointer to BlasMatrix of which to construct submatrix
rowbegStarting row
colbegStarting column
RowdimRow dimension
ColdimColumn dimension
BlasSubmatrix ( const BlasMatrix< _Field > &  M)

Constructor from an existing BlasMatrix.

Parameters
MPointer to BlasMatrix of which to construct submatrix
BlasSubmatrix ( const BlasSubmatrix< _Field > &  SM,
size_t  rowbeg,
size_t  colbeg,
size_t  Rowdim,
size_t  Coldim 
)

Constructor from an existing submatrix and dimensions.

Parameters
SMConstant reference to BlasSubmatrix from which to construct submatrix
rowbegStarting row
colbegStarting column
RowdimRow dimension
ColdimColumn dimension
BlasSubmatrix ( const BlasSubmatrix< _Field > &  SM)

Copy constructor.

Parameters
SMSubmatrix to copy

Member Function Documentation

BlasSubmatrix< _Field > & operator= ( const BlasSubmatrix< _Field > &  SM)

Assignment operator.

Assign the given submatrix to this one This is only renaming ! There is no copy because BlasSubmatrix owns nothing.

Parameters
SMSubmatrix to assign
Returns
Reference to this submatrix
size_t rowdim ( ) const

Get the number of rows in the matrix.

Returns
Number of rows in matrix
size_t coldim ( ) const

Get the number of columns in the matrix.

Returns
Number of columns in matrix
size_t getStride ( ) const

 Get the stride of the matrix.

Returns
stride of submatrix (number of cols of dense base matrix)
std::istream & read ( std::istream &  file)

Read the matrix from an input stream.

Parameters
fileInput stream from which to read
Bug:
reading a submatrix should not be allowed !!

Reimplemented in Submatrix< BlasMatrix< _Field >, VectorCategories::DenseVectorTag >.

std::ostream & write ( std::ostream &  os,
enum LinBoxTag::Format  f = LinBoxTag::FormatMaple 
) const

Write the matrix to an output stream.

Parameters
osOutput stream to which to write
fwrite in some format (LinBoxTag::Format). Default is Maple's.
Warning
matrix base does not provide this field(), maybe should? _Mat.field ().write (os, *pe); os << *pe; fixed by using extra field
std::ostream& write ( std::ostream &  os,
bool  mapleFormat 
) const
inline
Deprecated:
Only for compatiblity.
void setEntry ( size_t  i,
size_t  j,
const Element a_ij 
)

Set the entry at (i, j).

Parameters
iRow number, 0...rowdim () - 1
jColumn number 0...coldim () - 1
a_ijElement to set
_Field::Element & refEntry ( size_t  i,
size_t  j 
)

Get a writeable reference to an entry in the matrix.

Parameters
iRow index of entry
jColumn index of entry
Returns
Reference to matrix entry
const _Field::Element & getEntry ( size_t  i,
size_t  j 
) const

Get a read-only individual entry from the matrix.

Parameters
iRow index
jColumn index
Returns
Const reference to matrix entry
_Field::Element & getEntry ( Element x,
size_t  i,
size_t  j 
) const

Get an entry and store it in the given value.

This form is more in the Linbox style and is provided for interface compatibility with other parts of the library

Parameters
xElement in which to store result
iRow index
jColumn index
Returns
Reference to x
BlasSubmatrix< _Field >::Row operator[] ( size_t  i)

operator[].

Retrieve a reference to a row

Parameters
iRow index
Vector1& apply ( Vector1 &  y,
const Vector2 &  x 
) const
inline
Bug:
this supposes &x[0]++ == &x[1]

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