88 if (
auto data_ptr =
dataPtr.lock()) {
90 const auto nb_eval_points = data_ptr->nbEvalPoints;
91 const auto &shape_functions = data_ptr->shapeFunctions;
92 const auto &eval_pointentity_handle = data_ptr->evalPointEntityHandle;
94 if (
auto fe_ptr = data_ptr->feMethodPtr.lock()) {
96 auto &fe =
static_cast<ForcesAndSourcesCore &
>(*fe_ptr);
99 if (fe_ptr.get() != fe_raw_ptr)
103 const auto fe_ent = fe.numeredEntFiniteElementPtr->getEnt();
105 const auto fe_dim = moab::CN::Dimension(fe_type);
107 auto &gauss_pts = fe.gaussPts;
111 gauss_pts.resize(4, nb_eval_points,
false);
113 &shape_functions(0, 0), &shape_functions(0, 1),
114 &shape_functions(0, 2), &shape_functions(0, 3)};
116 &gauss_pts(0, 0), &gauss_pts(1, 0), &gauss_pts(2, 0)};
119 for (
int nn = 0; nn != nb_eval_points; ++nn) {
120 if (eval_pointentity_handle[nn] == fe_ent) {
121 for (
const int i : {0, 1, 2}) {
122 t_gauss_pts(
i) = t_shape(
i + 1);
124 gauss_pts(3, nb_gauss_pts) = nn;
130 gauss_pts.resize(4, nb_gauss_pts,
true);
131 }
else if (fe_dim == 2) {
132 gauss_pts.resize(3, nb_eval_points,
false);
134 &shape_functions(0, 0), &shape_functions(0, 1),
135 &shape_functions(0, 2)};
137 &gauss_pts(0, 0), &gauss_pts(1, 0)};
139 for (
int nn = 0; nn != nb_eval_points; ++nn) {
140 if (eval_pointentity_handle[nn] == fe_ent) {
141 for (
const int i : {0, 1}) {
142 t_gauss_pts(
i) = t_shape(
i + 1);
144 gauss_pts(2, nb_gauss_pts) = nn;
150 gauss_pts.resize(3, nb_gauss_pts,
true);
153 "Dimension not implemented");
158 <<
"nbEvalOPoints / nbGau_sspt_s: " << nb_eval_points <<
" / "
160 MOFEM_LOG(
"SELF", Sev::noisy) <<
"gauss pts: " << gauss_pts;
165 "Pointer to element does not exists");
169 "Pointer to data does not exists");