Assembler¶
The purpose of an assembler is to assemble local quantities (local stiffness matrix, local force vector, local energy, etc.) by looping over finite elements and thereby arriving at a global structure. This page describes the available assemblers and how they can be used.
Each of the assemblers is constructed as follows:
basis
is the basis that was used to construct the finite elements. The implementation of the bases involves four different strategies:BlockedLexicographic
,BlockedInterleaved
,FlatLexicographic
andFlatInterleaved
. These strategies are to be considered while creating the assembler. For further information on these strategies, refer to Chapter 10 of DUNE1.fes
is a container that contains all the finite elements that should be assembled.dirichletFlags
is astd::vector<bool>
type. Thei
-th degree of freedom is fixed whendirichletFlags = true
. When a reduced matrix or vector is chosen, the corresponding row and column entries are removed.
Base class for flat assemblers¶
The FlatAssemblerBase is the base class for all assemblers currently available. All other assemblers inherit from this one, i.e., their interface includes the following functions:
size_t size() // (1)!
size_t reducedSize() // (2)!
auto &finiteElements() const // (3)!
Eigen::VectorXd createFullVector(const Eigen::VectorXd &reducedVector) // (4)!
size_t constraintsBelow(size_t i) // (5)!
bool isConstrained(size_t i) // (6)!
size_t estimateOfConnectivity() // (7)!
void bind(const RequirementType& feRequirements, AffordanceCollection<ScalarAffordance, VectorAffordance, MatrixAffordance> affordance) // (8)!
- Returns the number of degrees of freedom.
- Returns the number of degrees of freedom that are not constrained by a Dirichlet boundary condition.
- Returns a reference to the finite element container, which was passed to the assembler.
- Gets a reduced vector and returns a full vector. Entries corresponding to fixed dofs are set to 0. The values of the other entries are obtained from the reduced vector.
- Indicates how many degrees of freedom {0,1,...i-1} are fixed.
- Indicates whether the degree of freedom
i
is fixed. - An estimate for the connectivity. It can be used to allocate vectors.
- The assembler can be bound to specific FE requirements and an affordance collection
Scalar assembler¶
It has the capabilities of (#flatassemblerbase) plus one additional function:
This assembler can be used when only a scalar quantity is of interest and the assembly of matrices or vectors is irrelevant.
The available requirements are explained on the (feRequirements.md).
dirichletFlags
is not used in this assembler.
It assembles the requested scalar quantity. A call to this function could look like this:
ScalarAssembler myAssembler(...) // (1)!
const auto& K = myAssembler.scalar(feRequirements, scalarAffordance) // (2)!
- Represents the construction of the desired assembler.
- To learn more about the available alternatives to
energy
and how this works, read the (feRequirements.md) page.
Flat vector assembler¶
It has all the features of (#scalarassembler) plus more, like:
Eigen::VectorXd& vector(const FERequirementType& feRequirements, VectorAffordance affordance, DBCOption dbcOption)
Eigen::VectorXd& vector( DBCOption dbcOption)
The Enum DBCOption
dictates how the Dirichlet boundary conditions should be applied
The DBCOption::Raw
returns a vector without considering the boundary conditions.
The DBCOption::Full
option returns a full vector, where zeros are written for the fixed degrees of freedom and DBCOption::Reduced
returns reduced vector removing the fixed degrees of freedom.
The second function can be used if the assembler is bound to specific fe requirements and affordances.
They work in the same way as the scalar assembly functions of (#scalarassembler).
The available FE requirements are explained on the (feRequirements.md) page.
Flat sparse assembler¶
It offers the functions of (#vectorflatassembler) plus more, like:
Eigen::SparseMatrix<double>& matrix(const FERequirementType& feRequirements, MatrixAffordance affordance, DBCOption dbcOption)
Eigen::SparseMatrix<double>& matrix(DBCOption dbcOption)
A sparse matrix is returned.
The Enum DBCOption
dictates how the Dirichlet boundary conditions should be applied
The DBCOption::Raw
returns a matrix without considering the boundary conditions.
The DBCOption::Full
option returns a full matrx, where zeros are written on the rows and columns associated to fixed degrees of
freedom and a one is written on the diagonal.
DBCOption::Reduced
returns reduced matrix removing the rows and columns associated to fixed degrees of freedom.
The second function can be used if the assembler is bound to specific fe requirements and affordances.
They work in the same way as the vector assembly functions of (#vectorflatassembler).
The available FE requirements are explained on the (feRequirements.md) page.
Flat dense assembler¶
The only difference between the (#sparseflatassembler) and the DenseFlatAssembler is that the DenseFlatAssembler returns a dense matrix.
Eigen::MatrixXd& matrix(const FERequirementType& feRequirements, MatrixAffordance affordance, DBCOption dbcOption)
Eigen::MatrixXd& matrix(DBCOption dbcOption)
-
Oliver Sander. DUNEāThe Distributed and Unified Numerics Environment. Volume 140. Springer Nature, 2020. doi:10.1007/978-3-030-59702-3. ↩