![]() |
Reference documentation for deal.II version 8.4.2
|
#include <deal.II/lac/block_sparsity_pattern.h>
Public Member Functions | |
| BlockDynamicSparsityPattern () | |
| BlockDynamicSparsityPattern (const size_type n_rows, const size_type n_columns) | |
| BlockDynamicSparsityPattern (const std::vector< size_type > &row_block_sizes, const std::vector< size_type > &col_block_sizes) | |
| BlockDynamicSparsityPattern (const std::vector< IndexSet > &partitioning) | |
| BlockDynamicSparsityPattern (const BlockIndices &row_indices, const BlockIndices &col_indices) | |
| void | reinit (const std::vector< size_type > &row_block_sizes, const std::vector< size_type > &col_block_sizes) |
| void | reinit (const std::vector< IndexSet > &partitioning) |
| void | reinit (const BlockIndices &row_indices, const BlockIndices &col_indices) |
| size_type | column_number (const size_type row, const unsigned int index) const |
Public Member Functions inherited from BlockSparsityPatternBase< DynamicSparsityPattern > | |
| BlockSparsityPatternBase () | |
| BlockSparsityPatternBase (const size_type n_block_rows, const size_type n_block_columns) | |
| BlockSparsityPatternBase (const BlockSparsityPatternBase &bsp) | |
| ~BlockSparsityPatternBase () | |
| void | reinit (const size_type n_block_rows, const size_type n_block_columns) |
| BlockSparsityPatternBase & | operator= (const BlockSparsityPatternBase &) |
| void | collect_sizes () |
| DynamicSparsityPattern & | block (const size_type row, const size_type column) |
| const DynamicSparsityPattern & | block (const size_type row, const size_type column) const |
| const BlockIndices & | get_row_indices () const |
| const BlockIndices & | get_column_indices () const |
| void | compress () |
| size_type | n_block_rows () const |
| size_type | n_block_cols () const |
| bool | empty () const |
| size_type | max_entries_per_row () const |
| void | add (const size_type i, const size_type j) |
| void | add_entries (const size_type row, ForwardIterator begin, ForwardIterator end, const bool indices_are_sorted=false) |
| size_type | n_rows () const |
| size_type | n_cols () const |
| bool | exists (const size_type i, const size_type j) const |
| unsigned int | row_length (const size_type row) const |
| size_type | n_nonzero_elements () const |
| void | print (std::ostream &out) const |
| void | print_gnuplot (std::ostream &out) const |
| DeclException4 (ExcIncompatibleRowNumbers, int, int, int, int,<< "The blocks ["<< arg1<< ','<< arg2<< "] and ["<< arg3<< ','<< arg4<< "] have differing row numbers.") | |
| DeclException4 (ExcIncompatibleColNumbers, int, int, int, int,<< "The blocks ["<< arg1<< ','<< arg2<< "] and ["<< arg3<< ','<< arg4<< "] have differing column numbers.") | |
| DeclException0 (ExcInvalidConstructorCall) | |
Public Member Functions inherited from Subscriptor | |
| Subscriptor () | |
| Subscriptor (const Subscriptor &) | |
| virtual | ~Subscriptor () |
| Subscriptor & | operator= (const Subscriptor &) |
| void | subscribe (const char *identifier=0) const |
| void | unsubscribe (const char *identifier=0) const |
| unsigned int | n_subscriptions () const |
| void | list_subscribers () const |
| DeclException3 (ExcInUse, int, char *, std::string &,<< "Object of class "<< arg2<< " is still used by "<< arg1<< " other objects."<< "\"<< "(Additional information: "<< arg3<< ")\"<< "See the entry in the Frequently Asked Questions of "<< "deal.II (linked to from http://www.dealii.org/) for "<< "a lot more information on what this error means and "<< "how to fix programs in which it happens.") | |
| DeclException2 (ExcNoSubscriber, char *, char *,<< "No subscriber with identifier <"<< arg2<< "> subscribes to this object of class "<< arg1<< ". Consequently, it cannot be unsubscribed.") | |
| template<class Archive > | |
| void | serialize (Archive &ar, const unsigned int version) |
Additional Inherited Members | |
Public Types inherited from BlockSparsityPatternBase< DynamicSparsityPattern > | |
| typedef types::global_dof_index | size_type |
Static Public Attributes inherited from BlockSparsityPatternBase< DynamicSparsityPattern > | |
| static const size_type | invalid_entry |
Protected Attributes inherited from BlockSparsityPatternBase< DynamicSparsityPattern > | |
| size_type | rows |
| size_type | columns |
| Table< 2, SmartPointer< DynamicSparsityPattern, BlockSparsityPatternBase< DynamicSparsityPattern > > > | sub_objects |
| BlockIndices | row_indices |
| BlockIndices | column_indices |
This class extends the base class to implement an array of compressed sparsity patterns that can be used to initialize objects of type BlockSparsityPattern. It does not add additional member functions, but rather acts as a typedef to introduce the name of this class, without requiring the user to specify the templated name of the base class. For information on the interface of this class refer to the base class. The individual blocks are based on the CompressedSparsityPattern class.
This class is an example of the "dynamic" type of Sparsity patterns.
Usage of this class is very similar to DynamicSparsityPattern, but since the use of block indices causes some additional complications, we give a short example.
After the the DoFHandler dof and the ConstraintMatrix constraints have been set up with a system element, we must count the degrees of freedom in each matrix block:
Now, we are ready to set up the BlockDynamicSparsityPattern.
It is filled as if it were a normal pattern
In the end, it is copied to a normal BlockSparsityPattern for later use.
Definition at line 495 of file block_sparsity_pattern.h.
| BlockDynamicSparsityPattern::BlockDynamicSparsityPattern | ( | ) |
Initialize the matrix empty, that is with no memory allocated. This is useful if you want such objects as member variables in other classes. You can make the structure usable by calling the reinit() function.
Definition at line 419 of file block_sparsity_pattern.cc.
| BlockDynamicSparsityPattern::BlockDynamicSparsityPattern | ( | const size_type | n_rows, |
| const size_type | n_columns | ||
| ) |
Initialize the matrix with the given number of block rows and columns. The blocks themselves are still empty, and you have to call collect_sizes() after you assign them sizes.
Definition at line 425 of file block_sparsity_pattern.cc.
| BlockDynamicSparsityPattern::BlockDynamicSparsityPattern | ( | const std::vector< size_type > & | row_block_sizes, |
| const std::vector< size_type > & | col_block_sizes | ||
| ) |
Initialize the pattern with two BlockIndices for the block structures of matrix rows and columns. This function is equivalent to calling the previous constructor with the length of the two index vector and then entering the index values.
Definition at line 435 of file block_sparsity_pattern.cc.
| BlockDynamicSparsityPattern::BlockDynamicSparsityPattern | ( | const std::vector< IndexSet > & | partitioning | ) |
Initialize the pattern with symmetric blocks. The number of IndexSets in the vector determine the number of rows and columns of blocks. The size of each block is determined by the size() of the respective IndexSet. Each block only stores the rows given by the values in the IndexSet, which is useful for distributed memory parallel computations and usually corresponds to the locally owned DoFs.
Definition at line 449 of file block_sparsity_pattern.cc.
| BlockDynamicSparsityPattern::BlockDynamicSparsityPattern | ( | const BlockIndices & | row_indices, |
| const BlockIndices & | col_indices | ||
| ) |
Initialize the pattern with two BlockIndices for the block structures of matrix rows and columns.
Definition at line 464 of file block_sparsity_pattern.cc.
| void BlockDynamicSparsityPattern::reinit | ( | const std::vector< size_type > & | row_block_sizes, |
| const std::vector< size_type > & | col_block_sizes | ||
| ) |
Resize the pattern to a tensor product of matrices with dimensions defined by the arguments.
The matrix will have as many block rows and columns as there are entries in the two arguments. The block at position (i,j) will have the dimensions row_block_sizes[i] times col_block_sizes[j].
Definition at line 472 of file block_sparsity_pattern.cc.
| void BlockDynamicSparsityPattern::reinit | ( | const std::vector< IndexSet > & | partitioning | ) |
Resize the pattern with symmetric blocks determined by the size() of each IndexSet. See the constructor taking a vector of IndexSets for details.
Definition at line 485 of file block_sparsity_pattern.cc.
| void BlockDynamicSparsityPattern::reinit | ( | const BlockIndices & | row_indices, |
| const BlockIndices & | col_indices | ||
| ) |
Resize the matrix to a tensor product of matrices with dimensions defined by the arguments. The two BlockIndices objects must be initialized and the sparsity pattern will have the same block structure afterwards.
Definition at line 499 of file block_sparsity_pattern.cc.
|
inline |
Access to column number field. Return the column number of the index th entry in row row.
Definition at line 961 of file block_sparsity_pattern.h.
1.8.12