358 {
360
365
367
368
369 const size_t nb_gauss_pts = DomainEleOp::getGaussPts().size2();
370 auto t_D = getFTensor4DdgFromMat<DIM, DIM, S>(*
commonDataPtr->matDPtr);
371 auto t_logC = getFTensor2SymmetricFromMat<DIM>(
commonDataPtr->matLogC);
372 auto t_logC_dC = getFTensor4DdgFromMat<DIM, DIM>(
commonDataPtr->matLogCdC);
373 constexpr auto size_symm = (DIM * (DIM + 1)) / 2;
375 commonDataPtr->matFirstPiolaStress.resize(DIM * DIM, nb_gauss_pts,
false);
377 auto t_T = getFTensor2SymmetricFromMat<DIM>(
commonDataPtr->matHenckyStress);
378 auto t_P = getFTensor2FromMat<DIM, DIM>(
commonDataPtr->matFirstPiolaStress);
379 auto t_S =
380 getFTensor2SymmetricFromMat<DIM>(
commonDataPtr->matSecondPiolaStress);
381 auto t_grad = getFTensor2FromMat<DIM, DIM>(*(
commonDataPtr->matGradPtr));
382 auto t_temp = getFTensor0FromVec(*
tempPtr);
383
385 t_coeff_exp(
i,
j) = 0;
387 t_coeff_exp(d, d) = (*coeffExpansionPtr)[
d];
388 }
389
390 for (size_t gg = 0; gg != nb_gauss_pts; ++gg) {
391#ifdef HENCKY_SMALL_STRAIN
392 t_P(
i,
j) = t_D(
i,
j,
k,
l) *
393 (t_grad(
k,
l) - t_coeff_exp(
k,
l) * (t_temp - (*refTempPtr)));
394#else
395 t_T(
i,
j) = t_D(
i,
j,
k,
l) *
396 (t_logC(
k,
l) - t_coeff_exp(
k,
l) * (t_temp - (*refTempPtr)));
399 t_S(
k,
l) = t_T(
i,
j) * t_logC_dC(
i,
j,
k,
l);
400 t_P(
i,
l) = t_F(
i,
k) * t_S(
k,
l);
401#endif
402 ++t_grad;
403 ++t_logC;
404 ++t_logC_dC;
405 ++t_P;
406 ++t_T;
407 ++t_S;
408 ++t_D;
409 ++t_temp;
410 }
411
constexpr int SPACE_DIM
[Define dimension]
#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