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>
23template <
unsigned int dim,
unsigned int degree>
35 DoFManager(
const std::vector<FieldAttributes> &field_attributes,
57 init(
unsigned int num_levels);
72 reinit_mapping(
const std::vector<FieldAttributes> &field_attributes);
78 [[nodiscard]]
const std::vector<std::vector<const dealii::DoFHandler<dim> *>> &
85 [[nodiscard]]
const std::vector<const dealii::DoFHandler<dim> *> &
92 [[nodiscard]]
const dealii::DoFHandler<dim> &
98 [[nodiscard]]
const std::vector<std::array<dealii::DoFHandler<dim>, 2>> &
104 [[nodiscard]]
const std::array<dealii::DoFHandler<dim>, 2> &
110 [[nodiscard]]
const dealii::DoFHandler<dim> &
111 get_dof_handler(
const unsigned int &rank,
unsigned int relative_level = 0)
const;
117 [[nodiscard]] dealii::types::global_dof_index
133PRISMS_PF_END_NAMESPACE
DoFManager operator=(const DoFManager &)=delete
DoFManager(const DoFManager &)=delete
Disable copying.
std::vector< std::vector< const dealii::DoFHandler< dim > * > > field_dof_handlers
Pointers to the dof handlers for each field on every mg level. Outer vector is indexed by relative mg...
Definition dof_manager.h:125
dealii::types::global_dof_index get_total_dofs() const
Get the total DoFs excluding multigrid DoFs.
Definition dof_manager.cc:115
DoFManager(const DoFManager &&)=delete
~DoFManager()=default
Destructor.
DoFManager & operator=(DoFManager &&other)=delete
const std::vector< std::vector< const dealii::DoFHandler< dim > * > > & get_field_dof_handlers_levels() const
Getter function for all the DoFHandlers.
Definition dof_manager.cc:71
const std::vector< std::array< dealii::DoFHandler< dim >, 2 > > & get_dof_handlers_levels() const
Getter function for the scalar and vector DoFHandlers.
Definition dof_manager.cc:93
void init(unsigned int num_levels)
Resize the DoFHandlers set.
Definition dof_manager.cc:25
DoFManager()=default
Constructor.
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.cc:107
const std::array< dealii::DoFHandler< dim >, 2 > & get_dof_handlers(unsigned int relative_level=0) const
Getter function for the scalar and vector DoFHandlers on a level.
Definition dof_manager.cc:100
void reinit(const TriangulationManager< dim > &triangulation_manager)
Reinitialize the DoFHandlers.
Definition dof_manager.cc:33
const std::vector< const dealii::DoFHandler< dim > * > & get_field_dof_handlers(unsigned int relative_level=0) const
Getter function for all the DoFHandlers on a level.
Definition dof_manager.cc:78
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.cc:85
void reinit_mapping(const std::vector< FieldAttributes > &field_attributes)
Reinitialize the DoFHandlers.
Definition dof_manager.cc:51
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:130
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