v0.15.0
Loading...
Searching...
No Matches
PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp > Struct Template Reference

#include "tutorials/adv-0/src/PlasticOpsGeneric.hpp"

Inheritance diagram for PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp >:
[legend]
Collaboration diagram for PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp >:
[legend]

Public Member Functions

 OpCalculateConstraintsLhs_dTAUImpl (const std::string row_field_name, const std::string col_field_name, boost::shared_ptr< CommonData > common_data_ptr)
 
MoFEMErrorCode iNtegrate (EntitiesFieldData::EntData &row_data, EntitiesFieldData::EntData &col_data)
 

Private Attributes

boost::shared_ptr< CommonDatacommonDataPtr
 

Detailed Description

template<typename AssemblyDomainEleOp>
struct PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp >

Definition at line 1265 of file PlasticOpsGeneric.hpp.

Constructor & Destructor Documentation

◆ OpCalculateConstraintsLhs_dTAUImpl()

template<typename AssemblyDomainEleOp >
PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp >::OpCalculateConstraintsLhs_dTAUImpl ( const std::string row_field_name,
const std::string col_field_name,
boost::shared_ptr< CommonData > common_data_ptr )

Definition at line 1278 of file PlasticOpsGeneric.hpp.

1282 : AssemblyDomainEleOp(row_field_name, col_field_name,
1283 DomainEleOp::OPROWCOL),
1284 commonDataPtr(common_data_ptr) {
1285 AssemblyDomainEleOp::sYmm = false;
1286}
FormsIntegrators< DomainEleOp >::Assembly< A >::OpBase AssemblyDomainEleOp

Member Function Documentation

◆ iNtegrate()

template<typename AssemblyDomainEleOp >
MoFEMErrorCode PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp >::iNtegrate ( EntitiesFieldData::EntData & row_data,
EntitiesFieldData::EntData & col_data )
Examples
PlasticOpsGeneric.hpp.

Definition at line 1290 of file PlasticOpsGeneric.hpp.

1292 {
1294
1295 const auto nb_integration_pts = AssemblyDomainEleOp::getGaussPts().size2();
1296 const auto nb_row_base_functions = row_data.getN().size2();
1297
1298 auto t_res_c_dtau = getFTensor0FromVec(commonDataPtr->resCdTau);
1299 auto next = [&]() { ++t_res_c_dtau; };
1300
1301 auto t_w = AssemblyDomainEleOp::getFTensor0IntegrationWeight();
1302 auto t_row_base = row_data.getFTensor0N();
1303 for (size_t gg = 0; gg != nb_integration_pts; ++gg) {
1304 const double alpha = AssemblyDomainEleOp::getMeasure() * t_w;
1305 ++t_w;
1306
1307 const auto res = alpha * (t_res_c_dtau);
1308 next();
1309
1310 auto mat_ptr = AssemblyDomainEleOp::locMat.data().begin();
1311 size_t rr = 0;
1312 for (; rr != AssemblyDomainEleOp::nbRows; ++rr) {
1313 auto t_col_base = col_data.getFTensor0N(gg, 0);
1314 for (size_t cc = 0; cc != AssemblyDomainEleOp::nbCols; ++cc) {
1315 *mat_ptr += t_row_base * t_col_base * res;
1316 ++t_col_base;
1317 ++mat_ptr;
1318 }
1319 ++t_row_base;
1320 }
1321 for (; rr < nb_row_base_functions; ++rr)
1322 ++t_row_base;
1323 }
1324
1326}
#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()

Member Data Documentation

◆ commonDataPtr

template<typename AssemblyDomainEleOp >
boost::shared_ptr<CommonData> PlasticOps::OpCalculateConstraintsLhs_dTAUImpl< GAUSS, AssemblyDomainEleOp >::commonDataPtr
private

Definition at line 1274 of file PlasticOpsGeneric.hpp.


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