357 {
359
364
366
367
368 const size_t nb_gauss_pts = DomainEleOp::getGaussPts().size2();
369 auto t_D = getFTensor4DdgFromMat<DIM, DIM, S>(*
commonDataPtr->matDPtr);
370 auto t_logC = getFTensor2SymmetricFromMat<DIM>(
commonDataPtr->matLogC);
371 auto t_logC_dC = getFTensor4DdgFromMat<DIM, DIM>(
commonDataPtr->matLogCdC);
372 constexpr auto size_symm = (DIM * (DIM + 1)) / 2;
374 commonDataPtr->matFirstPiolaStress.resize(DIM * DIM, nb_gauss_pts,
false);
376 auto t_T = getFTensor2SymmetricFromMat<DIM>(
commonDataPtr->matHenckyStress);
377 auto t_P = getFTensor2FromMat<DIM, DIM>(
commonDataPtr->matFirstPiolaStress);
378 auto t_S =
379 getFTensor2SymmetricFromMat<DIM>(
commonDataPtr->matSecondPiolaStress);
380 auto t_grad = getFTensor2FromMat<DIM, DIM>(*(
commonDataPtr->matGradPtr));
381 auto t_temp = getFTensor0FromVec(*
tempPtr);
382
384 t_coeff_exp(
i,
j) = 0;
386 t_coeff_exp(d, d) = (*coeffExpansionPtr)[
d];
387 }
388
389 for (size_t gg = 0; gg != nb_gauss_pts; ++gg) {
390#ifdef HENCKY_SMALL_STRAIN
391 t_P(
i,
j) = t_D(
i,
j,
k,
l) *
392 (t_grad(
k,
l) - t_coeff_exp(
k,
l) * (t_temp - (*refTempPtr)));
393#else
394 t_T(
i,
j) = t_D(
i,
j,
k,
l) *
395 (t_logC(
k,
l) - t_coeff_exp(
k,
l) * (t_temp - (*refTempPtr)));
398 t_S(
k,
l) = t_T(
i,
j) * t_logC_dC(
i,
j,
k,
l);
399 t_P(
i,
l) = t_F(
i,
k) * t_S(
k,
l);
400#endif
401 ++t_grad;
402 ++t_logC;
403 ++t_logC_dC;
404 ++t_P;
405 ++t_T;
406 ++t_S;
407 ++t_D;
408 ++t_temp;
409 }
410
412 }
#define MoFEMFunctionBegin
First executable line of each MoFEM function, used for error handling. Final line of MoFEM functions ...
#define MoFEMFunctionReturn(a)
Last executable line of each PETSc function used for error handling. Replaces return()
FTensor::Index< 'i', SPACE_DIM > i
FTensor::Index< 'l', 3 > l
FTensor::Index< 'j', 3 > j
FTensor::Index< 'k', 3 > k