v0.15.0
Loading...
Searching...
No Matches
HenckyOps::OpCalculateHenckyThermalStressdTImpl< DIM, GAUSS, AssemblyDomainEleOp, S > Struct Template Reference

#include "tutorials/vec-2/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)
 

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 631 of file HenckyOps.hpp.

Constructor & Destructor Documentation

◆ OpCalculateHenckyThermalStressdTImpl()

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 647 of file HenckyOps.hpp.

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

Member Function Documentation

◆ iNtegrate()

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 661 of file HenckyOps.hpp.

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

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 643 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 642 of file HenckyOps.hpp.


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