6#include <deal.II/base/mg_level_object.h>
7#include <deal.II/dofs/dof_handler.h>
8#include <deal.II/fe/mapping.h>
9#include <deal.II/lac/affine_constraints.h>
20#include <prismspf/config.h>
25template <
unsigned int dim,
unsigned int degree,
typename number>
48template <
unsigned int dim,
unsigned int degree,
typename number>
64 [[nodiscard]]
const std::vector<std::vector<dealii::AffineConstraints<number>>> &
70 [[nodiscard]] std::vector<const dealii::AffineConstraints<number> *>
76 [[nodiscard]]
const dealii::AffineConstraints<number> &
82 [[nodiscard]]
const std::vector<std::array<dealii::AffineConstraints<number>, 2>> &
88 [[nodiscard]]
const std::array<dealii::AffineConstraints<number>, 2> &
94 [[nodiscard]]
const dealii::AffineConstraints<number> &
101 reinit(
const std::vector<FieldAttributes> &field_attributes);
122 const dealii::DoFHandler<dim> &dof_handler,
132 const dealii::DoFHandler<dim> &dof_handler,
142 unsigned int boundary_id,
143 unsigned int component,
145 const dealii::DoFHandler<dim> &dof_handler,
160 const dealii::DoFHandler<dim> &dof_handler,
161 const unsigned int &boundary_id,
162 const unsigned int &field_index,
163 const bool &is_vector_field,
164 const dealii::ComponentMask &mask)
const;
172 const dealii::DoFHandler<dim> &dof_handler,
173 const unsigned int &boundary_id,
174 const dealii::ComponentMask &mask)
const;
208PRISMS_PF_END_NAMESPACE
const dealii::AffineConstraints< number > & get_generic_constraint(unsigned int rank, unsigned int relative_level=0) const
Getter function for the constraint of an index (constant reference).
Definition constraint_manager.cc:103
void update_time_dependent_constraints(const std::vector< FieldAttributes > &field_attributes)
Update time-dependent constraints. For now this only updates the Dirichlet constraints.
Definition constraint_manager.cc:315
const PDEOperatorBase< dim, degree, number > * pde_operator
PDE operator.
Definition constraint_manager.h:194
const std::array< dealii::AffineConstraints< number >, 2 > & get_generic_constraints(unsigned int relative_level=0) const
Getter function for the constraints.
Definition constraint_manager.cc:95
const BoundaryParameters< dim > * boundary_parameters
User-inputs constraint parameters.
Definition constraint_manager.h:179
std::vector< std::array< dealii::AffineConstraints< number >, 2 > > generic_constraints
Constraints not specific to any field. We need this for invm.
Definition constraint_manager.h:205
std::vector< const dealii::AffineConstraints< number > * > get_field_constraints(unsigned int relative_level=0) const
Getter function for the constraints.
Definition constraint_manager.cc:66
void make_periodic_constraints(dealii::AffineConstraints< number > &_constraints, const dealii::DoFHandler< dim > &dof_handler, const unsigned int &boundary_id, const dealii::ComponentMask &mask) const
make periodic constraints.
Definition constraint_manager.cc:393
void make_dirichlet_constraints(dealii::AffineConstraints< number > &_constraints, const dealii::DoFHandler< dim > &dof_handler, const unsigned int &boundary_id, const unsigned int &field_index, const bool &is_vector_field, const dealii::ComponentMask &mask) const
Make dirichlet constraints.
Definition constraint_manager.cc:371
void make_one_boundary_constraint(dealii::AffineConstraints< number > &_constraints, unsigned int boundary_id, unsigned int component, Condition boundary_type, const dealii::DoFHandler< dim > &dof_handler, TensorRank tensor_rank, Types::Index field_index) const
Apply constraints for common boundary conditions.
Definition constraint_manager.cc:252
const dealii::AffineConstraints< number > & get_constraint(Types::Index index, unsigned int relative_level=0) const
Getter function for the constraint of an index (constant reference).
Definition constraint_manager.cc:80
void make_bc_constraints(dealii::AffineConstraints< number > &constraint, const dealii::DoFHandler< dim > &dof_handler, const FieldConstraints< dim > &boundary_condition, TensorRank tensor_rank, Types::Index field_index)
Add boundary conditions to a single constraint.
Definition constraint_manager.cc:226
const std::vector< std::vector< dealii::AffineConstraints< number > > > & get_field_constraints_levels() const
Getter function for a selection of the constraints.
Definition constraint_manager.cc:59
const SpatialDiscretization< dim > * spatial_discretization
User-inputs discretization.
Definition constraint_manager.h:184
void reinit(const std::vector< FieldAttributes > &field_attributes)
Make constraints based on the inputs of the constructor.
Definition constraint_manager.cc:112
void make_natural_constraints() const
Apply natural constraints.
Definition constraint_manager.cc:364
static const dealii::ComponentMask scalar_empty_mask
Definition constraint_manager.h:115
void make_constraints_for_single_field(dealii::AffineConstraints< number > &constraint, const dealii::DoFHandler< dim > &dof_handler, const FieldConstraints< dim > &_field_constraints, TensorRank tensor_rank, Types::Index field_index)
Construct constraints for a single field based on the boundary conditions.
Definition constraint_manager.cc:184
static const std::array< dealii::ComponentMask, dim > vector_component_mask
Create a component mask.
Definition constraint_manager.h:114
const std::vector< std::array< dealii::AffineConstraints< number >, 2 > > & get_generic_constraints_levels() const
Getter function for the constraints.
Definition constraint_manager.cc:88
const DoFManager< dim, degree > * dof_manager
Dof manager pointer.
Definition constraint_manager.h:189
std::vector< std::vector< dealii::AffineConstraints< number > > > field_constraints
Constraints. Outer vector is indexed by field index. Inner vector is indexed by relative mg level.
Definition constraint_manager.h:200
ConstraintManager(const std::vector< FieldAttributes > &field_attributes, const BoundaryParameters< dim > &_boundary_parameters, const SpatialDiscretization< dim > &_spatial_discretization, const DoFManager< dim, degree > &_dof_manager, const PDEOperatorBase< dim, degree, number > &_pde_operator)
Constructor.
Definition constraint_manager.cc:33
Class that manages the deal.II DoFHandlers.
Definition dof_manager.h:25
This class contains the user implementation of each PDE operator.
Definition pde_operator_base.h:27
Condition
Condition of boundary condition.
Definition constraint_parameters.h:33
Definition conditional_ostreams.cc:20
unsigned int Index
Type for field indices.
Definition types.h:19
Struct that holds boundary parameters.
Definition constraint_parameters.h:162
Definition constraint_parameters.h:142
Struct that holds spatial discretization parameters.
Definition spatial_discretization.h:231
TensorRank
Tensor rank of the field.
Definition type_enums.h:52