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]] std::vector<const dealii::AffineConstraints<number> *>
66 unsigned int relative_level = 0)
const;
71 [[nodiscard]]
const dealii::AffineConstraints<number> &
77 [[nodiscard]]
const std::vector<std::array<dealii::AffineConstraints<number>, 2>> &
83 [[nodiscard]]
const dealii::AffineConstraints<number> &
90 reinit(
const std::vector<FieldAttributes> &field_attributes);
111 const dealii::DoFHandler<dim> &dof_handler,
121 const dealii::DoFHandler<dim> &dof_handler,
131 unsigned int boundary_id,
132 unsigned int component,
134 const dealii::DoFHandler<dim> &dof_handler,
149 const dealii::DoFHandler<dim> &dof_handler,
150 const unsigned int &boundary_id,
151 const unsigned int &field_index,
152 const bool &is_vector_field,
153 const dealii::ComponentMask &mask)
const;
161 const dealii::DoFHandler<dim> &dof_handler,
162 const unsigned int &boundary_id,
163 const dealii::ComponentMask &mask)
const;
170 const dealii::Point<dim> &target_point,
171 const std::array<number, dim> &value,
172 const dealii::DoFHandler<dim> &dof_handler,
199 std::vector<std::vector<dealii::AffineConstraints<number>>>
constraints;
207PRISMS_PF_END_NAMESPACE
The class handles the generation and application of boundary conditions based on the user-inputs.
Definition constraint_manager.h:50
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:89
void update_time_dependent_constraints(const std::vector< FieldAttributes > &field_attributes)
Update time-dependent constraints. For now this only updates the non-uniform dirichlet constraints.
Definition constraint_manager.cc:299
const PDEOperatorBase< dim, degree, number > * pde_operator
PDE operator.
Definition constraint_manager.h:193
std::vector< std::vector< dealii::AffineConstraints< number > > > constraints
Constraints. Outer vector is indexed by field index. Inner vector is indexed by relative mg level.
Definition constraint_manager.h:199
const BoundaryParameters< dim > * boundary_parameters
User-inputs constraint parameters.
Definition constraint_manager.h:178
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:204
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:381
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:359
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:236
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:74
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:210
const SpatialDiscretization< dim > * spatial_discretization
User-inputs discretization.
Definition constraint_manager.h:183
void reinit(const std::vector< FieldAttributes > &field_attributes)
Make constraints based on the inputs of the constructor.
Definition constraint_manager.cc:98
std::vector< const dealii::AffineConstraints< number > * > get_constraints(const std::set< unsigned int > &field_indices, unsigned int relative_level=0) const
Getter function for the constraints.
Definition constraint_manager.cc:59
void make_natural_constraints() const
Apply natural constraints.
Definition constraint_manager.cc:352
static const dealii::ComponentMask scalar_empty_mask
Definition constraint_manager.h:104
const std::vector< std::array< dealii::AffineConstraints< number >, 2 > > & get_generic_constraints() const
Getter function for the constraints.
Definition constraint_manager.cc:82
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:168
void set_pinned_point(dealii::AffineConstraints< number > &constraint, const dealii::Point< dim > &target_point, const std::array< number, dim > &value, const dealii::DoFHandler< dim > &dof_handler, TensorRank tensor_rank) const
Set the dirichlet constraint for the pinned point.
Definition constraint_manager.cc:411
const DoFManager< dim, degree > * dof_manager
Dof manager pointer.
Definition constraint_manager.h:188
static const std::array< dealii::ComponentMask, dim > vector_component_mask
Create a component mask.
Definition constraint_manager.h:103
Class that manages the deal.II DoFHandlers.
Definition dof_manager.h:27
This class contains the user implementation of each PDE operator.
Definition pde_operator_base.h:24
Condition
Condition of boundary condition.
Definition constraint_parameters.h:32
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:164
Definition constraint_parameters.h:141
Struct that holds spatial discretization parameters.
Definition spatial_discretization.h:230
TensorRank
Tensor rank of the field.
Definition type_enums.h:30