37 std::vector<unsigned int>
38 build_multiplicities(
const std::vector<std::vector<T>> &
functions)
40 std::vector<unsigned int> multiplicities;
41 multiplicities.push_back(1);
42 for (
unsigned int i = 0; i <
functions.size(); i++)
43 multiplicities.push_back(
functions[i].size());
45 return multiplicities;
52 template <
int dim,
int spacedim>
53 std::vector<const FiniteElement<dim, spacedim> *>
58 std::vector<const FiniteElement<dim, spacedim> *> fes;
59 fes.push_back(fe_base);
60 for (
unsigned int i = 0; i < fe_enriched.size(); i++)
61 fes.push_back(fe_enriched[i]);
71 template <
int dim,
int spacedim>
75 const std::vector<unsigned int> & multiplicities,
77 const typename ::Triangulation<dim, spacedim>::cell_iterator
83 "FEs and multiplicities should have the same size"));
91 const unsigned int n_comp_base = fes[0]->n_components();
94 for (
unsigned int fe = 1; fe < fes.size(); fe++)
102 "Only dominating FE_Nothing can be used in FE_Enriched"));
107 "All elements must have the same number of components"));
117 template <
int dim,
int spacedim>
123 for (
unsigned int fe = 1; fe < fes.size(); fe++)
135 template <
int dim,
int spacedim>
145 template <
int dim,
int spacedim>
154 const typename
Triangulation<dim, spacedim>::cell_iterator &)>>>(
157 const typename
Triangulation<dim, spacedim>::cell_iterator &)>>(
159 [=](const typename
Triangulation<dim, spacedim>::cell_iterator &)
160 -> const
Function<spacedim> * {
return enrichment_function; })))
164 template <
int dim,
int spacedim>
177 template <
int dim,
int spacedim>
180 const std::vector<unsigned int> & multiplicities,
197 Assert(internal::FE_Enriched::consistency_check(fes,
207 for (
unsigned int fe = 1; fe < fes.size(); fe++)
215 for (
unsigned int system_index = 0; system_index < this->
dofs_per_cell;
218 const unsigned int base_no =
223 const unsigned int base_m =
228 "Size mismatch for base_no_mult_local_enriched_dofs: " 244 for (
unsigned int base_no = 1;
248 for (
unsigned int m = 0;
252 fes[base_no]->dofs_per_cell,
255 fes[base_no]->dofs_per_cell));
260 template <
int dim,
int spacedim>
261 const std::vector<std::vector<std::function<const Function<spacedim> *(
269 template <
int dim,
int spacedim>
277 "For enriched finite elements shape_value() can not be defined on the reference element."));
282 template <
int dim,
int spacedim>
283 std::unique_ptr<FiniteElement<dim, spacedim>>
286 std::vector<const FiniteElement<dim, spacedim> *> fes;
287 std::vector<unsigned int> multiplicities;
295 return std::unique_ptr<FE_Enriched<dim, spacedim>>(
300 template <
int dim,
int spacedim>
323 template <
int dim,
int spacedim>
325 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
333 auto update_each_flags = fes_data->update_each;
334 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
335 data_ptr = std_cxx14::make_unique<InternalData>(std::move(fes_data));
344 const unsigned int n_q_points = quadrature.
size();
352 data.enrichment[base][m].values.resize(n_q_points);
355 data.enrichment[base][m].gradients.resize(n_q_points);
358 data.enrichment[base][m].hessians.resize(n_q_points);
366 template <
int dim,
int spacedim>
367 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
376 fe_system->get_face_data(update_flags, mapping, quadrature, output_data);
385 template <
int dim,
int spacedim>
386 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
396 fe_system->get_subface_data(update_flags, mapping, quadrature, output_data);
405 template <
int dim,
int spacedim>
406 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
414 auto data =
fe_system->get_data(flags, mapping, quadrature, output_data);
423 template <
int dim,
int spacedim>
427 const std::vector<unsigned int> & multiplicities)
429 Assert(fes.size() == multiplicities.size(),
436 for (
unsigned int i = 0; i < fes.size(); i++)
437 if (multiplicities[i] > 0)
479 fe_system->adjust_line_dof_index_for_line_orientation_table;
484 template <
int dim,
int spacedim>
488 std::ostringstream namebuf;
501 return namebuf.str();
505 template <
int dim,
int spacedim>
513 template <
int dim,
int spacedim>
521 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
528 Assert(dynamic_cast<const InternalData *>(&fe_internal) !=
nullptr,
544 quadrature, fe_data, mapping_data, cell, output_data);
548 template <
int dim,
int spacedim>
552 const unsigned int face_no,
556 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
563 Assert(dynamic_cast<const InternalData *>(&fe_internal) !=
nullptr,
579 quadrature, fe_data, mapping_data, cell, output_data);
583 template <
int dim,
int spacedim>
587 const unsigned int face_no,
588 const unsigned int sub_no,
592 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
599 Assert(dynamic_cast<const InternalData *>(&fe_internal) !=
nullptr,
616 quadrature, fe_data, mapping_data, cell, output_data);
620 template <
int dim,
int spacedim>
642 const unsigned int n_q_points = quadrature.
size();
652 for (
unsigned int base_no = 1; base_no < this->
n_base_elements(); base_no++)
663 for (
unsigned int system_index = 0; system_index < this->
dofs_per_cell;
667 const unsigned int base_index =
677 unsigned int out_index = 0;
678 for (
unsigned int i = 0; i < system_index; ++i)
680 unsigned int in_index = 0;
681 for (
unsigned int i = 0; i < base_index; ++i)
688 for (
unsigned int s = 0;
693 for (
unsigned int q = 0; q < n_q_points; ++q)
695 base_data.shape_values(in_index + s, q);
698 for (
unsigned int q = 0; q < n_q_points; ++q)
700 base_data.shape_gradients[in_index + s][q];
703 for (
unsigned int q = 0; q < n_q_points; ++q)
705 base_data.shape_hessians[in_index + s][q];
714 for (
unsigned int base_no = 1; base_no < this->
n_base_elements(); base_no++)
721 for (
unsigned int m = 0;
733 "The pointer to the enrichment function is not set"));
737 "Only scalar-valued enrichment functions are allowed"));
744 fe_data.
enrichment[base_no][m].hessians.size(),
746 for (
unsigned int q = 0; q < n_q_points; q++)
757 fe_data.
enrichment[base_no][m].gradients.size(),
759 for (
unsigned int q = 0; q < n_q_points; q++)
771 for (
unsigned int q = 0; q < n_q_points; q++)
790 for (
unsigned int m = 0;
793 for (
unsigned int i = 0;
797 const unsigned int enriched_dof =
799 for (
unsigned int q = 0; q < n_q_points; ++q)
819 for (
unsigned int base_no = 1; base_no < this->
n_base_elements(); base_no++)
821 for (
unsigned int m = 0;
824 for (
unsigned int i = 0;
828 const unsigned int enriched_dof =
830 for (
unsigned int q = 0; q < n_q_points; ++q)
842 for (
unsigned int base_no = 1; base_no < this->
n_base_elements(); base_no++)
844 for (
unsigned int m = 0;
847 for (
unsigned int i = 0;
851 const unsigned int enriched_dof =
853 for (
unsigned int q = 0; q < n_q_points; ++q)
863 template <
int dim,
int spacedim>
871 template <
int dim,
int spacedim>
879 template <
int dim,
int spacedim>
888 fe_system->get_face_interpolation_matrix(fe_enr_other->get_fe_system(),
901 template <
int dim,
int spacedim>
905 const unsigned int subface,
911 fe_system->get_subface_interpolation_matrix(fe_enr_other->get_fe_system(),
925 template <
int dim,
int spacedim>
926 std::vector<std::pair<unsigned int, unsigned int>>
933 return fe_system->hp_vertex_dof_identities(fe_enr_other->get_fe_system());
938 return std::vector<std::pair<unsigned int, unsigned int>>();
943 template <
int dim,
int spacedim>
944 std::vector<std::pair<unsigned int, unsigned int>>
951 return fe_system->hp_line_dof_identities(fe_enr_other->get_fe_system());
956 return std::vector<std::pair<unsigned int, unsigned int>>();
961 template <
int dim,
int spacedim>
962 std::vector<std::pair<unsigned int, unsigned int>>
969 return fe_system->hp_quad_dof_identities(fe_enr_other->get_fe_system());
974 return std::vector<std::pair<unsigned int, unsigned int>>();
979 template <
int dim,
int spacedim>
983 const unsigned int codim)
const 1002 return fe_system->compare_for_domination(fe_enr_other->get_fe_system(),
1013 template <
int dim,
int spacedim>
1016 const unsigned int child,
1019 return fe_system->get_prolongation_matrix(child, refinement_case);
1023 template <
int dim,
int spacedim>
1026 const unsigned int child,
1029 return fe_system->get_restriction_matrix(child, refinement_case);
1036 template <
int dim,
int spacedim>
1039 : fesystem_data(
std::move(fesystem_data))
1043 template <
int dim,
int spacedim>
1046 const unsigned int base_no)
const 1052 template <
int dim,
int spacedim>
1055 const unsigned int base_no)
const 1065 template <
int dim,
int spacedim>
1073 std::vector<bool> vertices_subdomain_1(
1078 if (predicate_1(cell))
1080 vertices_subdomain_1[cell->vertex_index(v)] =
true;
1084 if (predicate_2(cell))
1086 if (vertices_subdomain_1[cell->vertex_index(v)] ==
true)
1095 template <
int dim,
int spacedim>
1100 std::vector<unsigned int> & predicate_colors)
1102 const unsigned int num_indices = predicates.size();
1107 dsp.
reinit(num_indices, num_indices);
1114 for (
unsigned int i = 0; i < num_indices; ++i)
1115 for (
unsigned int j = i + 1; j < num_indices; ++j)
1127 predicate_colors.resize(num_indices);
1135 template <
int dim,
int spacedim>
1140 const std::vector<unsigned int> & predicate_colors,
1141 std::map<
unsigned int, std::map<unsigned int, unsigned int>>
1142 & cellwise_color_predicate_map,
1143 std::vector<std::set<unsigned int>> &fe_sets)
1147 cellwise_color_predicate_map.clear();
1175 unsigned int map_index = 0;
1179 cell->set_active_fe_index(0);
1188 cell->set_material_id(map_index);
1189 std::set<unsigned int> color_list;
1197 std::map<unsigned int, unsigned int> &cell_map =
1198 cellwise_color_predicate_map[map_index];
1199 for (
unsigned int i = 0; i < predicates.size(); ++i)
1201 if (predicates[i](cell))
1207 auto ret = cell_map.insert(
1208 std::pair<unsigned int, unsigned int>(predicate_colors[i],
1213 "Only one enrichment function per color"));
1215 color_list.insert(predicate_colors[i]);
1232 if (!color_list.empty())
1235 std::find(fe_sets.begin(), fe_sets.end(), color_list);
1237 if (it == fe_sets.end())
1239 fe_sets.push_back(color_list);
1240 cell->set_active_fe_index(fe_sets.size() - 1);
1245 cell->set_active_fe_index(std::distance(fe_sets.begin(), it));
1292 const unsigned int fe_index = cell->active_fe_index();
1293 const std::set<unsigned int> fe_set = fe_sets.at(fe_index);
1300 if (!cell->at_boundary(face) &&
1301 cell->material_id() < cell->neighbor(face)->material_id())
1303 const auto nbr_fe_index =
1304 cell->neighbor(face)->active_fe_index();
1307 const auto nbr_fe_set = fe_sets.at(nbr_fe_index);
1310 std::set<unsigned int> intersection_set;
1311 std::set_intersection(
1316 std::inserter(intersection_set, intersection_set.begin()));
1319 if (!intersection_set.empty())
1321 const auto it = std::find(fe_sets.begin(),
1325 if (it == fe_sets.end())
1327 fe_sets.push_back(intersection_set);
1337 template <
int dim,
int spacedim>
1340 const unsigned int n_colors,
1342 const std::map<
unsigned int, std::map<unsigned int, unsigned int>>
1343 &cellwise_color_predicate_map,
1348 color_enrichments.clear();
1364 color_enrichments.resize(n_colors);
1365 for (
unsigned int i = 0; i < n_colors; ++i)
1367 color_enrichments[i] =
1370 const unsigned int id = cell->material_id();
1377 return enrichments[cellwise_color_predicate_map.at(
id).at(i + 1)]
1385 template <
int dim,
int spacedim>
1388 const unsigned int n_colors,
1389 const std::vector<std::set<unsigned int>> &fe_sets,
1392 & color_enrichments,
1399 const std::function<const Function<spacedim> *(
1405 ExcMessage(
"Called enrichment function for FE_Nothing"));
1413 for (
const auto &fe_set : fe_sets)
1415 std::vector<const FiniteElement<dim, spacedim> *> vec_fe_enriched(
1416 n_colors, &fe_nothing);
1417 std::vector<std::vector<std::function<const Function<spacedim> *(
1421 for (
const unsigned int color_id : fe_set)
1426 const unsigned int ind = color_id - 1;
1436 vec_fe_enriched[ind] = &fe_enriched;
1440 functions[ind][0] = color_enrichments[ind];
1455 template <
int dim,
int spacedim>
1462 , fe_enriched(fe_enriched)
1464 , predicates(predicates)
1471 ExcMessage(
"Number of predicates should be positive"));
1476 template <
int dim,
int spacedim>
1494 internal::make_colorwise_enrichment_functions<dim, spacedim>(
1512 #include "fe_enriched.inst" virtual FiniteElementDomination::Domination compare_for_domination(const FiniteElement< dim, spacedim > &fe_other, const unsigned int codim=0) const override final
bool is_dominating() const
static const unsigned int invalid_unsigned_int
virtual const FiniteElement< dim, spacedim > & base_element(const unsigned int index) const override
#define AssertDimension(dim1, dim2)
const std::vector< std::vector< std::function< const Function< spacedim > *(const typename Triangulation< dim, spacedim >::cell_iterator &)> > > get_enrichments() const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
FullMatrix< double > interface_constraints
Contents is actually a matrix.
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
InternalData(std::unique_ptr< typename FESystem< dim, spacedim >::InternalData > fesystem_data)
unsigned int n_nonzero_components(const unsigned int i) const
constexpr SymmetricTensor< 2, dim, Number > symmetrize(const Tensor< 2, dim, Number > &t)
FE_Enriched(const FiniteElement< dim, spacedim > &fe_base, const FiniteElement< dim, spacedim > &fe_enriched, const Function< spacedim > *enrichment_function)
void initialize(const std::vector< const FiniteElement< dim, spacedim > *> &fes, const std::vector< unsigned int > &multiplicities)
const FiniteElement< dim, spacedim > & fe_enriched
void add(const size_type i, const size_type j)
internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > & get_fe_output_object(const unsigned int base_no) const
#define AssertIndexRange(index, range)
const hp::FECollection< dim, spacedim > & build_fe_collection(hp::DoFHandler< dim, spacedim > &dof_handler)
std::vector< std::pair< std::pair< unsigned int, unsigned int >, unsigned int > > component_to_base_table
std::vector< std::vector< EnrichmentValues > > enrichment
std::function< bool(const typename Triangulation< dim, spacedim >::cell_iterator &)> predicate_function
std::vector< Point< dim - 1 > > unit_face_support_points
Transformed quadrature points.
#define AssertThrow(cond, exc)
hp::FECollection< dim, spacedim > fe_collection
static ::ExceptionBase & ExcInterpolationNotImplemented()
void multiply_by_enrichment(const Quadrature< dim_1 > &quadrature, const InternalData &fe_data, const internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &mapping_data, const typename Triangulation< dim, spacedim >::cell_iterator &cell, internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const
std::unique_ptr< To > dynamic_unique_cast(std::unique_ptr< From > &&p)
std::vector< Point< dim > > unit_support_points
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::string get_name() const override
constexpr SymmetricTensor< 4, dim, Number > outer_product(const SymmetricTensor< 2, dim, Number > &t1, const SymmetricTensor< 2, dim, Number > &t2)
const std::vector< std::vector< std::function< const Function< spacedim > *(const typename Triangulation< dim, spacedim >::cell_iterator &)> > > enrichments
const FESystem< dim, spacedim > & get_fe_system() const
static ::ExceptionBase & ExcMessage(std::string arg1)
static ::ExceptionBase & ExcImpossibleInDim(int arg1)
void push_back(const FiniteElement< dim, spacedim > &new_fe)
std::unique_ptr< typename FESystem< dim, spacedim >::InternalData > fesystem_data
Third derivatives of shape functions.
const std::unique_ptr< const FESystem< dim, spacedim > > fe_system
#define Assert(cond, exc)
unsigned int element_multiplicity(const unsigned int index) const
IteratorRange< active_cell_iterator > active_cell_iterators() const
FiniteElement< dim, spacedim >::InternalDataBase & get_fe_data(const unsigned int base_no) const
void reinit(const size_type m, const size_type n, const IndexSet &rowset=IndexSet())
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
Abstract base class for mapping classes.
void reinit(const unsigned int n_blocks, const size_type n_elements_per_block)
#define DEAL_II_NAMESPACE_CLOSE
void make_fe_collection_from_colored_enrichments(const unsigned int n_colors, const std::vector< std::set< unsigned int >> &fe_sets, const std::vector< std::function< const Function< spacedim > *(const typename Triangulation< dim, spacedim >::cell_iterator &)>> &color_enrichments, const FiniteElement< dim, spacedim > &fe_base, const FiniteElement< dim, spacedim > &fe_enriched, const FE_Nothing< dim, spacedim > &fe_nothing, hp::FECollection< dim, spacedim > &fe_collection)
std::vector< std::set< unsigned int > > fe_sets
std::vector< unsigned int > predicate_colors
void copy_from(const size_type n_rows, const size_type n_cols, const ForwardIterator begin, const ForwardIterator end)
Second derivatives of shape functions.
unsigned int color_predicates(const hp::DoFHandler< dim, spacedim > &mesh, const std::vector< predicate_function< dim, spacedim >> &predicates, std::vector< unsigned int > &predicate_colors)
void make_colorwise_enrichment_functions(const unsigned int n_colors, const std::vector< std::shared_ptr< Function< spacedim >>> &enrichments, const std::map< unsigned int, std::map< unsigned int, unsigned int >> &cellwise_color_predicate_map, std::vector< std::function< const Function< spacedim > *(const typename Triangulation< dim, spacedim >::cell_iterator &)>> &color_enrichments)
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim - 1 > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
virtual double shape_value(const unsigned int i, const Point< dim > &p) const override
std::string dim_string(const int dim, const int spacedim)
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
unsigned int size() const
const unsigned int dofs_per_cell
const std::vector< predicate_function< dim, spacedim > > predicates
bool find_connection_between_subdomains(const hp::DoFHandler< dim, spacedim > &dof_handler, const predicate_function< dim, spacedim > &predicate_1, const predicate_function< dim, spacedim > &predicate_2)
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
unsigned int n_components() const
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const override
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
#define DEAL_II_NAMESPACE_OPEN
Shape function gradients.
std::vector< std::vector< std::vector< unsigned int > > > base_no_mult_local_enriched_dofs
std::vector< std::pair< unsigned int, unsigned int > > system_to_component_table
const Triangulation< dim, spacedim > & get_triangulation() const
void push_back(const size_type size)
const unsigned int dofs_per_face
std::vector< std::pair< std::pair< unsigned int, unsigned int >, unsigned int > > system_to_base_table
static ::ExceptionBase & ExcNotImplemented()
std::vector< std::pair< unsigned int, unsigned int > > face_system_to_component_table
std::vector< cell_iterator_function > color_enrichments
std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > setup_data(std::unique_ptr< typename FESystem< dim, spacedim >::InternalData > fes_data, const UpdateFlags flags, const Quadrature< dim_1 > &quadrature) const
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
BlockIndices base_to_block_indices
std::map< unsigned int, std::map< unsigned int, unsigned int > > cellwise_color_predicate_map
std::vector< std::pair< std::pair< unsigned int, unsigned int >, unsigned int > > face_system_to_base_table
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
const std::vector< std::shared_ptr< Function< spacedim > > > enrichments
unsigned int n_base_elements() const
void set_cellwise_color_set_and_fe_index(hp::DoFHandler< dim, spacedim > &dof_handler, const std::vector< predicate_function< dim, spacedim >> &predicates, const std::vector< unsigned int > &predicate_colors, std::map< unsigned int, std::map< unsigned int, unsigned int >> &cellwise_color_predicate_map, std::vector< std::set< unsigned int >> &fe_sets)
virtual void fill_fe_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const CellSimilarity::Similarity cell_similarity, const Quadrature< dim > &quadrature, const Mapping< dim, spacedim > &mapping, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_internal, const ::internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &mapping_data, const typename FiniteElement< dim, spacedim >::InternalDataBase &fe_internal, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
virtual void fill_fe_face_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const Quadrature< dim - 1 > &quadrature, const Mapping< dim, spacedim > &mapping, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_internal, const ::internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &mapping_data, const typename FiniteElement< dim, spacedim >::InternalDataBase &fe_internal, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
virtual void fill_fe_subface_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int sub_no, const Quadrature< dim - 1 > &quadrature, const Mapping< dim, spacedim > &mapping, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_internal, const ::internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &mapping_data, const typename FiniteElement< dim, spacedim >::InternalDataBase &fe_internal, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
std::vector< int > adjust_line_dof_index_for_line_orientation_table
const FE_Nothing< dim, spacedim > fe_nothing
virtual bool hp_constraints_are_implemented() const override
int(&) functions(const void *v1, const void *v2)
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim - 1 > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
static ::ExceptionBase & ExcInternalError()