v0.15.5
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Protected Attributes | List of all members
EshelbianPlasticity::OpMoveNode Struct Reference
Inheritance diagram for EshelbianPlasticity::OpMoveNode:
[legend]
Collaboration diagram for EshelbianPlasticity::OpMoveNode:
[legend]

Public Types

using UOP = FaceElementForcesAndSourcesCore::UserDataOperator
 

Public Member Functions

 OpMoveNode (boost::shared_ptr< ContactTree > contact_tree_ptr, boost::shared_ptr< ContactOps::CommonData > common_data_ptr, boost::shared_ptr< MatrixDouble > u_h1_ptr)
 
MoFEMErrorCode doWork (int side, EntityType type, EntitiesFieldData::EntData &data)
 

Protected Attributes

boost::weak_ptr< ContactTreecontactTreePtr
 
boost::shared_ptr< MatrixDouble > uH1Ptr
 
boost::shared_ptr< ContactOps::CommonDatacommonDataPtr
 

Detailed Description

Definition at line 1344 of file EshelbianContact.cpp.

Member Typedef Documentation

◆ UOP

using EshelbianPlasticity::OpMoveNode::UOP = FaceElementForcesAndSourcesCore::UserDataOperator

Definition at line 1346 of file EshelbianContact.cpp.

Constructor & Destructor Documentation

◆ OpMoveNode()

EshelbianPlasticity::OpMoveNode::OpMoveNode ( boost::shared_ptr< ContactTree contact_tree_ptr,
boost::shared_ptr< ContactOps::CommonData common_data_ptr,
boost::shared_ptr< MatrixDouble >  u_h1_ptr 
)

Definition at line 1360 of file EshelbianContact.cpp.

1364 : UOP(NOSPACE, UOP::OPSPACE), contactTreePtr(contact_tree_ptr),
1365 uH1Ptr(u_h1_ptr), commonDataPtr(common_data_ptr) {}
@ NOSPACE
Definition definitions.h:83
boost::shared_ptr< ContactOps::CommonData > commonDataPtr
boost::weak_ptr< ContactTree > contactTreePtr
FaceElementForcesAndSourcesCore::UserDataOperator UOP
boost::shared_ptr< MatrixDouble > uH1Ptr

Member Function Documentation

◆ doWork()

MoFEMErrorCode EshelbianPlasticity::OpMoveNode::doWork ( int  side,
EntityType  type,
EntitiesFieldData::EntData data 
)

Definition at line 1367 of file EshelbianContact.cpp.

1368 {
1370
1371 if (auto contact_tree_ptr = contactTreePtr.lock()) {
1372
1373 auto get_body_id = [&](auto fe_ent) {
1374 for (auto &m : contact_tree_ptr->bodyMap) {
1375 if (m.second.find(fe_ent) != m.second.end()) {
1376 return m.first;
1377 }
1378 }
1379 return -1;
1380 };
1381
1382 auto &moab_post_proc_mesh = contact_tree_ptr->getPostProcMesh();
1383 auto &post_proc_ents = contact_tree_ptr->getPostProcElements();
1384
1385 auto fe_ent = getNumeredEntFiniteElementPtr()->getEnt();
1386 auto fe_id = id_from_handle(fe_ent);
1387 auto body_id = get_body_id(fe_ent);
1388 auto &map_gauss_pts = contact_tree_ptr->getMapGaussPts();
1389
1390 CHKERR moab_post_proc_mesh.tag_clear_data(contact_tree_ptr->thEleId,
1391 post_proc_ents, &fe_id);
1392 CHKERR moab_post_proc_mesh.tag_clear_data(contact_tree_ptr->thBodyId,
1393 post_proc_ents, &body_id);
1394
1395 auto nb_gauss_pts = getGaussPts().size2();
1396 auto t_u_h1 = getFTensor1FromMat<3>(*uH1Ptr);
1397 auto t_u_l2 = getFTensor1FromMat<3>(commonDataPtr->contactDisp);
1398 auto t_coords = getFTensor1CoordsAtGaussPts();
1399
1400 MatrixDouble x_h1(nb_gauss_pts, 3);
1401 auto t_x_h1 = getFTensor1FromPtr<3>(&x_h1(0, 0));
1402 MatrixDouble x_l2(nb_gauss_pts, 3);
1403 auto t_x_l2 = getFTensor1FromPtr<3>(&x_l2(0, 0));
1404 MatrixDouble tractions = trans(commonDataPtr->contactTraction);
1405 MatrixDouble coords = getCoordsAtGaussPts();
1406
1407 FTensor::Index<'i', 3> i;
1408
1409 // VectorDouble bases(nb_bases, 0);
1410 for (auto gg = 0; gg != nb_gauss_pts; ++gg) {
1411 t_x_h1(i) = t_coords(i) + t_u_h1(i);
1412 t_x_l2(i) = t_coords(i) + t_u_l2(i);
1413
1414 ++t_coords;
1415 ++t_u_h1;
1416 ++t_u_l2;
1417 ++t_x_h1;
1418 ++t_x_l2;
1419 }
1420
1421 CHKERR moab_post_proc_mesh.set_coords(
1422 &*map_gauss_pts.begin(), map_gauss_pts.size(), &*x_h1.data().begin());
1423 CHKERR moab_post_proc_mesh.tag_set_data(
1424 contact_tree_ptr->thSmallX, &*map_gauss_pts.begin(),
1425 map_gauss_pts.size(), &*x_h1.data().begin());
1426 CHKERR moab_post_proc_mesh.tag_set_data(
1427 contact_tree_ptr->thLargeX, &*map_gauss_pts.begin(),
1428 map_gauss_pts.size(), &*coords.data().begin());
1429 CHKERR moab_post_proc_mesh.tag_set_data(
1430 contact_tree_ptr->thTraction, &*map_gauss_pts.begin(),
1431 map_gauss_pts.size(), &*tractions.data().begin());
1432
1433 } else {
1434 SETERRQ(PETSC_COMM_WORLD, MOFEM_DATA_INCONSISTENCY,
1435 "ContactTree pointer expired in OpMoveNode");
1436 }
1437
1439}
#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::Index< 'i', SPACE_DIM > i
auto id_from_handle(const EntityHandle h)
FTensor::Index< 'm', 3 > m

Member Data Documentation

◆ commonDataPtr

boost::shared_ptr<ContactOps::CommonData> EshelbianPlasticity::OpMoveNode::commonDataPtr
protected

Definition at line 1357 of file EshelbianContact.cpp.

◆ contactTreePtr

boost::weak_ptr<ContactTree> EshelbianPlasticity::OpMoveNode::contactTreePtr
protected

Definition at line 1355 of file EshelbianContact.cpp.

◆ uH1Ptr

boost::shared_ptr<MatrixDouble> EshelbianPlasticity::OpMoveNode::uH1Ptr
protected

Definition at line 1356 of file EshelbianContact.cpp.


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