MatrixFacade and VectorFacade
Summary
The class VectorFacade is a base class and interface class for all vectors associated to the
indices of a global basis and, correspondingly, the class MatrixFacade is a base class and interface
class for all matrices associated to the indices of a row and column global basis.
Classes
| Class | Descriptions | 
|---|---|
| MatrixFacade | Base class for matrices | 
| VectorFacade | Base class for vectors | 
class MatrixFacade
Defined in header <amdis/linearalgebra/MatrixFacade.hpp>
template <class T, template <class> class MatrixImpl>
class MatrixFacade
MatrixFacade is an interface class for matrices storing the implementation and rediricting to its interface functions.
The template parameter T defines the coefficient type of the matrix, MatrixImpl refers to the actual implementation of the matrix data-structure.
Member Types
| Member Type | Definition | 
|---|---|
| Impl | The Linear-Algebra implementation used to store the assembled coefficients | 
class VectorFacade
Defined in header <amdis/linearalgebra/VectorFacade.hpp>
template <class T, template <class> class VectorImpl>
class VectorFacade
VectorFacade is an interface class for vectors storing the implementation and rediricting to its interface functions.
The template parameter T defines the coefficient type of the vector, VectorImpl refers to the actual implementation of the vector data-structure.
Member Types
| Member Type | Definition | 
|---|---|
| Impl | The Linear-Algebra implementation used to store the assembled coefficients | 
Member functions
| Function | Descriptions | 
|---|---|
| (constructor) | Construct the VectorFacade | 
| impl | Return the vector implementation | 
Capacity
| Function | Descriptions | 
|---|---|
| localSize,globalSize | The number of entries in the local/global part of the vector | 
| resize,resizeZero | Resize the vector to the size of the basis | 
| init | Prepare the vector for insertion of values | 
| finish | Finish the insertion of values | 
Element access
| Function | Descriptions | 
|---|---|
| at | Return the value of the vector at the given local index | 
| gather | Extract values from the vector referring to the given local indices | 
Modifiers
| Function | Descriptions | 
|---|---|
| insert,set,add | Insert a single value into the matrix (add or overwrite to existing value) | 
| scatter | Insert a block of values into the vector | 
| forEach | Apply a functor to each value at given indices | 
function VectorFacade::VectorFacade
VectorFacade(GlobalBasis const& basis)
Constructor that passes the global basis to the implementation.
function VectorFacade::impl
Impl const& impl() const    // (1)
Impl&       impl()          // (2)
function VectorFacade::localSize,globalSize
std::size_t localSize() const     // (1)
std::size_t globalSize() const    // (2)
function VectorFacade::resize,resizeZero
std::size_t resize() const        // (1)
std::size_t resizeZero() const    // (2)
function VectorFacade::init
void init(bool clear)
Arguments
- bool clear
- If true, sets the vector to zero before insertion
function VectorFacade::finish
void finish()
function VectorFacade::at
template <class Index>
typename Backend::value_type at(Index const& dof) const
Note
Prefer a block operation to retrieve data, like gather().
Arguments
- Index dof
- Any (Multi-)index type. Currently only flat multiindices are supported. This will be relaxed in future versions of the library.
function VectorFacade::gather
// (1)
template <class Node, class Buffer>
void gather(LocalView const& localView, Node const& node, Buffer& buffer) const
// (2)
template <class Buffer>
void gather(LocalView const& localView, Buffer& buffer) const
buffer.resize() and buffer.begin(). The
indices are defined by (1) the nodeIndices(localView, node) or (2) the
nodeIndices(localView).
If the vector is not in synchronized state, collects all necessary values possibly from neighboring processors. Gather can not be called during insertion state. This must be closed using finish() before.
Arguments
- LocalView localView
- The localView object of a global basis
- Node node
- A node in the basis tree
- Buffer buffer
- A resizable output range with resize()andbegin()member functions.
Requirements
- Nodemust be a model of the concept- Dune::Functions::Concept::BasisNode
Preconditions
- expects: localViewis bound to an element
- expects: nodeis inlocalView.tree()
function VectorFacade::insert,set,add
// (1)
template <class Index, class Assign = Assigner::plus_assign>
void insert(Index const& dof, typename Backend::value_type const& value,
            Assign assign = {})
// (2)
template <class Index>
void set(Index const& dof, typename Backend::value_type const& value)
// (3)
template <class Index>
void add(Index const& dof, typename Backend::value_type const& value)
dof (given as dof multi-index)
of a vector. The insertion mode is determined by the assign functor. Use
Assigner::plus_assign for adding values (default) or Assigner::assign
for overwriting (setting) values. Different insertion modes must not be mixed!
Insertion must be closed with a call to finish().
(2) and (3) are abbreviations for the general insert() method (1) by fixing the insertion mode.
Note
Prefer a block operation to insert data, like scatter().
Arguments
- Index dof
- Any (Multi-)index type. Currently only flat multiindices are supported. This will be relaxed in future versions of the library.
- value_type value
- The single value to insert or to add to the container
- Assign assign
- An assignment functor with the signature void operator()(T const& from, S&& to) const
function VectorFacade::scatter
// (1)
template <class Node, class NodeVector, class MaskRange, class Assign>
void scatter(LocalView const& localView, Node const& node, NodeVector const& nodeVec,
             MaskRange const& mask, Assign assign)
// (2)
template <class Node, class NodeVector, class Assign>
void scatter(LocalView const& localView, Node const& node, NodeVector const& nodeVec,
             Assign assign)
// (3)
template <class NodeVector, class Assign>
void scatter(LocalView const& localView, NodeVector const& nodeVec, Assign assign)
localView. The insertion mode is determined
by the assign functor. Use Assigner::plus_assign for adding values
(default) or Assigner::assign for overwriting (setting) values. Different
insertion modes can not be mixed! The nodeVec is assumed to be a continuous
memory container with a data() method to get a pointer to the beginning and must
have the same size as the node.
The mask models a boolean range with at least a begin() method. Must
be forward iterable for at least localVector.size() elements. Does not
need an end() method. See, e.g. FakeContainer.
Insertion must be closed with a call to \ref finish(). It is not allowed to switch insertion mode before calling finish().
(2) Same as (1) but all indices are inserted.
(3) Same as (2) but node == localView.tree()
Arguments
- LocalView localView
- The localView object of a global basis
- Node node
- A node in the basis tree
- NodeVector nodeVec
- Continuous range with a data()method to get a pointer to the beginning
- MaskRange mask
- An boolean forward iterable range with at least a begin()member functions.
Requirements
- Nodemust be a model of the concept- Dune::Functions::Concept::BasisNode
Preconditions
- expects: Vector is either in the same insertion mode as before (no mixing of different insertion modes), or in non-insertion mode.
- expects: localViewis bound to an element
- expects: nodeis inlocalView.tree()
- expects: nodeVecis of sizenode.size()
- expects: maskmust be forward iterable for at leastnodeVec.size()elements
Postconditions
- ensures: Vector is in insertion mode defined by the assignfunctor.