6#include <deal.II/base/mg_level_object.h>
7#include <deal.II/dofs/dof_handler.h>
8#include <deal.II/fe/fe_system.h>
16#include <prismspf/config.h>
25template <
unsigned int dim,
unsigned int degree>
32 explicit DoFManager(
const std::vector<FieldAttributes> &field_attributes);
37 DoFManager(
const std::vector<FieldAttributes> &field_attributes,
55 [[nodiscard]] std::vector<const dealii::DoFHandler<dim> *>
57 unsigned int relative_level = 0)
const;
62 [[nodiscard]]
const dealii::DoFHandler<dim> &
71 const std::vector<std::array<dealii::DoFHandler<dim>, 2>> &
80 [[nodiscard]]
const dealii::DoFHandler<dim> &
89 [[nodiscard]] dealii::types::global_dof_index
92 dealii::types::global_dof_index n_dofs = 0;
95 n_dofs += dof_handler_set[0]->n_dofs();
109 std::vector<std::vector<const dealii::DoFHandler<dim> *>>
dof_handlers;
117PRISMS_PF_END_NAMESPACE
Class that manages the deal.II DoFHandlers.
Definition dof_manager.h:27
void init(const TriangulationManager< dim > &triangulation_handler)
Initialize the DoFHandlers.
Definition dof_manager.cc:43
dealii::types::global_dof_index get_total_dofs() const
Get the total DoFs excluding multigrid DoFs.
Definition dof_manager.h:90
std::vector< const dealii::DoFHandler< dim > * > get_field_dof_handlers(const std::set< unsigned int > &field_indices, unsigned int relative_level=0) const
Getter function for the DoFHandlers (constant reference).
Definition dof_manager.cc:66
std::vector< std::vector< const dealii::DoFHandler< dim > * > > dof_handlers
Collection of the triangulation DoFs. The number of DoFHandlers should be equal to or less than the n...
Definition dof_manager.h:109
const dealii::DoFHandler< dim > & get_dof_handler(const unsigned int &rank, unsigned int relative_level=0) const
Getter function for a specific scalar or vector DoFHandler.
Definition dof_manager.h:81
void reinit(const TriangulationManager< dim > &triangulation_handler)
Reinitialize the DoFHandlers.
Definition dof_manager.cc:59
const dealii::DoFHandler< dim > & get_field_dof_handler(Types::Index field_index, unsigned int relative_level=0) const
Getter function for the DoFHandler (reference).
Definition dof_manager.h:63
const std::vector< std::array< dealii::DoFHandler< dim >, 2 > > & get_dof_handlers() const
Getter function for the scalar and vector DoFHandlers.
Definition dof_manager.h:72
std::vector< std::array< dealii::DoFHandler< dim >, 2 > > level_dof_handlers
A scalar and a vector dof handler for each level.
Definition dof_manager.h:114
This class handlers the generation and manipulation of triangulations.
Definition triangulation_manager.h:26
Definition conditional_ostreams.cc:20
unsigned int Index
Type for field indices.
Definition types.h:19