v0.16.0
Loading...
Searching...
No Matches
Public Member Functions | Private Attributes | List of all members
HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S > Struct Template Reference

#include "tutorials/vec-2_nonlinear_elasticity/src/HenckyOps.hpp"

Inheritance diagram for HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >:
[legend]
Collaboration diagram for HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >:
[legend]

Public Member Functions

 OpCalculateHenckyThermalStressdTImpl (const std::string row_field_name, const std::string col_field_name, boost::shared_ptr< CommonData > elastic_common_data_ptr, boost::shared_ptr< VectorDouble > coeff_expansion_ptr)
 
MoFEMErrorCode iNtegrate (EntitiesFieldData::EntData &row_data, EntitiesFieldData::EntData &col_data)
 
 OpCalculateHenckyThermalStressdTImpl (const std::string row_field_name, const std::string col_field_name, boost::shared_ptr< CommonData > elastic_common_data_ptr, boost::shared_ptr< VectorDouble > coeff_expansion_ptr)
 
MoFEMErrorCode iNtegrate (EntitiesFieldData::EntData &row_data, EntitiesFieldData::EntData &col_data)
 

Private Attributes

boost::shared_ptr< CommonDataelasticCommonDataPtr
 
boost::shared_ptr< VectorDouble > coeffExpansionPtr
 

Detailed Description

template<int DIM, typename AssemblyDomainEleOp, int S>
struct HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >

Definition at line 629 of file HenckyOps.hpp.

Constructor & Destructor Documentation

◆ OpCalculateHenckyThermalStressdTImpl() [1/2]

template<int DIM, typename AssemblyDomainEleOp , int S>
HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >::OpCalculateHenckyThermalStressdTImpl ( const std::string  row_field_name,
const std::string  col_field_name,
boost::shared_ptr< CommonData elastic_common_data_ptr,
boost::shared_ptr< VectorDouble >  coeff_expansion_ptr 
)

Definition at line 645 of file HenckyOps.hpp.

650 : AssemblyDomainEleOp(row_field_name, col_field_name,
651 AssemblyDomainEleOp::OPROWCOL),
652 elasticCommonDataPtr(elastic_common_data_ptr),
653 coeffExpansionPtr(coeff_expansion_ptr) {
654 this->sYmm = false;
655}
FormsIntegrators< DomainEleOp >::Assembly< A >::OpBase AssemblyDomainEleOp

◆ OpCalculateHenckyThermalStressdTImpl() [2/2]

template<int DIM, typename AssemblyDomainEleOp , int S>
HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >::OpCalculateHenckyThermalStressdTImpl ( const std::string  row_field_name,
const std::string  col_field_name,
boost::shared_ptr< CommonData elastic_common_data_ptr,
boost::shared_ptr< VectorDouble >  coeff_expansion_ptr 
)

Member Function Documentation

◆ iNtegrate() [1/2]

template<int DIM, typename AssemblyDomainEleOp , int S>
MoFEMErrorCode HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >::iNtegrate ( EntitiesFieldData::EntData &  row_data,
EntitiesFieldData::EntData &  col_data 
)

Definition at line 659 of file HenckyOps.hpp.

661 {
663
664 auto &locMat = AssemblyDomainEleOp::locMat;
665
666 const auto nb_integration_pts = row_data.getN().size1();
667 const auto nb_row_base_functions = row_data.getN().size2();
668 auto t_w = this->getFTensor0IntegrationWeight();
669
670 constexpr auto t_kd = FTensor::Kronecker_Delta<int>();
671 auto t_row_diff_base = row_data.getFTensor1DiffN<DIM>();
672 auto t_D = getFTensor4DdgFromMat<DIM, DIM, 0>(*elasticCommonDataPtr->matDPtr);
673 auto t_grad =
674 getFTensor2FromMat<DIM, DIM>(*(elasticCommonDataPtr->matGradPtr));
675 auto t_logC_dC =
676 getFTensor4DdgFromMat<DIM, DIM>(elasticCommonDataPtr->matLogCdC);
679
680 FTensor::Index<'i', DIM> i;
681 FTensor::Index<'j', DIM> j;
682 FTensor::Index<'k', DIM> k;
683 FTensor::Index<'l', DIM> l;
684 FTensor::Index<'m', DIM> m;
685 FTensor::Index<'n', DIM> n;
686 FTensor::Index<'o', DIM> o;
687
689 t_coeff_exp(i, j) = 0;
690 for (auto d = 0; d != SPACE_DIM; ++d) {
691 t_coeff_exp(d, d) = (*coeffExpansionPtr)[d];
692 }
693
694 t_eigen_strain(i, j) = (t_D(i, j, k, l) * t_coeff_exp(k, l));
695
696 for (auto gg = 0; gg != nb_integration_pts; ++gg) {
697
698 t_F(i, j) = t_grad(i, j) + t_kd(i, j);
699
700 double alpha = this->getMeasure() * t_w;
701 auto rr = 0;
702 for (; rr != AssemblyDomainEleOp::nbRows / DIM; ++rr) {
703 auto t_mat =
704 getFTensor1FromMat<DIM, 1,
705 DataLayoutTraits<DataLayout::CoeffsByGauss>>(
706 locMat, rr * DIM);
707 auto t_col_base = col_data.getFTensor0N(gg, 0);
708 for (auto cc = 0; cc != AssemblyDomainEleOp::nbCols; cc++) {
709#ifdef HENCKY_SMALL_STRAIN
710 t_mat(i) -=
711 (t_row_diff_base(j) * t_eigen_strain(i, j)) * (t_col_base * alpha);
712#else
713 t_mat(i) -= (t_row_diff_base(j) *
714 (t_F(i, o) * ((t_D(m, n, k, l) * t_coeff_exp(k, l)) *
715 t_logC_dC(m, n, o, j)))) *
716 (t_col_base * alpha);
717#endif
718
719 ++t_mat;
720 ++t_col_base;
721 }
722
723 ++t_row_diff_base;
724 }
725 for (; rr != nb_row_base_functions; ++rr)
726 ++t_row_diff_base;
727
728 ++t_w;
729 ++t_grad;
730 ++t_logC_dC;
731 ++t_D;
732 }
733
735}
constexpr int SPACE_DIM
Kronecker Delta class.
#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()
constexpr auto t_kd
FTensor::Index< 'i', SPACE_DIM > i
const double n
refractive index of diffusive medium
FTensor::Index< 'l', 3 > l
FTensor::Index< 'j', 3 > j
FTensor::Index< 'k', 3 > k
auto getFTensor1FromMat(M &data, int rr=0, int cc=0)
Get tensor rank 1 (vector) form data matrix.
FTensor::Index< 'm', 3 > m

◆ iNtegrate() [2/2]

template<int DIM, typename AssemblyDomainEleOp , int S>
MoFEMErrorCode HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >::iNtegrate ( EntitiesFieldData::EntData &  row_data,
EntitiesFieldData::EntData &  col_data 
)

Member Data Documentation

◆ coeffExpansionPtr

template<int DIM, typename AssemblyDomainEleOp , int S>
boost::shared_ptr< VectorDouble > HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >::coeffExpansionPtr
private

Definition at line 641 of file HenckyOps.hpp.

◆ elasticCommonDataPtr

template<int DIM, typename AssemblyDomainEleOp , int S>
boost::shared_ptr< CommonData > HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S >::elasticCommonDataPtr
private

Definition at line 640 of file HenckyOps.hpp.


The documentation for this struct was generated from the following files: