PRISMS-PF Manual
Loading...
Searching...
No Matches
constraint_manager.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: © 2025 PRISMS Center at the University of Michigan
2// SPDX-License-Identifier: GNU Lesser General Public Version 2.1
3
4#pragma once
5
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>
10
15#include <prismspf/core/types.h>
16
19
20#include <prismspf/config.h>
21
23
24// Forward declaration to avoid circular dependency.
25template <unsigned int dim, unsigned int degree, typename number>
26class PDEOperatorBase;
27
28// TODO (fractalsbyx): The following snippet is from dealii. Using this (by
29// pre-constructing the needed maps and functions) may be cleaner than how dirichlet are
30// currently done.
31/* template <int dim, int spacedim, typename number>
32 void
33 interpolate_boundary_values(
34 const Mapping<dim, spacedim> &mapping,
35 const DoFHandler<dim, spacedim> &dof,
36 const std::map<types::boundary_id, const Function<spacedim, number> *>
37 &function_map,
38 AffineConstraints<number> &constraints,
39 const ComponentMask &component_mask = {}); */
40
41// TODO (fractalsbyx): I don't think we actually need 'change' constraints for newton
42// solves at all. Verify this and remove them.
43
48template <unsigned int dim, unsigned int degree, typename number>
50{
51public:
55 ConstraintManager(const std::vector<FieldAttributes> &field_attributes,
56 const BoundaryParameters<dim> &_boundary_parameters,
57 const SpatialDiscretization<dim> &_spatial_discretization,
58 const DoFManager<dim, degree> &_dof_manager,
59 const PDEOperatorBase<dim, degree, number> &_pde_operator);
60
64 [[nodiscard]] const std::vector<std::vector<dealii::AffineConstraints<number>>> &
66
70 [[nodiscard]] std::vector<const dealii::AffineConstraints<number> *>
71 get_field_constraints(unsigned int relative_level = 0) const;
72
76 [[nodiscard]] const dealii::AffineConstraints<number> &
77 get_constraint(Types::Index index, unsigned int relative_level = 0) const;
78
82 [[nodiscard]] const std::vector<std::array<dealii::AffineConstraints<number>, 2>> &
84
88 [[nodiscard]] const std::array<dealii::AffineConstraints<number>, 2> &
89 get_generic_constraints(unsigned int relative_level = 0) const;
90
94 [[nodiscard]] const dealii::AffineConstraints<number> &
95 get_generic_constraint(unsigned int rank, unsigned int relative_level = 0) const;
96
100 void
101 reinit(const std::vector<FieldAttributes> &field_attributes);
102
107 void
108 update_time_dependent_constraints(const std::vector<FieldAttributes> &field_attributes);
109
110private:
114 static const std::array<dealii::ComponentMask, dim> vector_component_mask;
115 static const dealii::ComponentMask scalar_empty_mask;
116
120 void
121 make_constraints_for_single_field(dealii::AffineConstraints<number> &constraint,
122 const dealii::DoFHandler<dim> &dof_handler,
123 const FieldConstraints<dim> &_field_constraints,
124 TensorRank tensor_rank,
125 Types::Index field_index);
126
130 void
131 make_bc_constraints(dealii::AffineConstraints<number> &constraint,
132 const dealii::DoFHandler<dim> &dof_handler,
133 const FieldConstraints<dim> &boundary_condition,
134 TensorRank tensor_rank,
135 Types::Index field_index);
136
140 void
141 make_one_boundary_constraint(dealii::AffineConstraints<number> &_constraints,
142 unsigned int boundary_id,
143 unsigned int component,
144 Condition boundary_type,
145 const dealii::DoFHandler<dim> &dof_handler,
146 TensorRank tensor_rank,
147 Types::Index field_index) const;
148
152 void
154
158 void
159 make_dirichlet_constraints(dealii::AffineConstraints<number> &_constraints,
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;
165
170 void
171 make_periodic_constraints(dealii::AffineConstraints<number> &_constraints,
172 const dealii::DoFHandler<dim> &dof_handler,
173 const unsigned int &boundary_id,
174 const dealii::ComponentMask &mask) const;
175
180
185
190
195
200 std::vector<std::vector<dealii::AffineConstraints<number>>> field_constraints;
201
205 std::vector<std::array<dealii::AffineConstraints<number>, 2>> generic_constraints;
206};
207
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