37#include <boost/container/small_vector.hpp>
49template <
int dim,
int spacedim>
59template <
int dim,
int spacedim>
80template <
int dim,
int spacedim>
89 const unsigned int n_q_points = q.
size();
136template <
int dim,
int spacedim>
139 const UpdateFlags update_flags,
141 const unsigned int n_original_q_points)
153 const auto reference_cell = this->
fe.reference_cell();
154 const auto n_faces = reference_cell.n_faces();
156 for (
unsigned int i = 0; i < n_faces; ++i)
161 reference_cell.template face_tangent_vector<dim>(i, 0));
167 reference_cell.template face_tangent_vector<dim>(i, 1));
175template <
int dim,
int spacedim>
184 const auto &tensor_pols = fe_poly->get_poly_space();
187 const unsigned int n_points = unit_points.size();
189 std::vector<double> values;
190 std::vector<Tensor<1, dim>> grads;
204 std::vector<Tensor<2, dim>> grad2;
212 std::vector<Tensor<3, dim>> grad3;
220 std::vector<Tensor<4, dim>> grad4;
233 for (
unsigned int point = 0; point < n_points; ++point)
235 tensor_pols.evaluate(
236 unit_points[point], values, grads, grad2, grad3, grad4);
240 shape(point, i) = values[i];
273 template <
int dim,
int spacedim>
275 maybe_compute_q_points(
277 const typename ::MappingFE<dim, spacedim>::InternalData &data,
279 const unsigned int n_q_points)
281 const UpdateFlags update_flags = data.update_each;
284 for (
unsigned int point = 0; point < n_q_points; ++point)
286 const double *shape = &data.shape(point + data_set, 0);
288 (shape[0] * data.mapping_support_points[0]);
289 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
290 for (
unsigned int i = 0; i < spacedim; ++i)
291 result[i] += shape[k] * data.mapping_support_points[k][i];
292 quadrature_points[point] = result;
306 template <
int dim,
int spacedim>
308 maybe_update_Jacobians(
310 const typename ::QProjector<dim>::DataSetDescriptor data_set,
311 const typename ::MappingFE<dim, spacedim>::InternalData &data,
312 const unsigned int n_q_points)
314 const UpdateFlags update_flags = data.update_each;
322 std::fill(data.contravariant.begin(),
323 data.contravariant.end(),
328 for (
unsigned int point = 0; point < n_q_points; ++point)
330 double result[spacedim][dim];
334 for (
unsigned int i = 0; i < spacedim; ++i)
335 for (
unsigned int j = 0; j < dim; ++j)
336 result[i][j] = data.derivative(point + data_set, 0)[j] *
337 data.mapping_support_points[0][i];
338 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
339 for (
unsigned int i = 0; i < spacedim; ++i)
340 for (
unsigned int j = 0; j < dim; ++j)
342 data.derivative(point + data_set, k)[j] *
343 data.mapping_support_points[k][i];
350 for (
unsigned int i = 0; i < spacedim; ++i)
351 for (
unsigned int j = 0; j < dim; ++j)
352 data.contravariant[point][i][j] = result[i][j];
359 for (
unsigned int point = 0; point < n_q_points; ++point)
361 data.covariant[point] =
362 (data.contravariant[point]).covariant_form();
369 for (
unsigned int point = 0; point < n_q_points; ++point)
370 data.volume_elements[point] =
371 data.contravariant[point].determinant();
381 template <
int dim,
int spacedim>
383 maybe_update_jacobian_grads(
386 const typename ::MappingFE<dim, spacedim>::InternalData &data,
388 const unsigned int n_q_points)
390 const UpdateFlags update_flags = data.update_each;
396 for (
unsigned int point = 0; point < n_q_points; ++point)
399 &data.second_derivative(point + data_set, 0);
400 double result[spacedim][dim][dim];
401 for (
unsigned int i = 0; i < spacedim; ++i)
402 for (
unsigned int j = 0; j < dim; ++j)
403 for (
unsigned int l = 0; l < dim; ++l)
405 (second[0][j][l] * data.mapping_support_points[0][i]);
406 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
407 for (
unsigned int i = 0; i < spacedim; ++i)
408 for (
unsigned int j = 0; j < dim; ++j)
409 for (
unsigned int l = 0; l < dim; ++l)
412 data.mapping_support_points[k][i]);
414 for (
unsigned int i = 0; i < spacedim; ++i)
415 for (
unsigned int j = 0; j < dim; ++j)
416 for (
unsigned int l = 0; l < dim; ++l)
417 jacobian_grads[point][i][j][l] = result[i][j][l];
428 template <
int dim,
int spacedim>
430 maybe_update_jacobian_pushed_forward_grads(
433 const typename ::MappingFE<dim, spacedim>::InternalData &data,
435 const unsigned int n_q_points)
437 const UpdateFlags update_flags = data.update_each;
441 jacobian_pushed_forward_grads.size() + 1);
445 double tmp[spacedim][spacedim][spacedim];
446 for (
unsigned int point = 0; point < n_q_points; ++point)
449 &data.second_derivative(point + data_set, 0);
450 double result[spacedim][dim][dim];
451 for (
unsigned int i = 0; i < spacedim; ++i)
452 for (
unsigned int j = 0; j < dim; ++j)
453 for (
unsigned int l = 0; l < dim; ++l)
454 result[i][j][l] = (second[0][j][l] *
455 data.mapping_support_points[0][i]);
456 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
457 for (
unsigned int i = 0; i < spacedim; ++i)
458 for (
unsigned int j = 0; j < dim; ++j)
459 for (
unsigned int l = 0; l < dim; ++l)
462 data.mapping_support_points[k][i]);
465 for (
unsigned int i = 0; i < spacedim; ++i)
466 for (
unsigned int j = 0; j < spacedim; ++j)
467 for (
unsigned int l = 0; l < dim; ++l)
470 result[i][0][l] * data.covariant[point][j][0];
471 for (
unsigned int jr = 1; jr < dim; ++jr)
473 tmp[i][j][l] += result[i][jr][l] *
474 data.covariant[point][j][jr];
479 for (
unsigned int i = 0; i < spacedim; ++i)
480 for (
unsigned int j = 0; j < spacedim; ++j)
481 for (
unsigned int l = 0; l < spacedim; ++l)
483 jacobian_pushed_forward_grads[point][i][j][l] =
484 tmp[i][j][0] * data.covariant[point][l][0];
485 for (
unsigned int lr = 1; lr < dim; ++lr)
487 jacobian_pushed_forward_grads[point][i][j][l] +=
488 tmp[i][j][lr] * data.covariant[point][l][lr];
502 template <
int dim,
int spacedim>
504 maybe_update_jacobian_2nd_derivatives(
507 const typename ::MappingFE<dim, spacedim>::InternalData &data,
509 const unsigned int n_q_points)
511 const UpdateFlags update_flags = data.update_each;
518 for (
unsigned int point = 0; point < n_q_points; ++point)
521 &data.third_derivative(point + data_set, 0);
522 double result[spacedim][dim][dim][dim];
523 for (
unsigned int i = 0; i < spacedim; ++i)
524 for (
unsigned int j = 0; j < dim; ++j)
525 for (
unsigned int l = 0; l < dim; ++l)
526 for (
unsigned int m = 0; m < dim; ++m)
529 data.mapping_support_points[0][i]);
530 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
531 for (
unsigned int i = 0; i < spacedim; ++i)
532 for (
unsigned int j = 0; j < dim; ++j)
533 for (
unsigned int l = 0; l < dim; ++l)
534 for (
unsigned int m = 0; m < dim; ++m)
535 result[i][j][l][m] +=
537 data.mapping_support_points[k][i]);
539 for (
unsigned int i = 0; i < spacedim; ++i)
540 for (
unsigned int j = 0; j < dim; ++j)
541 for (
unsigned int l = 0; l < dim; ++l)
542 for (
unsigned int m = 0; m < dim; ++m)
543 jacobian_2nd_derivatives[point][i][j][l][m] =
557 template <
int dim,
int spacedim>
559 maybe_update_jacobian_pushed_forward_2nd_derivatives(
562 const typename ::MappingFE<dim, spacedim>::InternalData &data,
564 &jacobian_pushed_forward_2nd_derivatives,
565 const unsigned int n_q_points)
567 const UpdateFlags update_flags = data.update_each;
571 jacobian_pushed_forward_2nd_derivatives.size() +
576 double tmp[spacedim][spacedim][spacedim][spacedim];
577 for (
unsigned int point = 0; point < n_q_points; ++point)
580 &data.third_derivative(point + data_set, 0);
581 double result[spacedim][dim][dim][dim];
582 for (
unsigned int i = 0; i < spacedim; ++i)
583 for (
unsigned int j = 0; j < dim; ++j)
584 for (
unsigned int l = 0; l < dim; ++l)
585 for (
unsigned int m = 0; m < dim; ++m)
588 data.mapping_support_points[0][i]);
589 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
590 for (
unsigned int i = 0; i < spacedim; ++i)
591 for (
unsigned int j = 0; j < dim; ++j)
592 for (
unsigned int l = 0; l < dim; ++l)
593 for (
unsigned int m = 0; m < dim; ++m)
594 result[i][j][l][m] +=
596 data.mapping_support_points[k][i]);
599 for (
unsigned int i = 0; i < spacedim; ++i)
600 for (
unsigned int j = 0; j < spacedim; ++j)
601 for (
unsigned int l = 0; l < dim; ++l)
602 for (
unsigned int m = 0; m < dim; ++m)
604 jacobian_pushed_forward_2nd_derivatives
605 [point][i][j][l][m] =
607 data.covariant[point][j][0];
608 for (
unsigned int jr = 1; jr < dim; ++jr)
609 jacobian_pushed_forward_2nd_derivatives[point]
612 result[i][jr][l][m] *
613 data.covariant[point][j][jr];
617 for (
unsigned int i = 0; i < spacedim; ++i)
618 for (
unsigned int j = 0; j < spacedim; ++j)
619 for (
unsigned int l = 0; l < spacedim; ++l)
620 for (
unsigned int m = 0; m < dim; ++m)
623 jacobian_pushed_forward_2nd_derivatives[point]
626 data.covariant[point][l][0];
627 for (
unsigned int lr = 1; lr < dim; ++lr)
629 jacobian_pushed_forward_2nd_derivatives
630 [point][i][j][lr][m] *
631 data.covariant[point][l][lr];
635 for (
unsigned int i = 0; i < spacedim; ++i)
636 for (
unsigned int j = 0; j < spacedim; ++j)
637 for (
unsigned int l = 0; l < spacedim; ++l)
638 for (
unsigned int m = 0; m < spacedim; ++m)
640 jacobian_pushed_forward_2nd_derivatives
641 [point][i][j][l][m] =
642 tmp[i][j][l][0] * data.covariant[point][m][0];
643 for (
unsigned int mr = 1; mr < dim; ++mr)
644 jacobian_pushed_forward_2nd_derivatives[point]
648 data.covariant[point][m][mr];
661 template <
int dim,
int spacedim>
663 maybe_update_jacobian_3rd_derivatives(
666 const typename ::MappingFE<dim, spacedim>::InternalData &data,
668 const unsigned int n_q_points)
670 const UpdateFlags update_flags = data.update_each;
677 for (
unsigned int point = 0; point < n_q_points; ++point)
680 &data.fourth_derivative(point + data_set, 0);
681 double result[spacedim][dim][dim][dim][dim];
682 for (
unsigned int i = 0; i < spacedim; ++i)
683 for (
unsigned int j = 0; j < dim; ++j)
684 for (
unsigned int l = 0; l < dim; ++l)
685 for (
unsigned int m = 0; m < dim; ++m)
686 for (
unsigned int n = 0; n < dim; ++n)
687 result[i][j][l][m][n] =
688 (fourth[0][j][l][m][n] *
689 data.mapping_support_points[0][i]);
690 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
691 for (
unsigned int i = 0; i < spacedim; ++i)
692 for (
unsigned int j = 0; j < dim; ++j)
693 for (
unsigned int l = 0; l < dim; ++l)
694 for (
unsigned int m = 0; m < dim; ++m)
695 for (
unsigned int n = 0; n < dim; ++n)
696 result[i][j][l][m][n] +=
697 (fourth[k][j][l][m][n] *
698 data.mapping_support_points[k][i]);
700 for (
unsigned int i = 0; i < spacedim; ++i)
701 for (
unsigned int j = 0; j < dim; ++j)
702 for (
unsigned int l = 0; l < dim; ++l)
703 for (
unsigned int m = 0; m < dim; ++m)
704 for (
unsigned int n = 0; n < dim; ++n)
705 jacobian_3rd_derivatives[point][i][j][l][m][n] =
706 result[i][j][l][m][n];
719 template <
int dim,
int spacedim>
721 maybe_update_jacobian_pushed_forward_3rd_derivatives(
724 const typename ::MappingFE<dim, spacedim>::InternalData &data,
726 &jacobian_pushed_forward_3rd_derivatives,
727 const unsigned int n_q_points)
729 const UpdateFlags update_flags = data.update_each;
733 jacobian_pushed_forward_3rd_derivatives.size() +
738 double tmp[spacedim][spacedim][spacedim][spacedim][spacedim];
739 for (
unsigned int point = 0; point < n_q_points; ++point)
742 &data.fourth_derivative(point + data_set, 0);
743 double result[spacedim][dim][dim][dim][dim];
744 for (
unsigned int i = 0; i < spacedim; ++i)
745 for (
unsigned int j = 0; j < dim; ++j)
746 for (
unsigned int l = 0; l < dim; ++l)
747 for (
unsigned int m = 0; m < dim; ++m)
748 for (
unsigned int n = 0; n < dim; ++n)
749 result[i][j][l][m][n] =
750 (fourth[0][j][l][m][n] *
751 data.mapping_support_points[0][i]);
752 for (
unsigned int k = 1; k < data.n_shape_functions; ++k)
753 for (
unsigned int i = 0; i < spacedim; ++i)
754 for (
unsigned int j = 0; j < dim; ++j)
755 for (
unsigned int l = 0; l < dim; ++l)
756 for (
unsigned int m = 0; m < dim; ++m)
757 for (
unsigned int n = 0; n < dim; ++n)
758 result[i][j][l][m][n] +=
759 (fourth[k][j][l][m][n] *
760 data.mapping_support_points[k][i]);
763 for (
unsigned int i = 0; i < spacedim; ++i)
764 for (
unsigned int j = 0; j < spacedim; ++j)
765 for (
unsigned int l = 0; l < dim; ++l)
766 for (
unsigned int m = 0; m < dim; ++m)
767 for (
unsigned int n = 0; n < dim; ++n)
770 result[i][0][l][m][n] *
771 data.covariant[point][j][0];
772 for (
unsigned int jr = 1; jr < dim; ++jr)
773 tmp[i][j][l][m][n] +=
774 result[i][jr][l][m][n] *
775 data.covariant[point][j][jr];
779 for (
unsigned int i = 0; i < spacedim; ++i)
780 for (
unsigned int j = 0; j < spacedim; ++j)
781 for (
unsigned int l = 0; l < spacedim; ++l)
782 for (
unsigned int m = 0; m < dim; ++m)
783 for (
unsigned int n = 0; n < dim; ++n)
785 jacobian_pushed_forward_3rd_derivatives
786 [point][i][j][l][m][n] =
788 data.covariant[point][l][0];
789 for (
unsigned int lr = 1; lr < dim; ++lr)
790 jacobian_pushed_forward_3rd_derivatives
791 [point][i][j][l][m][n] +=
792 tmp[i][j][lr][m][n] *
793 data.covariant[point][l][lr];
797 for (
unsigned int i = 0; i < spacedim; ++i)
798 for (
unsigned int j = 0; j < spacedim; ++j)
799 for (
unsigned int l = 0; l < spacedim; ++l)
800 for (
unsigned int m = 0; m < spacedim; ++m)
801 for (
unsigned int n = 0; n < dim; ++n)
804 jacobian_pushed_forward_3rd_derivatives
805 [point][i][j][l][0][n] *
806 data.covariant[point][m][0];
807 for (
unsigned int mr = 1; mr < dim; ++mr)
808 tmp[i][j][l][m][n] +=
809 jacobian_pushed_forward_3rd_derivatives
810 [point][i][j][l][mr][n] *
811 data.covariant[point][m][mr];
815 for (
unsigned int i = 0; i < spacedim; ++i)
816 for (
unsigned int j = 0; j < spacedim; ++j)
817 for (
unsigned int l = 0; l < spacedim; ++l)
818 for (
unsigned int m = 0; m < spacedim; ++m)
819 for (
unsigned int n = 0; n < spacedim; ++n)
821 jacobian_pushed_forward_3rd_derivatives
822 [point][i][j][l][m][n] =
824 data.covariant[point][n][0];
825 for (
unsigned int nr = 1; nr < dim; ++nr)
826 jacobian_pushed_forward_3rd_derivatives
827 [point][i][j][l][m][n] +=
828 tmp[i][j][l][m][nr] *
829 data.covariant[point][n][nr];
841template <
int dim,
int spacedim>
847 ExcMessage(
"It only makes sense to create polynomial mappings "
848 "with a polynomial degree greater or equal to one."));
853 const auto &mapping_support_points =
fe.get_unit_support_points();
855 const auto reference_cell =
fe.reference_cell();
857 const unsigned int n_points = mapping_support_points.size();
858 const unsigned int n_shape_functions = reference_cell.n_vertices();
863 for (
unsigned int point = 0; point < n_points; ++point)
864 for (
unsigned int i = 0; i < n_shape_functions; ++i)
866 reference_cell.d_linear_shape_function(mapping_support_points[point],
872template <
int dim,
int spacedim>
881template <
int dim,
int spacedim>
882std::unique_ptr<Mapping<dim, spacedim>>
885 return std::make_unique<MappingFE<dim, spacedim>>(*this);
890template <
int dim,
int spacedim>
899template <
int dim,
int spacedim>
905 const std::vector<Point<spacedim>> support_points =
910 for (
unsigned int i = 0; i < this->
fe->n_dofs_per_cell(); ++i)
911 mapped_point += support_points[i] * this->
fe->shape_value(i, p);
918template <
int dim,
int spacedim>
924 const std::vector<Point<spacedim>> support_points =
927 const double eps = 1.e-12 * cell->
diameter();
928 const unsigned int loop_limit = 10;
932 unsigned int loop = 0;
948 for (
unsigned int i = 0; i < this->
fe->n_dofs_per_cell(); ++i)
950 mapped_point += support_points[i] * this->
fe->shape_value(i, p_unit);
951 const auto grad_F_i = this->
fe->shape_grad(i, p_unit);
952 const auto hessian_F_i = this->
fe->shape_grad_grad(i, p_unit);
953 for (
unsigned int j = 0; j < dim; ++j)
955 grad_FT[j] += grad_F_i[j] * support_points[i];
956 for (
unsigned int l = 0; l < dim; ++l)
957 hess_FT[j][l] += hessian_F_i[j][l] * support_points[i];
962 const auto residual = p - mapped_point;
969 if (grad_FT_residual.norm() <= eps)
974 for (
unsigned int j = 0; j < dim; ++j)
975 for (
unsigned int l = 0; l < dim; ++l)
976 corrected_metric_tensor[j][l] =
977 -grad_FT[j] * grad_FT[l] + hess_FT[j][l] * residual;
980 const auto g_inverse =
invert(corrected_metric_tensor);
981 p_unit -=
Point<dim>(g_inverse * grad_FT_residual);
985 while (loop < loop_limit);
999template <
int dim,
int spacedim>
1009 UpdateFlags out = in;
1010 for (
unsigned int i = 0; i < 5; ++i)
1055template <
int dim,
int spacedim>
1056std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
1060 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase> data_ptr =
1061 std::make_unique<InternalData>(*this->
fe);
1068template <
int dim,
int spacedim>
1069std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
1071 const UpdateFlags update_flags,
1074 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase> data_ptr =
1075 std::make_unique<InternalData>(*this->
fe);
1079 this->
fe->reference_cell(), quadrature),
1087template <
int dim,
int spacedim>
1088std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
1090 const UpdateFlags update_flags,
1093 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase> data_ptr =
1094 std::make_unique<InternalData>(*this->
fe);
1098 this->
fe->reference_cell(), quadrature),
1106template <
int dim,
int spacedim>
1121 const unsigned int n_q_points = quadrature.
size();
1143 internal::MappingFEImplementation::maybe_compute_q_points<dim, spacedim>(
1149 internal::MappingFEImplementation::maybe_update_Jacobians<dim, spacedim>(
1150 computed_cell_similarity,
1155 internal::MappingFEImplementation::maybe_update_jacobian_grads<dim, spacedim>(
1156 computed_cell_similarity,
1162 internal::MappingFEImplementation::maybe_update_jacobian_pushed_forward_grads<
1164 spacedim>(computed_cell_similarity,
1170 internal::MappingFEImplementation::maybe_update_jacobian_2nd_derivatives<
1172 spacedim>(computed_cell_similarity,
1178 internal::MappingFEImplementation::
1179 maybe_update_jacobian_pushed_forward_2nd_derivatives<dim, spacedim>(
1180 computed_cell_similarity,
1186 internal::MappingFEImplementation::maybe_update_jacobian_3rd_derivatives<
1188 spacedim>(computed_cell_similarity,
1194 internal::MappingFEImplementation::
1195 maybe_update_jacobian_pushed_forward_3rd_derivatives<dim, spacedim>(
1196 computed_cell_similarity,
1202 const UpdateFlags update_flags = data.
update_each;
1203 const std::vector<double> &weights = quadrature.
get_weights();
1219 for (
unsigned int point = 0; point < n_q_points; ++point)
1221 if (dim == spacedim)
1234 cell->
center(), det, point)));
1236 output_data.
JxW_values[point] = weights[point] * det;
1244 for (
unsigned int i = 0; i < spacedim; ++i)
1245 for (
unsigned int j = 0; j < dim; ++j)
1249 for (
unsigned int i = 0; i < dim; ++i)
1250 for (
unsigned int j = 0; j < dim; ++j)
1251 G[i][j] = DX_t[i] * DX_t[j];
1256 if (computed_cell_similarity ==
1267 Assert(spacedim == dim + 1,
1269 "There is no (unique) cell normal for " +
1271 "-dimensional cells in " +
1273 "-dimensional space. This only works if the "
1274 "space dimension is one greater than the "
1275 "dimensionality of the mesh cells."));
1302 for (
unsigned int point = 0; point < n_q_points; ++point)
1311 for (
unsigned int point = 0; point < n_q_points; ++point)
1316 return computed_cell_similarity;
1323 namespace MappingFEImplementation
1337 template <
int dim,
int spacedim>
1339 maybe_compute_face_data(
1340 const ::MappingFE<dim, spacedim> &
mapping,
1341 const typename ::Triangulation<dim, spacedim>::cell_iterator
1343 const unsigned int face_no,
1344 const unsigned int subface_no,
1345 const unsigned int n_q_points,
1347 const typename ::MappingFE<dim, spacedim>::InternalData &data,
1351 const UpdateFlags update_flags = data.update_each;
1374 for (
unsigned int d = 0; d != dim - 1; ++d)
1376 Assert(face_no + cell->n_faces() * d <
1377 data.unit_tangentials.size(),
1380 data.aux[d].size() <=
1381 data.unit_tangentials[face_no + cell->n_faces() * d].size(),
1386 data.unit_tangentials[face_no + cell->n_faces() * d]),
1397 if (dim == spacedim)
1399 for (
unsigned int i = 0; i < n_q_points; ++i)
1409 (face_no == 0 ? -1 : +1);
1433 for (
unsigned int point = 0;
point < n_q_points; ++
point)
1439 data.contravariant[
point].transpose()[0];
1441 (face_no == 0 ? -1. : +1.) *
1447 const DerivativeForm<1, spacedim, dim> DX_t =
1448 data.contravariant[
point].transpose();
1450 Tensor<1, spacedim> cell_normal =
1452 cell_normal /= cell_normal.
norm();
1464 for (
unsigned int i = 0; i < n_q_points; ++i)
1468 data.quadrature_weights[i + data_set];
1474 const double area_ratio =
1475 1. / cell->reference_cell()
1476 .face_reference_cell(face_no)
1477 .n_isotropic_children();
1486 for (
unsigned int i = 0; i < n_q_points; ++i)
1492 for (
unsigned int point = 0;
point < n_q_points; ++
point)
1493 output_data.
jacobians[point] = data.contravariant[point];
1496 for (
unsigned int point = 0;
point < n_q_points; ++
point)
1498 data.covariant[point].transpose();
1509 template <
int dim,
int spacedim>
1512 const ::MappingFE<dim, spacedim> &
mapping,
1513 const typename ::Triangulation<dim, spacedim>::cell_iterator
1515 const unsigned int face_no,
1516 const unsigned int subface_no,
1517 const typename QProjector<dim>::DataSetDescriptor data_set,
1518 const Quadrature<dim - 1> &quadrature,
1519 const typename ::MappingFE<dim, spacedim>::InternalData &data,
1520 internal::FEValuesImplementation::MappingRelatedData<dim, spacedim>
1523 const unsigned int n_q_points = quadrature.
size();
1525 maybe_compute_q_points<dim, spacedim>(data_set,
1538 maybe_update_jacobian_pushed_forward_grads<dim, spacedim>(
1544 maybe_update_jacobian_2nd_derivatives<dim, spacedim>(
1550 maybe_update_jacobian_pushed_forward_2nd_derivatives<dim, spacedim>(
1556 maybe_update_jacobian_3rd_derivatives<dim, spacedim>(
1562 maybe_update_jacobian_pushed_forward_3rd_derivatives<dim, spacedim>(
1584template <
int dim,
int spacedim>
1588 const unsigned int face_no,
1612 internal::MappingFEImplementation::do_fill_fe_face_values(
1622 quadrature[quadrature.
size() == 1 ? 0 : face_no],
1629template <
int dim,
int spacedim>
1633 const unsigned int face_no,
1634 const unsigned int subface_no,
1658 internal::MappingFEImplementation::do_fill_fe_face_values(
1679 namespace MappingFEImplementation
1683 template <
int dim,
int spacedim,
int rank>
1700 const typename ::MappingFE<dim, spacedim>::InternalData *
>(
1701 &mapping_data) !=
nullptr),
1703 const typename ::MappingFE<dim, spacedim>::InternalData &data =
1705 const typename ::MappingFE<dim, spacedim>::InternalData &
>(
1708 switch (mapping_kind)
1715 "update_contravariant_transformation"));
1717 for (
unsigned int i = 0; i < input.size(); ++i)
1729 "update_contravariant_transformation"));
1733 "update_volume_elements"));
1738 for (
unsigned int i = 0; i < input.size(); ++i)
1742 output[i] /= data.volume_elements[i];
1754 "update_covariant_transformation"));
1756 for (
unsigned int i = 0; i < input.size(); ++i)
1768 template <
int dim,
int spacedim,
int rank>
1771 const ArrayView<
const Tensor<rank, dim>> &input,
1773 const typename Mapping<dim, spacedim>::InternalDataBase &mapping_data,
1774 const ArrayView<Tensor<rank, spacedim>> &output)
1779 const typename ::MappingFE<dim, spacedim>::InternalData *
>(
1780 &mapping_data) !=
nullptr),
1782 const typename ::MappingFE<dim, spacedim>::InternalData &data =
1784 const typename ::MappingFE<dim, spacedim>::InternalData &
>(
1787 switch (mapping_kind)
1794 "update_covariant_transformation"));
1798 "update_contravariant_transformation"));
1801 for (
unsigned int i = 0; i < output.size(); ++i)
1803 const DerivativeForm<1, spacedim, dim>
A =
1818 "update_covariant_transformation"));
1821 for (
unsigned int i = 0; i < output.size(); ++i)
1823 const DerivativeForm<1, spacedim, dim>
A =
1838 "update_covariant_transformation"));
1842 "update_contravariant_transformation"));
1846 "update_volume_elements"));
1849 for (
unsigned int i = 0; i < output.size(); ++i)
1851 const DerivativeForm<1, spacedim, dim>
A =
1853 const Tensor<2, spacedim>
T =
1858 output[i] /= data.volume_elements[i];
1871 template <
int dim,
int spacedim>
1874 const ArrayView<
const Tensor<3, dim>> &input,
1876 const typename Mapping<dim, spacedim>::InternalDataBase &mapping_data,
1877 const ArrayView<Tensor<3, spacedim>> &output)
1882 const typename ::MappingFE<dim, spacedim>::InternalData *
>(
1883 &mapping_data) !=
nullptr),
1885 const typename ::MappingFE<dim, spacedim>::InternalData &data =
1887 const typename ::MappingFE<dim, spacedim>::InternalData &
>(
1890 switch (mapping_kind)
1897 "update_covariant_transformation"));
1901 "update_contravariant_transformation"));
1903 for (
unsigned int q = 0; q < output.size(); ++q)
1906 data.contravariant[q],
1917 "update_covariant_transformation"));
1919 for (
unsigned int q = 0; q < output.size(); ++q)
1932 "update_covariant_transformation"));
1936 "update_contravariant_transformation"));
1940 "update_volume_elements"));
1942 for (
unsigned int q = 0; q < output.size(); ++q)
1945 data.contravariant[q],
1946 data.volume_elements[q],
1959 template <
int dim,
int spacedim,
int rank>
1962 const ArrayView<
const DerivativeForm<rank, dim, spacedim>> &input,
1964 const typename Mapping<dim, spacedim>::InternalDataBase &mapping_data,
1965 const ArrayView<Tensor<rank + 1, spacedim>> &output)
1970 const typename ::MappingFE<dim, spacedim>::InternalData *
>(
1971 &mapping_data) !=
nullptr),
1973 const typename ::MappingFE<dim, spacedim>::InternalData &data =
1975 const typename ::MappingFE<dim, spacedim>::InternalData &
>(
1978 switch (mapping_kind)
1985 "update_covariant_transformation"));
1987 for (
unsigned int i = 0; i < output.size(); ++i)
2002template <
int dim,
int spacedim>
2006 const MappingKind mapping_kind,
2010 internal::MappingFEImplementation::transform_fields(input,
2018template <
int dim,
int spacedim>
2022 const MappingKind mapping_kind,
2026 internal::MappingFEImplementation::transform_differential_forms(input,
2034template <
int dim,
int spacedim>
2038 const MappingKind mapping_kind,
2042 switch (mapping_kind)
2045 internal::MappingFEImplementation::transform_fields(input,
2054 internal::MappingFEImplementation::transform_gradients(input,
2066template <
int dim,
int spacedim>
2070 const MappingKind mapping_kind,
2079 switch (mapping_kind)
2085 "update_covariant_transformation"));
2087 for (
unsigned int q = 0; q < output.size(); ++q)
2101template <
int dim,
int spacedim>
2105 const MappingKind mapping_kind,
2109 switch (mapping_kind)
2114 internal::MappingFEImplementation::transform_hessians(input,
2128 template <
int spacedim>
2130 check_all_manifold_ids_identical(
2138 template <
int spacedim>
2140 check_all_manifold_ids_identical(
2143 const auto m_id = cell->manifold_id();
2145 for (
const auto f : cell->face_indices())
2146 if (m_id != cell->face(f)->manifold_id())
2154 template <
int spacedim>
2156 check_all_manifold_ids_identical(
2159 const auto m_id = cell->manifold_id();
2161 for (
const auto f : cell->face_indices())
2162 if (m_id != cell->face(f)->manifold_id())
2165 for (
const auto l : cell->line_indices())
2166 if (m_id != cell->line(l)->manifold_id())
2175template <
int dim,
int spacedim>
2176std::vector<Point<spacedim>>
2180 std::vector<Point<spacedim>> mapping_support_points(
2181 fe->get_unit_support_points().size());
2183 std::vector<Point<spacedim>> vertices(cell->
n_vertices());
2185 vertices[i] = cell->
vertex(i);
2187 if (check_all_manifold_ids_identical(cell))
2193 mapping_support_points);
2204 const auto process = [&](
const auto &manifold,
2205 const auto &indices,
2206 const unsigned n_points) {
2207 if ((indices.size() == 0) || (n_points == 0))
2210 const unsigned int n_shape_functions =
2211 this->
fe->reference_cell().n_vertices();
2215 std::vector<Point<spacedim>> mapping_support_points_local(n_points);
2217 for (
unsigned int p = 0; p < n_points; ++p)
2218 for (
unsigned int i = 0; i < n_shape_functions; ++i)
2219 mapping_support_point_weights_local(p, i) =
2221 indices[p + (indices.size() - n_points)], i);
2223 manifold.get_new_points(vertices,
2224 mapping_support_point_weights_local,
2225 mapping_support_points_local);
2227 for (
unsigned int p = 0; p < n_points; ++p)
2228 mapping_support_points[indices[p + (indices.size() - n_points)]] =
2229 mapping_support_points_local[p];
2233 const auto &
fe = *this->
fe;
2240 std::vector<types::global_dof_index> indices;
2244 mapping_support_points[i] = cell->
vertex(i);
2247 for (
unsigned int l = 0; l < cell_ref->n_lines(); ++l)
2249 const auto accessor = cell_ref->line(l);
2250 indices.resize(
fe.n_dofs_per_line() + 2 *
fe.n_dofs_per_vertex());
2251 accessor->get_dof_indices(indices);
2252 process(cell->
line(l)->get_manifold(), indices,
fe.n_dofs_per_line());
2256 if constexpr (dim >= 3)
2258 for (
unsigned int f = 0; f < cell_ref->n_faces(); ++f)
2260 const auto accessor = cell_ref->face(f);
2261 indices.resize(
fe.n_dofs_per_face());
2262 accessor->get_dof_indices(indices);
2263 process(cell->
face(f)->get_manifold(),
2265 fe.n_dofs_per_quad());
2270 if constexpr (dim >= 2)
2272 indices.resize(
fe.n_dofs_per_cell());
2273 cell_ref->get_dof_indices(indices);
2276 (dim == 2) ?
fe.n_dofs_per_quad() :
fe.n_dofs_per_hex());
2280 return mapping_support_points;
2285template <
int dim,
int spacedim>
2295template <
int dim,
int spacedim>
2300 Assert(dim == reference_cell.get_dimension(),
2301 ExcMessage(
"The dimension of your mapping (" +
2303 ") and the reference cell cell_type (" +
2305 " ) do not agree."));
2307 return fe->reference_cell() == reference_cell;
2313#include "fe/mapping_fe.inst"
ArrayView< std::remove_reference_t< typename std::iterator_traits< Iterator >::reference >, MemorySpaceType > make_array_view(const Iterator begin, const Iterator end)
internal::SubfaceCase< dim > subface_case(const unsigned int face_no) const
double diameter(const Mapping< dim, spacedim > &mapping) const
TriaIterator< TriaAccessor< dim - 1, dim, spacedim > > face(const unsigned int i) const
bool direction_flag() const
void distribute_dofs(const FiniteElement< dim, spacedim > &fe)
active_cell_iterator begin_active(const unsigned int level=0) const
virtual void get_new_points(const ArrayView< const Point< spacedim > > &surrounding_points, const Table< 2, double > &weights, ArrayView< Point< spacedim > > new_points) const
const Tensor< 3, dim > & third_derivative(const unsigned int qpoint, const unsigned int shape_nr) const
void initialize_face(const UpdateFlags update_flags, const Quadrature< dim > &quadrature, const unsigned int n_original_q_points)
std::vector< Point< spacedim > > mapping_support_points
const Tensor< 4, dim > & fourth_derivative(const unsigned int qpoint, const unsigned int shape_nr) const
std::vector< std::vector< Tensor< 1, spacedim > > > aux
std::vector< Tensor< 3, dim > > shape_third_derivatives
std::vector< Tensor< 2, dim > > shape_second_derivatives
std::vector< Tensor< 4, dim > > shape_fourth_derivatives
Triangulation< dim, spacedim >::cell_iterator cell_of_current_support_points
void compute_shape_function_values(const std::vector< Point< dim > > &unit_points)
std::array< std::vector< Tensor< 1, dim > >, ReferenceCells::max_n_faces< dim >() *2 > unit_tangentials
std::vector< double > quadrature_weights
const FiniteElement< dim, spacedim > & fe
std::vector< DerivativeForm< 1, dim, spacedim > > contravariant
std::vector< DerivativeForm< 1, dim, spacedim > > covariant
const Tensor< 1, dim > & derivative(const unsigned int qpoint, const unsigned int shape_nr) const
std::vector< double > shape_values
std::vector< Tensor< 1, dim > > shape_derivatives
virtual std::size_t memory_consumption() const override
const Tensor< 2, dim > & second_derivative(const unsigned int qpoint, const unsigned int shape_nr) const
InternalData(const FiniteElement< dim, spacedim > &fe)
const unsigned int n_shape_functions
std::vector< double > volume_elements
const double & shape(const unsigned int qpoint, const unsigned int shape_nr) const
virtual void reinit(const UpdateFlags update_flags, const Quadrature< dim > &quadrature) override
const unsigned int polynomial_degree
virtual CellSimilarity::Similarity fill_fe_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const CellSimilarity::Similarity cell_similarity, const Quadrature< dim > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
const unsigned int polynomial_degree
MappingFE(const FiniteElement< dim, spacedim > &fe)
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags flags, const hp::QCollection< dim - 1 > &quadrature) const override
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const override
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
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 typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
Table< 2, double > mapping_support_point_weights
virtual std::vector< Point< spacedim > > compute_mapping_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const
virtual void transform(const ArrayView< const Tensor< 1, dim > > &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 1, spacedim > > &output) const override
virtual BoundingBox< spacedim > get_bounding_box(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags, const Quadrature< dim > &quadrature) const override
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags flags, const Quadrature< dim - 1 > &quadrature) const override
unsigned int get_degree() const
virtual bool is_compatible_with(const ReferenceCell &reference_cell) const override
virtual void fill_fe_subface_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int subface_no, const Quadrature< dim - 1 > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const override
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const override
const std::unique_ptr< FiniteElement< dim, spacedim > > fe
virtual std::size_t memory_consumption() const
Class storing the offset index into a Quadrature rule created by project_to_all_faces() or project_to...
static DataSetDescriptor subface(const ReferenceCell &reference_cell, const unsigned int face_no, const unsigned int subface_no, const bool face_orientation, const bool face_flip, const bool face_rotation, const unsigned int n_quadrature_points, const internal::SubfaceCase< dim > ref_case=internal::SubfaceCase< dim >::case_isotropic)
static DataSetDescriptor cell()
static DataSetDescriptor face(const ReferenceCell &reference_cell, const unsigned int face_no, const bool face_orientation, const bool face_flip, const bool face_rotation, const unsigned int n_quadrature_points)
static Quadrature< dim > project_to_all_subfaces(const ReferenceCell &reference_cell, const SubQuadrature &quadrature)
static Quadrature< dim > project_to_all_faces(const ReferenceCell &reference_cell, const hp::QCollection< dim - 1 > &quadrature)
const std::vector< double > & get_weights() const
const std::vector< Point< dim > > & get_points() const
unsigned int size() const
numbers::NumberTraits< Number >::real_type norm() const
const Triangulation< dim, spacedim > & get_triangulation() const
std_cxx20::ranges::iota_view< unsigned int, unsigned int > vertex_indices() const
const Manifold< dim, spacedim > & get_manifold() const
unsigned int n_vertices() const
Point< spacedim > center(const bool respect_manifold=false, const bool interpolate_from_surrounding=false) const
Point< spacedim > & vertex(const unsigned int i) const
typename::internal::TriangulationImplementation::Iterators< dim, spacedim >::line_iterator line(const unsigned int i) const
Triangulation< dim, spacedim > & get_triangulation()
unsigned int size() const
unsigned int max_n_quadrature_points() const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_NOT_IMPLEMENTED()
static ::ExceptionBase & ExcAccessToUninitializedField(std::string arg1)
static ::ExceptionBase & ExcDistortedMappedCell(Point< spacedim > arg1, double arg2, int arg3)
static ::ExceptionBase & ExcTransformationFailed()
static ::ExceptionBase & ExcNotImplemented()
#define Assert(cond, exc)
#define AssertDimension(dim1, dim2)
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcInternalError()
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
static ::ExceptionBase & ExcMessage(std::string arg1)
#define AssertThrow(cond, exc)
TriaIterator< CellAccessor< dim, spacedim > > cell_iterator
@ update_jacobian_pushed_forward_2nd_derivatives
@ update_volume_elements
Determinant of the Jacobian.
@ update_contravariant_transformation
Contravariant transformation.
@ update_jacobian_pushed_forward_grads
@ update_jacobian_3rd_derivatives
@ update_jacobian_grads
Gradient of volume element.
@ update_normal_vectors
Normal vectors.
@ update_JxW_values
Transformed quadrature weights.
@ update_covariant_transformation
Covariant transformation.
@ update_jacobians
Volume element.
@ update_inverse_jacobians
Volume element.
@ update_quadrature_points
Transformed quadrature points.
@ update_jacobian_pushed_forward_3rd_derivatives
@ update_boundary_forms
Outer normal vector, not normalized.
@ update_jacobian_2nd_derivatives
@ mapping_covariant_gradient
@ mapping_contravariant_hessian
@ mapping_covariant_hessian
@ mapping_contravariant_gradient
types::geometric_orientation combined_face_orientation(const unsigned int face) const
MappingQ< dim, spacedim > StaticMappingQ1< dim, spacedim >::mapping
void reference_cell(Triangulation< dim, spacedim > &tria, const ReferenceCell &reference_cell)
std::enable_if_t< std::is_fundamental_v< T >, std::size_t > memory_consumption(const T &t)
Point< spacedim > point(const gp_Pnt &p, const double tolerance=1e-10)
constexpr T fixed_power(const T t)
std::string to_string(const number value, const unsigned int digits=numbers::invalid_unsigned_int)
std::string int_to_string(const unsigned int value, const unsigned int digits=numbers::invalid_unsigned_int)
void transform_differential_forms(const ArrayView< const DerivativeForm< rank, dim, spacedim > > &input, const MappingKind mapping_kind, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_data, const ArrayView< Tensor< rank+1, spacedim > > &output)
void do_fill_fe_face_values(const ::MappingQ< dim, spacedim > &mapping, const typename ::Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int subface_no, const typename QProjector< dim >::DataSetDescriptor data_set, const Quadrature< dim - 1 > &quadrature, const typename ::MappingQ< dim, spacedim >::InternalData &data, const std::vector< Polynomials::Polynomial< double > > &polynomials_1d, const std::vector< unsigned int > &renumber_lexicographic_to_hierarchic, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data)
void transform_gradients(const ArrayView< const Tensor< rank, dim > > &input, const MappingKind mapping_kind, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_data, const ArrayView< Tensor< rank, spacedim > > &output)
void transform_hessians(const ArrayView< const Tensor< 3, dim > > &input, const MappingKind mapping_kind, const typename Mapping< dim, spacedim >::InternalDataBase &mapping_data, const ArrayView< Tensor< 3, spacedim > > &output)
void maybe_compute_face_data(const ::MappingQ< dim, spacedim > &mapping, const typename ::Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int subface_no, const unsigned int n_q_points, const std::vector< double > &weights, const typename ::MappingQ< dim, spacedim >::InternalData &data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data)
Tensor< 3, spacedim, Number > apply_contravariant_hessian(const DerivativeForm< 1, dim, spacedim, Number > &covariant, const DerivativeForm< 1, dim, spacedim, Number > &contravariant, const Tensor< 3, dim, Number > &input)
Tensor< 3, spacedim, Number > apply_piola_hessian(const DerivativeForm< 1, dim, spacedim, Number > &covariant, const DerivativeForm< 1, dim, spacedim, Number > &contravariant, const Number &volume_element, const Tensor< 3, dim, Number > &input)
Tensor< 3, spacedim, Number > apply_covariant_gradient(const DerivativeForm< 1, dim, spacedim, Number > &covariant, const DerivativeForm< 2, dim, spacedim, Number > &input)
Tensor< 3, spacedim, Number > apply_covariant_hessian(const DerivativeForm< 1, dim, spacedim, Number > &covariant, const Tensor< 3, dim, Number > &input)
constexpr unsigned int invalid_unsigned_int
::VectorizedArray< Number, width > sqrt(const ::VectorizedArray< Number, width > &)
DEAL_II_HOST constexpr Number determinant(const SymmetricTensor< 2, dim, Number > &)
DEAL_II_HOST constexpr SymmetricTensor< 2, dim, Number > invert(const SymmetricTensor< 2, dim, Number > &)
constexpr Tensor< 1, dim, Number > cross_product_2d(const Tensor< 1, dim, Number > &src)
constexpr Tensor< 1, dim, typename ProductType< Number1, Number2 >::type > cross_product_3d(const Tensor< 1, dim, Number1 > &src1, const Tensor< 1, dim, Number2 > &src2)