HermesCommon  3.0
Hermes::Algebra::CSRMatrix< Scalar > Class Template Reference

General CSR Matrix class. (can be used in umfpack, in that case use the CSCMatrix subclass, or with EigenSolver, or anything else). More...

#include <cs_matrix.h>

+ Inheritance diagram for Hermes::Algebra::CSRMatrix< Scalar >:

Public Member Functions

 CSRMatrix ()
 Default constructor.
 
 CSRMatrix (unsigned int size)
 Constructor with specific size Calls alloc. More...
 
virtual Scalar get (unsigned int m, unsigned int n) const
 
virtual void add (unsigned int m, unsigned int n, Scalar v)
 
void export_to_file (const char *filename, const char *var_name, MatrixExportFormat fmt, char *number_format="%lf")
 
void import_from_file (const char *filename, const char *var_name, MatrixExportFormat fmt)
 
SparseMatrix< Scalar > * duplicate () const
 Duplicates a matrix (including allocation).
 
virtual void pre_add_ij (unsigned int row, unsigned int col)
 
template<>
void add (unsigned int m, unsigned int n, double v)
 
template<>
void add (unsigned int m, unsigned int n, std::complex< double > v)
 
- Public Member Functions inherited from Hermes::Algebra::CSMatrix< Scalar >
void create (unsigned int size, unsigned int nnz, int *ap, int *ai, Scalar *ax)
 
 CSMatrix ()
 Default constructor.
 
 CSMatrix (unsigned int size)
 Constructor with specific size Calls alloc. More...
 
void switch_orientation ()
 Switches CSR / CSC arrays.
 
virtual void alloc ()
 Allocate utility storage (row, column indices, etc.).
 
virtual void alloc_data ()
 
virtual void free ()
 Utility method.
 
virtual void zero ()
 Utility method.
 
virtual void set_row_zero (unsigned int n)
 Utility method.
 
void export_to_file (const char *filename, const char *var_name, MatrixExportFormat fmt, char *number_format="%lf", bool invert_storage=false)
 
void import_from_file (const char *filename, const char *var_name, MatrixExportFormat fmt, bool invert_storage=false)
 
virtual unsigned int get_nnz () const
 Utility method.
 
virtual double get_fill_in () const
 Utility method.
 
void multiply_with_Scalar (Scalar value)
 Multiplies matrix with a Scalar.
 
int * get_Ap () const
 
int * get_Ai () const
 
Scalar * get_Ax () const
 
virtual void add_as_block (unsigned int i, unsigned int j, SparseMatrix< Scalar > *mat)
 
template<>
void add (unsigned int m, unsigned int n, double v)
 
template<>
void add (unsigned int m, unsigned int n, std::complex< double > v)
 
- Public Member Functions inherited from Hermes::Algebra::SparseMatrix< Scalar >
 SparseMatrix (unsigned int size)
 
virtual void prealloc (unsigned int n)
 
virtual void finish ()
 Finish manipulation with matrix (called before solving)
 
virtual void add_sparse_matrix (SparseMatrix< Scalar > *mat)
 
virtual void add_sparse_to_diagonal_blocks (int num_stages, SparseMatrix< Scalar > *mat)
 
virtual int get_num_row_entries (unsigned int row) const
 
virtual void extract_row_copy (unsigned int row, unsigned int len, unsigned int &n_entries, double *vals, unsigned int *idxs) const
 
virtual int get_num_col_entries (unsigned int col) const
 
virtual void extract_col_copy (unsigned int col, unsigned int len, unsigned int &n_entries, double *vals, unsigned int *idxs) const
 
- Public Member Functions inherited from Hermes::Algebra::Matrix< Scalar >
 Matrix (unsigned int size=0)
 
virtual void add (unsigned int m, unsigned int n, Scalar *mat, int *rows, int *cols, const int size)
 
virtual void add_to_diagonal (Scalar v)
 Add a number to each diagonal entry.
 
virtual void multiply_with_vector (Scalar *vector_in, Scalar *&vector_out, bool vector_out_initialized=false) const
 Multiply with a vector.
 
virtual unsigned int get_size () const
 
template<>
void add (unsigned int m, unsigned int n, double *mat, int *rows, int *cols, const int size)
 
template<>
void add (unsigned int m, unsigned int n, std::complex< double > *mat, int *rows, int *cols, const int size)
 
- Public Member Functions inherited from Hermes::Mixins::Loggable
 Loggable (bool verbose_output=false, callbackFn verbose_callback=NULL, bool add_newline=true)
 
void set_file_output_only (bool onOff)
 
void set_timestamps (bool onOff)
 Sets the addition of a time stamp on each line in the log file. By default it is on.
 
void set_erase_on_beginning (bool onOff)
 Sets the logFile being always erased before logging.
 
void set_logFile_name (const char *filename)
 
void set_logFile_name (std::string filename)
 
void info (const char *msg,...) const
 
void info_if (bool cond, const char *msg,...) const
 
void warn (const char *msg,...) const
 
void warn_if (bool cond, const char *msg,...) const
 
void error (const char *msg,...) const
 
void error_if (bool cond, const char *msg,...) const
 
virtual void set_verbose_output (bool to_set)
 
bool get_verbose_output () const
 Returns the current value of verbose_output;.
 
virtual void set_verbose_callback (callbackFn callback)
 
callbackFn get_verbose_callback () const
 Returns the current value of verbose_callback;.
 
- Public Member Functions inherited from Hermes::Algebra::Mixins::MatrixRhsImportExport< Scalar >
void export_to_file (std::string filename, const char *var_name, Algebra::MatrixExportFormat fmt, char *number_format="%lf")
 
void export_to_file (std::string filename, std::string var_name, Algebra::MatrixExportFormat fmt, char *number_format="%lf")
 
void import_from_file (std::string filename, const char *var_name, Algebra::MatrixExportFormat fmt)
 
void import_from_file (std::string filename, std::string var_name, Algebra::MatrixExportFormat fmt)
 

Additional Inherited Members

- Static Public Member Functions inherited from Hermes::Algebra::CSMatrix< Scalar >
static int find_position (int *Ai, int Alen, unsigned int idx)
 Finds the correct position to insert / retrieve elements.
 
- Static Public Member Functions inherited from Hermes::Mixins::Loggable
static void set_static_logFile_name (const char *filename)
 
static void set_static_logFile_name (std::string filename)
 
- Public Attributes inherited from Hermes::Mixins::Loggable
char * logFileName
 Logfile name.
 
- Static Public Attributes inherited from Hermes::Mixins::Loggable
static char * staticLogFileName = nullptr
 
- Protected Member Functions inherited from Hermes::Algebra::SparseMatrix< Scalar >
int sort_and_store_indices (Page *page, int *buffer, int *max)
 
int get_num_indices ()
 
- Protected Member Functions inherited from Hermes::Mixins::Loggable
void hermes_fwrite (const void *ptr, size_t size, size_t nitems, FILE *stream) const
 
void hermes_fread (void *ptr, size_t size, size_t nitems, FILE *stream) const
 
- Protected Attributes inherited from Hermes::Algebra::CSMatrix< Scalar >
Scalar * Ax
 
int * Ai
 Row / Column indices of values in Ax.
 
int * Ap
 Index to Ax/Ai, where each column / row starts.
 
unsigned int nnz
 Number of non-zero entries ( = Ap[size]).
 
- Protected Attributes inherited from Hermes::Algebra::SparseMatrix< Scalar >
Pagepages
 array of pages with indices array. Each field of arra contains pages for one column
 
Page ** next_pages
 
- Protected Attributes inherited from Hermes::Algebra::Matrix< Scalar >
unsigned int size
 matrix size
 
- Static Protected Attributes inherited from Hermes::Algebra::SparseMatrix< Scalar >
static const int PAGE_SIZE = 100
 

Detailed Description

template<typename Scalar>
class Hermes::Algebra::CSRMatrix< Scalar >

General CSR Matrix class. (can be used in umfpack, in that case use the CSCMatrix subclass, or with EigenSolver, or anything else).

Definition at line 161 of file cs_matrix.h.

Constructor & Destructor Documentation

template<typename Scalar >
Hermes::Algebra::CSRMatrix< Scalar >::CSRMatrix ( unsigned int  size)

Constructor with specific size Calls alloc.

Parameters
[in]sizesize of matrix (number of rows and columns)

Definition at line 753 of file cs_matrix.cpp.

Member Function Documentation

template<typename Scalar>
virtual void Hermes::Algebra::CSRMatrix< Scalar >::add ( unsigned int  Ai_data_index,
unsigned int  Ai_index,
Scalar  v 
)
virtual

Main addition method. Virtual - the method body is 1:1 for CSCMatrix, inverted for CSR.

Reimplemented from Hermes::Algebra::CSMatrix< Scalar >.

template<typename Scalar >
void Hermes::Algebra::CSRMatrix< Scalar >::export_to_file ( const char *  filename,
const char *  var_name,
MatrixExportFormat  fmt,
char *  number_format = "%lf" 
)
virtual

writing matrix.

Parameters
[in]filenameobvious
[in]var_namename of variable (will be written to output file)
[in]fmtoutput file format
[in]number_formatspecifies the number format where possible

Implements Hermes::Algebra::Mixins::MatrixRhsImportExport< Scalar >.

Definition at line 578 of file cs_matrix.cpp.

template<typename Scalar >
Scalar Hermes::Algebra::CSRMatrix< Scalar >::get ( unsigned int  Ai_data_index,
unsigned int  Ai_index 
) const
virtual

Main get method. Virtual - the method body is 1:1 for CSCMatrix, inverted for CSR.

Reimplemented from Hermes::Algebra::CSMatrix< Scalar >.

Definition at line 775 of file cs_matrix.cpp.

template<typename Scalar >
void Hermes::Algebra::CSRMatrix< Scalar >::import_from_file ( const char *  filename,
const char *  var_name,
MatrixExportFormat  fmt 
)
virtual

reading matrix

Parameters
[in]filenameobvious
[in]var_namename of variable (will be searched for to output file)
[in]fmtinput file format

Reimplemented from Hermes::Algebra::Mixins::MatrixRhsImportExport< Scalar >.

Definition at line 734 of file cs_matrix.cpp.

template<typename Scalar >
void Hermes::Algebra::CSRMatrix< Scalar >::pre_add_ij ( unsigned int  row,
unsigned int  col 
)
virtual

Important - normal SparseMatrix has the pages structure suitable for CSC matrix, so we need to override the structure creation here. add indices of nonzero matrix element

Parameters
[in]row- row index
[in]col- column index

Reimplemented from Hermes::Algebra::SparseMatrix< Scalar >.

Definition at line 781 of file cs_matrix.cpp.


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