38 count_nonzeros(
const std::vector<unsigned int> &vec)
40 return std::count_if(vec.begin(), vec.end(), [](
const unsigned int i) {
53 template <
int dim,
int spacedim = dim>
56 const unsigned int base_no)
64 unsigned int out_index = 0;
65 for (
unsigned int system_index = 0; system_index < fe.
n_dofs_per_cell();
72 const unsigned int base_component =
74 const unsigned int base_index =
79 table[base_component][base_index] = out_index;
90 template <
int dim,
int spacedim = dim>
91 std::vector<typename FESystem<dim, spacedim>::BaseOffsets>
93 const unsigned int base_no)
95 std::vector<typename FESystem<dim, spacedim>::BaseOffsets> table;
98 unsigned int out_index = 0;
99 for (
unsigned int system_index = 0; system_index < fe.
n_dofs_per_cell();
104 const unsigned int base_index =
107 table.emplace_back();
109 table.back().n_nonzero_components =
111 unsigned int in_index = 0;
112 for (
unsigned int i = 0; i < base_index; ++i)
115 table.back().in_index = in_index;
116 table.back().out_index = out_index;
131 template <
int dim,
int spacedim = dim>
135 const unsigned int base_no,
136 const unsigned int n_q_points,
146 const unsigned int n_dofs_per_cell =
148 for (
unsigned int component = 0; component < n_components; ++component)
149 for (
unsigned int b = 0;
b < n_dofs_per_cell; ++
b)
151 const unsigned int out_index = base_to_system_table[component][
b];
154 for (
unsigned int q = 0; q < n_q_points; ++q)
159 for (
unsigned int q = 0; q < n_q_points; ++q)
164 for (
unsigned int q = 0; q < n_q_points; ++q)
169 for (
unsigned int q = 0; q < n_q_points; ++q)
179 template <
int dim,
int spacedim = dim>
183 const unsigned int base_no,
184 const unsigned int n_q_points,
196 for (
const auto &offset : offsets)
199 for (
unsigned int s = 0; s < offset.n_nonzero_components; ++s)
200 for (
unsigned int q = 0; q < n_q_points; ++q)
205 for (
unsigned int s = 0; s < offset.n_nonzero_components; ++s)
206 for (
unsigned int q = 0; q < n_q_points; ++q)
211 for (
unsigned int s = 0; s < offset.n_nonzero_components; ++s)
212 for (
unsigned int q = 0; q < n_q_points; ++q)
217 for (
unsigned int s = 0; s < offset.n_nonzero_components; ++s)
218 for (
unsigned int q = 0; q < n_q_points; ++q)
227template <
int dim,
int spacedim>
229 const unsigned int n_base_elements)
230 : base_fe_datas(n_base_elements)
231 , base_fe_output_objects(n_base_elements)
236template <
int dim,
int spacedim>
240 for (
unsigned int i = 0; i < base_fe_datas.size(); ++i)
241 base_fe_datas[i].reset();
245template <
int dim,
int spacedim>
248 const unsigned int base_no)
const
251 return *base_fe_datas[base_no];
256template <
int dim,
int spacedim>
259 const unsigned int base_no,
263 base_fe_datas[base_no] = std::move(ptr);
268template <
int dim,
int spacedim>
271 const unsigned int base_no)
const
274 return base_fe_output_objects[base_no];
282template <
int dim,
int spacedim>
286template <
int dim,
int spacedim>
288 const unsigned int n_elements)
294 , base_elements((n_elements > 0))
296 std::vector<const FiniteElement<dim, spacedim> *> fes;
298 std::vector<unsigned int> multiplicities;
299 multiplicities.push_back(n_elements);
300 initialize(fes, multiplicities);
305template <
int dim,
int spacedim>
307 const unsigned int n1,
309 const unsigned int n2)
317 , base_elements(static_cast<
int>(n1 > 0) + static_cast<
int>(n2 > 0))
319 std::vector<const FiniteElement<dim, spacedim> *> fes;
322 std::vector<unsigned int> multiplicities;
323 multiplicities.push_back(n1);
324 multiplicities.push_back(n2);
325 initialize(fes, multiplicities);
330template <
int dim,
int spacedim>
332 const unsigned int n1,
334 const unsigned int n2,
336 const unsigned int n3)
351 , base_elements(static_cast<
int>(n1 > 0) + static_cast<
int>(n2 > 0) +
352 static_cast<
int>(n3 > 0))
354 std::vector<const FiniteElement<dim, spacedim> *> fes;
358 std::vector<unsigned int> multiplicities;
359 multiplicities.push_back(n1);
360 multiplicities.push_back(n2);
361 multiplicities.push_back(n3);
362 initialize(fes, multiplicities);
367template <
int dim,
int spacedim>
369 const unsigned int n1,
371 const unsigned int n2,
373 const unsigned int n3,
375 const unsigned int n4)
401 , base_elements(static_cast<
int>(n1 > 0) + static_cast<
int>(n2 > 0) +
402 static_cast<
int>(n3 > 0) + static_cast<
int>(n4 > 0))
404 std::vector<const FiniteElement<dim, spacedim> *> fes;
409 std::vector<unsigned int> multiplicities;
410 multiplicities.push_back(n1);
411 multiplicities.push_back(n2);
412 multiplicities.push_back(n3);
413 multiplicities.push_back(n4);
414 initialize(fes, multiplicities);
419template <
int dim,
int spacedim>
421 const unsigned int n1,
423 const unsigned int n2,
425 const unsigned int n3,
427 const unsigned int n4,
429 const unsigned int n5)
432 multiply_dof_numbers(&fe1, n1, &fe2, n2, &fe3, n3, &fe4, n4, &fe5, n5),
453 , base_elements(static_cast<
int>(n1 > 0) + static_cast<
int>(n2 > 0) +
454 static_cast<
int>(n3 > 0) + static_cast<
int>(n4 > 0) +
455 static_cast<
int>(n5 > 0))
457 std::vector<const FiniteElement<dim, spacedim> *> fes;
463 std::vector<unsigned int> multiplicities;
464 multiplicities.push_back(n1);
465 multiplicities.push_back(n2);
466 multiplicities.push_back(n3);
467 multiplicities.push_back(n4);
468 multiplicities.push_back(n5);
469 initialize(fes, multiplicities);
474template <
int dim,
int spacedim>
477 const std::vector<unsigned int> & multiplicities)
484 , base_elements(count_nonzeros(multiplicities))
486 initialize(fes, multiplicities);
491template <
int dim,
int spacedim>
502 std::ostringstream namebuf;
515 return namebuf.str();
520template <
int dim,
int spacedim>
521std::unique_ptr<FiniteElement<dim, spacedim>>
524 std::vector<const FiniteElement<dim, spacedim> *> fes;
525 std::vector<unsigned int> multiplicities;
532 return std::make_unique<FESystem<dim, spacedim>>(fes, multiplicities);
537template <
int dim,
int spacedim>
540 const unsigned int first_component,
541 const unsigned int n_selected_components)
const
544 ExcMessage(
"Invalid arguments (not a part of this FiniteElement)."));
546 const unsigned int base_index =
548 const unsigned int component_in_base =
550 const unsigned int base_components =
555 if (n_selected_components <= base_components)
557 .
get_sub_fe(component_in_base, n_selected_components);
560 ExcMessage(
"You can not select a part of a FiniteElement."));
566template <
int dim,
int spacedim>
577 .
shape_value(this->system_to_base_table[i].second, p));
582template <
int dim,
int spacedim>
585 const unsigned int i,
587 const unsigned int component)
const
603 const unsigned int component_in_base =
618template <
int dim,
int spacedim>
629 .
shape_grad(this->system_to_base_table[i].second, p));
634template <
int dim,
int spacedim>
637 const unsigned int i,
639 const unsigned int component)
const
651 const unsigned int component_in_base =
663template <
int dim,
int spacedim>
679template <
int dim,
int spacedim>
682 const unsigned int i,
684 const unsigned int component)
const
696 const unsigned int component_in_base =
708template <
int dim,
int spacedim>
724template <
int dim,
int spacedim>
727 const unsigned int i,
729 const unsigned int component)
const
741 const unsigned int component_in_base =
753template <
int dim,
int spacedim>
769template <
int dim,
int spacedim>
772 const unsigned int i,
774 const unsigned int component)
const
786 const unsigned int component_in_base =
798template <
int dim,
int spacedim>
808 Assert((interpolation_matrix.
m() == this->n_dofs_per_cell()) ||
811 this->n_dofs_per_cell()));
813 (this->n_dofs_per_cell() == 0),
823 (x_source_fe.
get_name().find(
"FESystem<") == 0) ||
850 std::vector<FullMatrix<double>> base_matrices(this->
n_base_elements());
862 interpolation_matrix = 0;
867 interpolation_matrix(i, j) =
875template <
int dim,
int spacedim>
878 const unsigned int child,
885 "Restriction matrices are only available for refined cells!"));
889 if (this->
restriction[refinement_case - 1][child].n() == 0)
891 std::lock_guard<std::mutex> lock(this->
mutex);
894 if (this->
restriction[refinement_case - 1][child].n() ==
896 return this->
restriction[refinement_case - 1][child];
899 bool do_restriction =
true;
902 std::vector<const FullMatrix<double> *> base_matrices(
910 do_restriction =
false;
942 const unsigned int base =
945 const unsigned int base_index_i =
953 (*base_matrices[base])(base_index_i, base_index_j);
961 return this->
restriction[refinement_case - 1][child];
966template <
int dim,
int spacedim>
969 const unsigned int child,
976 "Restriction matrices are only available for refined cells!"));
981 if (this->
prolongation[refinement_case - 1][child].n() == 0)
983 std::lock_guard<std::mutex> lock(this->
mutex);
985 if (this->
prolongation[refinement_case - 1][child].n() ==
989 bool do_prolongation =
true;
990 std::vector<const FullMatrix<double> *> base_matrices(
997 do_prolongation =
false;
1002 if (do_prolongation)
1013 const unsigned int base =
1016 const unsigned int base_index_i =
1021 (*base_matrices[base])(base_index_i, base_index_j);
1032template <
int dim,
int spacedim>
1035 const unsigned int face,
1036 const bool face_orientation,
1037 const bool face_flip,
1038 const bool face_rotation)
const
1043 const std::pair<std::pair<unsigned int, unsigned int>,
unsigned int>
1046 const unsigned int base_face_to_cell_index =
1059 const std::pair<std::pair<unsigned int, unsigned int>,
unsigned int> target =
1060 std::make_pair(face_base_index.first, base_face_to_cell_index);
1077template <
int dim,
int spacedim>
1084 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1091template <
int dim,
int spacedim>
1092std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
1108 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
1110 auto &data =
dynamic_cast<InternalData &
>(*data_ptr);
1125 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1128 &base_fe_output_object = data.get_fe_output_object(base_no);
1143 base_fe_output_object);
1145 data.set_fe_data(base_no, std::move(base_fe_data));
1154template <
int dim,
int spacedim>
1155std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
1171 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
1173 auto &data =
dynamic_cast<InternalData &
>(*data_ptr);
1188 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1191 &base_fe_output_object = data.get_fe_output_object(base_no);
1204 flags, mapping, quadrature, base_fe_output_object);
1206 data.set_fe_data(base_no, std::move(base_fe_data));
1217template <
int dim,
int spacedim>
1218std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
1234 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
1236 auto &data =
dynamic_cast<InternalData &
>(*data_ptr);
1252 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1255 &base_fe_output_object = data.get_fe_output_object(base_no);
1268 flags, mapping, quadrature, base_fe_output_object);
1270 data.set_fe_data(base_no, std::move(base_fe_data));
1278template <
int dim,
int spacedim>
1286 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
1308template <
int dim,
int spacedim>
1312 const unsigned int face_no,
1316 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
1338template <
int dim,
int spacedim>
1342 const unsigned int face_no,
1343 const unsigned int sub_no,
1347 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
1369template <
int dim,
int spacedim>
1370template <
class Q_or_QC>
1375 const unsigned int face_no,
1376 const unsigned int sub_no,
1377 const Q_or_QC & quadrature,
1390 Assert(
dynamic_cast<const InternalData *
>(&fe_internal) !=
nullptr,
1392 const InternalData &fe_data =
static_cast<const InternalData &
>(fe_internal);
1409 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1413 fe_data.get_fe_data(base_no);
1416 &base_data = fe_data.get_fe_output_object(base_no);
1422 const Quadrature<dim - 1> * sub_face_quadrature =
nullptr;
1428 const Subscriptor *quadrature_base_pointer = &quadrature;
1430 quadrature_base_pointer) !=
nullptr,
1435 n_q_points = cell_quadrature->
size();
1439 const Subscriptor *quadrature_base_pointer = &quadrature;
1441 quadrature_base_pointer) !=
nullptr,
1447 quadrature_base_pointer);
1449 (*face_quadrature)[face_quadrature->size() == 1 ? 0 : face_no]
1454 const Subscriptor *quadrature_base_pointer = &quadrature;
1456 quadrature_base_pointer) !=
nullptr,
1459 sub_face_quadrature =
1460 static_cast<const Quadrature<dim - 1
> *>(quadrature_base_pointer);
1461 n_q_points = sub_face_quadrature->
size();
1495 *sub_face_quadrature,
1505 const UpdateFlags base_flags = base_fe_data.update_each;
1533template <
int dim,
int spacedim>
1542 const unsigned int face_no = 0;
1573 const std::pair<std::pair<unsigned int, unsigned int>,
unsigned int>
1578 std::pair<std::pair<unsigned int, unsigned int>,
unsigned int> m_index;
1600 const unsigned int index_in_line =
1602 const unsigned int sub_line =
1610 const unsigned int tmp1 =
1629 const unsigned int tmp2 =
1659 const unsigned int index_in_line =
1662 const unsigned int sub_line =
1667 const unsigned int tmp1 =
1677 const unsigned int tmp2 =
1694 const unsigned int index_in_quad =
1700 const unsigned int sub_quad =
1722 const unsigned int tmp2 =
1750 if (n_index.first == m_index.first)
1759template <
int dim,
int spacedim>
1763 const std::vector<unsigned int> & multiplicities)
1765 Assert(fes.size() == multiplicities.size(),
1768 ExcMessage(
"Need to pass at least one finite element."));
1769 Assert(count_nonzeros(multiplicities) > 0,
1770 ExcMessage(
"You only passed FiniteElements with multiplicity 0."));
1777 for (
unsigned int i = 0; i < fes.size(); ++i)
1778 if (multiplicities[i] > 0)
1784 unsigned int ind = 0;
1785 for (
unsigned int i = 0; i < fes.size(); ++i)
1786 if (multiplicities[i] > 0)
1812 for (
unsigned int face_no = 0; face_no < this->
n_unique_faces(); ++face_no)
1840 for (
unsigned int base_el = 0; base_el < this->
n_base_elements(); ++base_el)
1866 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1875 for (
unsigned int base_no = 0; base_no < this->
n_base_elements(); ++base_no)
1897 bool flag_has_no_support_points =
false;
1905 flag_has_no_support_points =
true;
1910 if (flag_has_no_support_points)
1920 const unsigned int base_i =
1922 const unsigned int index_in_base =
1961 for (
const auto &
point :
1993 const auto &points =
1995 for (
unsigned int j = 0; j < points.size(); ++j)
2019 unsigned int index = 0;
2027 for (
unsigned int i = 0; i < temp.size(0); ++i)
2028 for (
unsigned int j = 0; j < 8; ++j)
2030 [face_no](index + i, j) = temp(i, j);
2031 index += temp.size(0);
2039 this->n_dofs_per_line(),
2041 unsigned int index = 0;
2044 const std::vector<int> &temp2 =
2052 this->adjust_line_dof_index_for_line_orientation_table.begin() +
2054 index += temp2.size();
2061 init_tasks.join_all();
2066template <
int dim,
int spacedim>
2079template <
int dim,
int spacedim>
2084 const unsigned int face_no)
const
2086 Assert(interpolation_matrix.
n() == this->n_dofs_per_face(face_no),
2088 this->n_dofs_per_face(face_no)));
2103 if (
const auto *fe_other_system =
2107 interpolation_matrix = 0;
2111 unsigned int base_index = 0, base_index_other = 0;
2112 unsigned int multiplicity = 0, multiplicity_other = 0;
2127 base_to_base_interpolation.reinit(base_other.n_dofs_per_face(face_no),
2130 base_to_base_interpolation,
2138 std::make_pair(base_index, multiplicity))
2139 for (
unsigned int j = 0;
2140 j < fe_other_system->n_dofs_per_face(face_no);
2142 if (fe_other_system->face_system_to_base_index(j, face_no)
2144 std::make_pair(base_index_other, multiplicity_other))
2145 interpolation_matrix(j, i) = base_to_base_interpolation(
2146 fe_other_system->face_system_to_base_index(j, face_no)
2148 this->face_system_to_base_index(i, face_no).second);
2159 ++multiplicity_other;
2160 if (multiplicity_other ==
2161 fe_other_system->element_multiplicity(base_index_other))
2163 multiplicity_other = 0;
2171 Assert(base_index_other == fe_other_system->n_base_elements(),
2178 Assert(base_index_other != fe_other_system->n_base_elements(),
2195template <
int dim,
int spacedim>
2199 const unsigned int subface,
2201 const unsigned int face_no)
const
2204 (x_source_fe.
get_name().find(
"FESystem<") == 0) ||
2208 Assert(interpolation_matrix.
n() == this->n_dofs_per_face(face_no),
2210 this->n_dofs_per_face(face_no)));
2227 if (fe_other_system !=
nullptr)
2230 interpolation_matrix = 0;
2234 unsigned int base_index = 0, base_index_other = 0;
2235 unsigned int multiplicity = 0, multiplicity_other = 0;
2250 base_to_base_interpolation.reinit(base_other.n_dofs_per_face(face_no),
2254 base_to_base_interpolation,
2262 std::make_pair(base_index, multiplicity))
2263 for (
unsigned int j = 0;
2268 std::make_pair(base_index_other, multiplicity_other))
2269 interpolation_matrix(j, i) = base_to_base_interpolation(
2272 this->face_system_to_base_index(i, face_no).second);
2283 ++multiplicity_other;
2284 if (multiplicity_other ==
2287 multiplicity_other = 0;
2310 fe_other_system !=
nullptr,
2318template <
int dim,
int spacedim>
2319template <
int structdim>
2320std::vector<std::pair<unsigned int, unsigned int>>
2323 const unsigned int face_no)
const
2342 unsigned int base_index = 0, base_index_other = 0;
2343 unsigned int multiplicity = 0, multiplicity_other = 0;
2347 unsigned int dof_offset = 0, dof_offset_other = 0;
2349 std::vector<std::pair<unsigned int, unsigned int>> identities;
2363 std::vector<std::pair<unsigned int, unsigned int>> base_identities;
2380 for (
const auto &base_identity : base_identities)
2381 identities.emplace_back(base_identity.first + dof_offset,
2382 base_identity.second + dof_offset_other);
2385 dof_offset += base.template n_dofs_per_object<structdim>();
2387 base_other.template n_dofs_per_object<structdim>();
2398 ++multiplicity_other;
2399 if (multiplicity_other ==
2402 multiplicity_other = 0;
2426 return std::vector<std::pair<unsigned int, unsigned int>>();
2432template <
int dim,
int spacedim>
2433std::vector<std::pair<unsigned int, unsigned int>>
2437 return hp_object_dof_identities<0>(fe_other);
2440template <
int dim,
int spacedim>
2441std::vector<std::pair<unsigned int, unsigned int>>
2445 return hp_object_dof_identities<1>(fe_other);
2450template <
int dim,
int spacedim>
2451std::vector<std::pair<unsigned int, unsigned int>>
2454 const unsigned int face_no)
const
2456 return hp_object_dof_identities<2>(fe_other, face_no);
2461template <
int dim,
int spacedim>
2465 const unsigned int codim)
const
2488 fe_sys_other->base_element(
b).n_components(),
2491 fe_sys_other->element_multiplicity(
b),
2498 fe_sys_other->base_element(
b), codim));
2499 domination = domination & base_domination;
2511template <
int dim,
int spacedim>
2521template <
int dim,
int spacedim>
2524 const unsigned int shape_index,
2525 const unsigned int face_index)
const
2534template <
int dim,
int spacedim>
2540 (this->unit_support_points.size() == 0),
2555template <
int dim,
int spacedim>
2558 const unsigned int index,
2559 const unsigned int face_no)
const
2573 ->unit_face_support_points[this->
n_unique_faces() == 1 ? 0 : face_no]
2581 this->face_system_to_base_index(index, face_no).second, face_no));
2586template <
int dim,
int spacedim>
2587std::pair<Table<2, bool>, std::vector<unsigned int>>
2597 const std::pair<Table<2, bool>, std::vector<unsigned int>> base_table =
2606 if (constant_modes.n_rows() <
2609 Table<2, bool> new_constant_modes(comp + base_table.first.n_rows() *
2611 constant_modes.n_cols());
2612 for (
unsigned int r = 0; r < comp; ++r)
2614 new_constant_modes(r, c) = constant_modes(r, c);
2615 constant_modes.swap(new_constant_modes);
2622 std::pair<std::pair<unsigned int, unsigned int>,
unsigned int> ind =
2624 if (ind.first.first == i)
2625 for (
unsigned int c = 0; c < base_table.first.n_rows(); ++c)
2626 constant_modes(comp +
2627 ind.first.second * base_table.first.n_rows() + c,
2628 k) = base_table.first(c, ind.second);
2631 for (
const unsigned int c : base_table.second)
2636 return std::pair<Table<2, bool>, std::vector<unsigned int>>(constant_modes,
2642template <
int dim,
int spacedim>
2646 std::vector<double> & dof_values)
const
2649 ExcMessage(
"The FESystem does not have generalized support points"));
2652 this->get_generalized_support_points().size());
2655 std::vector<double> base_dof_values;
2656 std::vector<Vector<double>> base_point_values;
2661 unsigned int current_vector_component = 0;
2662 for (
unsigned int base = 0; base <
base_elements.size(); ++base)
2675 if (n_base_dofs == 0)
2677 current_vector_component += multiplicity * n_base_components;
2683 const unsigned int n_base_points =
2686 base_dof_values.resize(n_base_dofs);
2687 base_point_values.resize(n_base_points);
2689 for (
unsigned int m = 0; m < multiplicity;
2690 ++m, current_vector_component += n_base_components)
2694 for (
unsigned int j = 0; j < base_point_values.size(); ++j)
2696 base_point_values[j].reinit(n_base_components,
false);
2705 const auto end =
begin + n_base_components;
2711 base_point_values, base_dof_values);
2722 std::make_pair(base, m))
2736 for (
unsigned int m = 0; m < multiplicity; ++m)
2739 std::make_pair(base, m))
2740 dof_values[i] = std::numeric_limits<double>::signaling_NaN();
2742 current_vector_component += multiplicity * n_base_components;
2749template <
int dim,
int spacedim>
2766#include "fe_system.inst"
void push_back(const size_type size)
void reinit(const unsigned int n_blocks, const size_type n_elements_per_block)
void set_fe_data(const unsigned int base_no, std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase >)
InternalData(const unsigned int n_base_elements)
FiniteElement< dim, spacedim >::InternalDataBase & get_fe_data(const unsigned int base_no) const
internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > & get_fe_output_object(const unsigned int base_no) const
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
virtual Tensor< 2, dim > shape_grad_grad(const unsigned int i, const Point< dim > &p) const override
virtual const FiniteElement< dim, spacedim > & base_element(const unsigned int index) const override
virtual Point< dim > unit_support_point(const unsigned int index) const override
std::vector< std::vector< BaseOffsets > > nonprimitive_offset_tables
virtual unsigned int face_to_cell_index(const unsigned int face_dof_index, const unsigned int face, const bool face_orientation=true, const bool face_flip=false, const bool face_rotation=false) const override
std::vector< std::pair< std::unique_ptr< const FiniteElement< dim, spacedim > >, unsigned int > > base_elements
virtual Tensor< 3, dim > shape_3rd_derivative(const unsigned int i, const Point< dim > &p) const override
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
std::vector< Table< 2, unsigned int > > primitive_offset_tables
virtual std::string get_name() const override
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
virtual const FiniteElement< dim, spacedim > & get_sub_fe(const unsigned int first_component, const unsigned int n_selected_components) const override
virtual Tensor< 1, dim > shape_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
virtual FiniteElementDomination::Domination compare_for_domination(const FiniteElement< dim, spacedim > &fe_other, const unsigned int codim=0) const override final
virtual void fill_fe_face_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const hp::QCollection< 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 std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other, const unsigned int face_no=0) const override
void compute_fill(const Mapping< dim, spacedim > &mapping, const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int sub_no, const Q_or_QC &quadrature, const CellSimilarity::Similarity cell_similarity, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_internal, const typename FiniteElement< dim, spacedim >::InternalDataBase &fe_data, const internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &mapping_data, internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const
virtual Tensor< 3, dim > shape_3rd_derivative_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
virtual Tensor< 1, dim > shape_grad(const unsigned int i, const Point< dim > &p) const override
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const hp::QCollection< dim - 1 > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
static const unsigned int invalid_face_number
virtual bool hp_constraints_are_implemented() const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
void build_interface_constraints()
virtual Tensor< 4, dim > shape_4th_derivative_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual Point< dim - 1 > unit_face_support_point(const unsigned int index, const unsigned int face_no=0) 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
void initialize(const std::vector< const FiniteElement< dim, spacedim > * > &fes, const std::vector< unsigned int > &multiplicities)
virtual void convert_generalized_support_point_values_to_dof_values(const std::vector< Vector< double > > &support_point_values, std::vector< double > &dof_values) const override
std::vector< std::pair< unsigned int, unsigned int > > hp_object_dof_identities(const FiniteElement< dim, spacedim > &fe_other, const unsigned int face_no=0) const
virtual double shape_value_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual double shape_value(const unsigned int i, const Point< dim > &p) const override
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix, const unsigned int face_no=0) const override
virtual Tensor< 2, dim > shape_grad_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix, const unsigned int face_no=0) const override
std::vector< std::vector< std::size_t > > generalized_support_points_index_table
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
virtual std::size_t memory_consumption() const override
virtual Tensor< 4, dim > shape_4th_derivative(const unsigned int i, const Point< dim > &p) const override
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
unsigned int n_dofs_per_vertex() const
const unsigned int components
unsigned int n_dofs_per_cell() const
unsigned int n_dofs_per_line() const
unsigned int n_dofs_per_face(unsigned int face_no=0, unsigned int child=0) const
unsigned int n_components() const
unsigned int n_unique_faces() const
unsigned int n_dofs_per_quad(unsigned int face_no=0) const
bool constraints_are_implemented(const ::internal::SubfaceCase< dim > &subface_case=::internal::SubfaceCase< dim >::case_isotropic) const
virtual std::string get_name() const =0
virtual Point< dim > unit_support_point(const unsigned int index) const
virtual FiniteElementDomination::Domination compare_for_domination(const FiniteElement< dim, spacedim > &fe_other, const unsigned int codim=0) const
virtual std::unique_ptr< InternalDataBase > get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const =0
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
std::vector< std::vector< Point< dim - 1 > > > unit_face_support_points
virtual const FiniteElement< dim, spacedim > & base_element(const unsigned int index) const
virtual Tensor< 1, dim > shape_grad(const unsigned int i, const Point< dim > &p) const
virtual std::unique_ptr< InternalDataBase > get_face_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const hp::QCollection< dim - 1 > &quadrature, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const
std::pair< unsigned int, unsigned int > component_to_base_index(const unsigned int component) const
virtual Point< dim - 1 > unit_face_support_point(const unsigned int index, const unsigned int face_no=0) const
virtual std::unique_ptr< 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
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other, const unsigned int face_no=0) const
bool has_support_points() const
std::vector< std::vector< FullMatrix< double > > > restriction
bool has_generalized_support_points() const
virtual Tensor< 2, dim > shape_grad_grad(const unsigned int i, const Point< dim > &p) const
std::vector< Table< 2, int > > adjust_quad_dof_index_for_face_orientation_table
BlockIndices base_to_block_indices
bool is_primitive() const
std::vector< int > adjust_line_dof_index_for_line_orientation_table
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
virtual unsigned int face_to_cell_index(const unsigned int face_dof_index, const unsigned int face, const bool face_orientation=true, const bool face_flip=false, const bool face_rotation=false) const
const FiniteElement< dim, spacedim > & get_sub_fe(const ComponentMask &mask) const
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 InternalDataBase &fe_internal, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const =0
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix, const unsigned int face_no=0) const
virtual void fill_fe_face_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const hp::QCollection< 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 InternalDataBase &fe_internal, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const =0
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
virtual Tensor< 3, dim > shape_3rd_derivative(const unsigned int i, const Point< dim > &p) const
std::vector< std::pair< std::pair< unsigned int, unsigned int >, unsigned int > > system_to_base_table
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual void convert_generalized_support_point_values_to_dof_values(const std::vector< Vector< double > > &support_point_values, std::vector< double > &nodal_values) const
std::pair< std::pair< unsigned int, unsigned int >, unsigned int > system_to_base_index(const unsigned int index) const
std::vector< std::pair< unsigned int, unsigned int > > system_to_component_table
std::pair< std::pair< unsigned int, unsigned int >, unsigned int > face_system_to_base_index(const unsigned int index, const unsigned int face_no=0) const
const FullMatrix< double > & constraints(const ::internal::SubfaceCase< dim > &subface_case=::internal::SubfaceCase< dim >::case_isotropic) const
unsigned int element_multiplicity(const unsigned int index) const
std::vector< std::pair< std::pair< unsigned int, unsigned int >, unsigned int > > component_to_base_table
TableIndices< 2 > interface_constraints_size() const
std::vector< std::vector< std::pair< std::pair< unsigned int, unsigned int >, unsigned int > > > face_system_to_base_table
std::vector< Point< dim > > unit_support_points
std::vector< std::vector< std::pair< unsigned int, unsigned int > > > face_system_to_component_table
unsigned int n_nonzero_components(const unsigned int i) const
FullMatrix< double > interface_constraints
const std::vector< Point< dim > > & get_generalized_support_points() const
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 InternalDataBase &fe_internal, ::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const =0
unsigned int n_base_elements() const
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
virtual double shape_value(const unsigned int i, const Point< dim > &p) const
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix, const unsigned int face_no=0) const
virtual std::size_t memory_consumption() const
virtual Tensor< 4, dim > shape_4th_derivative(const unsigned int i, const Point< dim > &p) const
std::vector< Point< dim > > generalized_support_points
const std::vector< ComponentMask > nonzero_components
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual bool hp_constraints_are_implemented() const
std::vector< std::vector< FullMatrix< double > > > prolongation
unsigned int size() const
unsigned int max_n_quadrature_points() const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
@ update_hessians
Second derivatives of shape functions.
@ update_values
Shape function values.
@ update_3rd_derivatives
Third derivatives of shape functions.
@ update_gradients
Shape function gradients.
@ update_default
No update.
static ::ExceptionBase & ExcNotImplemented()
#define Assert(cond, exc)
static ::ExceptionBase & ExcImpossibleInDim(int arg1)
#define AssertDimension(dim1, dim2)
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcInternalError()
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
static ::ExceptionBase & ExcInterpolationNotImplemented()
static ::ExceptionBase & ExcMessage(std::string arg1)
#define AssertThrow(cond, exc)
Task< RT > new_task(const std::function< RT()> &function)
@ neither_element_dominates
std::enable_if< std::is_fundamental< T >::value, std::size_t >::type memory_consumption(const T &t)
Point< spacedim > point(const gp_Pnt &p, const double tolerance=1e-10)
SymmetricTensor< 2, dim, Number > b(const Tensor< 2, dim, Number > &F)
VectorType::value_type * end(VectorType &V)
VectorType::value_type * begin(VectorType &V)
std::string dim_string(const int dim, const int spacedim)
void copy(const T *begin, const T *end, U *dest)
std::vector< typename FESystem< dim, spacedim >::BaseOffsets > setup_nonprimitive_offset_table(const FESystem< dim, spacedim > &fe, const unsigned int base_no)
Table< 2, unsigned int > setup_primitive_offset_table(const FESystem< dim, spacedim > &fe, const unsigned int base_no)
void copy_nonprimitive_base_element_values(const FESystem< dim, spacedim > &fe, const unsigned int base_no, const unsigned int n_q_points, const UpdateFlags base_flags, const std::vector< typename FESystem< dim, spacedim >::BaseOffsets > &offsets, const FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &base_data, FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data)
void copy_primitive_base_element_values(const FESystem< dim, spacedim > &fe, const unsigned int base_no, const unsigned int n_q_points, const UpdateFlags base_flags, const Table< 2, unsigned int > &base_to_system_table, const FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &base_data, FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data)
static const unsigned int invalid_unsigned_int