v0.15.0
Loading...
Searching...
No Matches
OpGetInternalStress< INTERP_ORDER > Struct Template Reference

#include "users_modules/eshelbian_plasticity/src/EshelbianOperators.hpp"

Inheritance diagram for OpGetInternalStress< INTERP_ORDER >:
[legend]
Collaboration diagram for OpGetInternalStress< INTERP_ORDER >:
[legend]

Public Member Functions

 OpGetInternalStress (boost::shared_ptr< DataAtIntegrationPts > data_ptr, std::string tag_name="")
 
MoFEMErrorCode doWork (int side, EntityType type, EntData &data)
 
MoFEMErrorCode doWork (int side, EntityType type, EntData &data)
 
MoFEMErrorCode doWork (int side, EntityType type, EntData &data)
 

Private Attributes

boost::shared_ptr< DataAtIntegrationPtsdataAtPts
 
std::string tagName
 

Detailed Description

template<int INTERP_ORDER>
struct OpGetInternalStress< INTERP_ORDER >
Examples
EshelbianPlasticity.cpp.

Definition at line 392 of file EshelbianOperators.hpp.

Constructor & Destructor Documentation

◆ OpGetInternalStress()

template<int INTERP_ORDER>
OpGetInternalStress< INTERP_ORDER >::OpGetInternalStress ( boost::shared_ptr< DataAtIntegrationPts > data_ptr,
std::string tag_name = "" )
inline

Definition at line 393 of file EshelbianOperators.hpp.

395 : UserDataOperator(H1, OPLAST), dataAtPts(data_ptr), tagName(tag_name) {
396 std::fill(&doEntities[MBVERTEX], &doEntities[MBMAXTYPE], false);
397 doEntities[MBVERTEX] = true;
398 }
ForcesAndSourcesCore::UserDataOperator UserDataOperator
@ H1
continuous field
Definition definitions.h:85
boost::shared_ptr< DataAtIntegrationPts > dataAtPts

Member Function Documentation

◆ doWork() [1/3]

template<int INTERP_ORDER>
MoFEMErrorCode OpGetInternalStress< INTERP_ORDER >::doWork ( int side,
EntityType type,
EntData & data )

◆ doWork() [2/3]

MoFEMErrorCode OpGetInternalStress< 0 >::doWork ( int side,
EntityType type,
EntData & data )

Definition at line 1241 of file EshelbianOperators.cpp.

1242 {
1244
1245 int nb_integration_pts = getGaussPts().size2();
1246
1247 Tag tag;
1248 CHKERR getPtrFE() -> mField.get_moab().tag_get_handle(tagName.c_str(), tag);
1249 int tag_length;
1250 CHKERR getPtrFE() -> mField.get_moab().tag_get_length(tag, tag_length);
1251 if (tag_length != 9) {
1252 SETERRQ(PETSC_COMM_SELF, MOFEM_DATA_INCONSISTENCY,
1253 "Number of internal stress components should be 9 but is %d",
1254 tag_length);
1255 }
1256
1257 VectorDouble const_stress_vec(9);
1258 auto fe_ent = getNumeredEntFiniteElementPtr()->getEnt();
1259 CHKERR getPtrFE() -> mField.get_moab().tag_get_data(
1260 tag, &fe_ent, 1, &*const_stress_vec.data().begin());
1261 auto t_const_stress = getFTensor1FromArray<9, 9>(const_stress_vec);
1262
1263 dataAtPts->internalStressAtPts.resize(tag_length, nb_integration_pts, false);
1264 dataAtPts->internalStressAtPts.clear();
1265 auto t_internal_stress =
1266 getFTensor1FromMat<9>(dataAtPts->internalStressAtPts);
1267
1268 FTensor::Index<'L', 9> L;
1269 for (int gg = 0; gg != nb_integration_pts; ++gg) {
1270 t_internal_stress(L) = t_const_stress(L);
1271 ++t_internal_stress;
1272 }
1273
1275}
#define MoFEMFunctionBegin
First executable line of each MoFEM function, used for error handling. Final line of MoFEM functions ...
@ MOFEM_DATA_INCONSISTENCY
Definition definitions.h:31
#define MoFEMFunctionReturn(a)
Last executable line of each PETSc function used for error handling. Replaces return()
#define CHKERR
Inline error check.
FTensor::Tensor1< FTensor::PackPtr< T *, S >, Tensor_Dim > getFTensor1FromMat(ublas::matrix< T, L, A > &data)
Get tensor rank 1 (vector) form data matrix.
auto getFTensor1FromArray(VectorDouble &data)
Get FTensor1 from array.

◆ doWork() [3/3]

MoFEMErrorCode OpGetInternalStress< 1 >::doWork ( int side,
EntityType type,
EntData & data )

Definition at line 1278 of file EshelbianOperators.cpp.

1280 {
1282
1283 int nb_integration_pts = getGaussPts().size2();
1284
1285 Tag tag;
1286 CHKERR getPtrFE() -> mField.get_moab().tag_get_handle(tagName.c_str(), tag);
1287 int tag_length;
1288 CHKERR getPtrFE() -> mField.get_moab().tag_get_length(tag, tag_length);
1289 if (tag_length != 9) {
1290 SETERRQ(PETSC_COMM_SELF, MOFEM_DATA_INCONSISTENCY,
1291 "Number of internal stress components should be 9 but is %d",
1292 tag_length);
1293 }
1294
1295 auto fe_ent = getNumeredEntFiniteElementPtr()->getEnt();
1296 const EntityHandle *vert_conn;
1297 int vert_num;
1298 CHKERR getPtrFE() -> mField.get_moab().get_connectivity(fe_ent, vert_conn,
1299 vert_num, true);
1300 VectorDouble vert_data(vert_num * tag_length);
1301 CHKERR getPtrFE() -> mField.get_moab().tag_get_data(tag, vert_conn, vert_num,
1302 &vert_data[0]);
1303
1304 dataAtPts->internalStressAtPts.resize(tag_length, nb_integration_pts, false);
1305 dataAtPts->internalStressAtPts.clear();
1306 auto t_internal_stress =
1307 getFTensor1FromMat<9>(dataAtPts->internalStressAtPts);
1308
1309 auto t_shape_n = data.getFTensor0N();
1310 int nb_shape_fn = data.getN(NOBASE).size2();
1311 FTensor::Index<'L', 9> L;
1312 for (int gg = 0; gg != nb_integration_pts; ++gg) {
1313 auto t_vert_data = getFTensor1FromArray<9, 9>(vert_data);
1314 for (int bb = 0; bb != nb_shape_fn; ++bb) {
1315 t_internal_stress(L) += t_vert_data(L) * t_shape_n;
1316 ++t_vert_data;
1317 ++t_shape_n;
1318 }
1319 ++t_internal_stress;
1320 }
1321
1323}
@ NOBASE
Definition definitions.h:59
FTensor::Tensor0< FTensor::PackPtr< double *, 1 > > getFTensor0N(const FieldApproximationBase base)
Get base function as Tensor0.
MatrixDouble & getN(const FieldApproximationBase base)
get base functions this return matrix (nb. of rows is equal to nb. of Gauss pts, nb....

Member Data Documentation

◆ dataAtPts

template<int INTERP_ORDER>
boost::shared_ptr<DataAtIntegrationPts> OpGetInternalStress< INTERP_ORDER >::dataAtPts
private

Definition at line 402 of file EshelbianOperators.hpp.

◆ tagName

template<int INTERP_ORDER>
std::string OpGetInternalStress< INTERP_ORDER >::tagName
private

Definition at line 403 of file EshelbianOperators.hpp.


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