v0.14.0
Public Member Functions | Private Attributes | List of all members
EshelbianPlasticity::OpConstrainBoundaryL2Rhs Struct Reference

#include <users_modules/eshelbian_plasticit/src/EshelbianContact.hpp>

Inheritance diagram for EshelbianPlasticity::OpConstrainBoundaryL2Rhs:
[legend]
Collaboration diagram for EshelbianPlasticity::OpConstrainBoundaryL2Rhs:
[legend]

Public Member Functions

 OpConstrainBoundaryL2Rhs (const std::string row_field_name, boost::shared_ptr< ContactOps::CommonData > common_data_ptr, boost::shared_ptr< ContactTree > contact_tree_ptr, boost::shared_ptr< std::map< int, Range >> sdf_map_range_ptr=nullptr)
 
MoFEMErrorCode iNtegrate (EntitiesFieldData::EntData &row_data)
 

Private Attributes

boost::shared_ptr< ContactOps::CommonDatacommonDataPtr
 
boost::shared_ptr< ContactTreecontactTreePtr
 
boost::shared_ptr< std::map< int, Range > > sdfMapRangePtr
 

Detailed Description

Examples
EshelbianPlasticity.cpp.

Definition at line 118 of file EshelbianContact.hpp.

Constructor & Destructor Documentation

◆ OpConstrainBoundaryL2Rhs()

EshelbianPlasticity::OpConstrainBoundaryL2Rhs::OpConstrainBoundaryL2Rhs ( const std::string  row_field_name,
boost::shared_ptr< ContactOps::CommonData common_data_ptr,
boost::shared_ptr< ContactTree contact_tree_ptr,
boost::shared_ptr< std::map< int, Range >>  sdf_map_range_ptr = nullptr 
)

Definition at line 309 of file EshelbianContact.cpp.

314  : ContactOps::AssemblyBoundaryEleOp(row_field_name, row_field_name,
315  ContactOps::BoundaryEleOp::OPROW),
316  commonDataPtr(common_data_ptr), contactTreePtr(contact_tree_ptr),
317  sdfMapRangePtr(sdf_map_range_ptr) {
318  CHK_THROW_MESSAGE(PetscOptionsGetScalar(PETSC_NULL, "", "-cn",
319  &ContactOps::cn_contact, PETSC_NULL),
320  "get cn failed");
323  PetscOptionsGetScalar(PETSC_NULL, "", "-alpha_contact_const",
324  &ContactOps::alpha_contact_const, PETSC_NULL),
325  "get alpha contact failed");
327  PetscOptionsGetScalar(PETSC_NULL, "", "-alpha_contact_quadratic",
329  "get alpha contact failed");
331  PetscOptionsGetScalar(PETSC_NULL, "", "-airplane_ray_distance",
332  &ContactOps::airplane_ray_distance, PETSC_NULL),
333  "get alpha contact failed");
334 
335 
336  MOFEM_LOG("EP", Sev::inform) << "cn " << ContactOps::cn_contact;
337  MOFEM_LOG("EP", Sev::inform)
338  << "alpha_contact_const " << ContactOps::alpha_contact_const;
339  MOFEM_LOG("EP", Sev::inform)
340  << "alpha_contact_quadratic " << ContactOps::alpha_contact_quadratic;
341  MOFEM_LOG("EP", Sev::inform)
342  << "airplane_ray_distance " << ContactOps::airplane_ray_distance;
343 }

Member Function Documentation

◆ iNtegrate()

MoFEMErrorCode EshelbianPlasticity::OpConstrainBoundaryL2Rhs::iNtegrate ( EntitiesFieldData::EntData row_data)

Definition at line 346 of file EshelbianContact.cpp.

346  {
348 
353 
354  const size_t nb_gauss_pts = getGaussPts().size2();
355 
356 #ifndef NDEBUG
357  if (commonDataPtr->contactDisp.size2() != nb_gauss_pts) {
358  SETERRQ2(PETSC_COMM_SELF, MOFEM_DATA_INCONSISTENCY,
359  "Wrong number of integration pts %d != %d",
360  commonDataPtr->contactDisp.size2(), nb_gauss_pts);
361  }
362 #endif // !NDEBUG
363 
364  auto &nf = locF;
365  locF.clear();
366 
367  auto t_w = getFTensor0IntegrationWeight();
368  auto t_coords = getFTensor1CoordsAtGaussPts();
369  auto t_disp = getFTensor1FromMat<3>(commonDataPtr->contactDisp);
370  auto t_traction = getFTensor1FromMat<3>(commonDataPtr->contactTraction);
371 
372  // placeholder to pass boundary block id to python. default SDF is set on
373  // block = -1, one can choose different block by making block "CONTACT_SDF",
374  // then specific SDF can be set to that block.
375  auto [block_id, m_normals_at_pts, v_sdf, m_grad_sdf, m_hess_sdf] =
376  getSdf(this, commonDataPtr->contactDisp,
377  checkSdf(getFEEntityHandle(), *sdfMapRangePtr), false);
378 
379  auto t_sdf_v = getFTensor0FromVec(v_sdf);
380  auto t_grad_sdf_v = getFTensor1FromMat<3>(m_grad_sdf);
381  auto t_normalize_normal = getFTensor1FromMat<3>(m_normals_at_pts);
382 
383  auto next = [&]() {
384  ++t_w;
385  ++t_coords;
386  ++t_disp;
387  ++t_traction;
388  ++t_normalize_normal;
389  ++t_sdf_v;
390  ++t_grad_sdf_v;
391  };
392 
393  auto face_data_vec_ptr =
394  contactTreePtr->findFaceDataVecPtr(getFEEntityHandle());
395  auto face_gauss_pts_it = face_data_vec_ptr->begin();
396 
397  auto nb_base_functions = data.getN().size2();
398  auto t_base = data.getFTensor0N();
399  for (auto gg = 0; gg != nb_gauss_pts; ++gg) {
400 
402  auto face_data_ptr = contactTreePtr->getFaceDataPtr(face_gauss_pts_it, gg,
403  face_data_vec_ptr);
404 
405  auto check_face_contact = [&]() {
406  if (face_data_ptr) {
407  return true;
408  }
409  return false;
410  };
411 
412 #ifdef PYTHON_SDF
413  auto tn = t_traction(i) * t_grad_sdf_v(i);
414  auto c = ContactOps::constrain(t_sdf_v, tn);
415 #else
416  constexpr double c = 0;
417 #endif
418 
419  if (!c && check_face_contact()) {
420  FTensor::Tensor1<double, 3> t_spatial_coords;
421  t_spatial_coords(i) = t_coords(i) + t_disp(i);
422  auto t_rhs_tmp = multiPointRhs(face_data_ptr, t_coords, t_spatial_coords,
423  t_traction, MultiPointRhsType::U, true);
424  t_rhs(i) = t_rhs_tmp(i);
425 
426  } else {
427 
428 #ifdef PYTHON_SDF
429  auto inv_cn = ContactOps::alpha_contact_const;
430 
431  if (ContactOps::sdfPythonWeakPtr.lock()) {
432  auto inv_cn = ContactOps::alpha_contact_const;
434  t_cP(i, j) = (c * t_grad_sdf_v(i)) * t_grad_sdf_v(j);
435  t_cQ(i, j) = kronecker_delta(i, j) - t_cP(i, j);
436  t_rhs(i) = t_cQ(i, j) * t_traction(j) +
437  (c * inv_cn * t_sdf_v) * t_grad_sdf_v(i);
438  } else {
439  t_rhs(i) = t_traction(i);
440  }
441 #else
442  t_rhs(i) = t_traction(i);
443 #endif
444  }
445 
446  auto t_nf = getFTensor1FromPtr<3>(&nf[0]);
447  const double alpha = t_w * getMeasure();
448 
449  size_t bb = 0;
450  for (; bb != nbRows / 3; ++bb) {
451  const double beta = alpha * t_base;
452  t_nf(i) -= beta * t_rhs(i);
453  ++t_nf;
454  ++t_base;
455  }
456  for (; bb < nb_base_functions; ++bb)
457  ++t_base;
458 
459  next();
460  }
461 
463 }

Member Data Documentation

◆ commonDataPtr

boost::shared_ptr<ContactOps::CommonData> EshelbianPlasticity::OpConstrainBoundaryL2Rhs::commonDataPtr
private

Definition at line 128 of file EshelbianContact.hpp.

◆ contactTreePtr

boost::shared_ptr<ContactTree> EshelbianPlasticity::OpConstrainBoundaryL2Rhs::contactTreePtr
private

Definition at line 129 of file EshelbianContact.hpp.

◆ sdfMapRangePtr

boost::shared_ptr<std::map<int, Range> > EshelbianPlasticity::OpConstrainBoundaryL2Rhs::sdfMapRangePtr
private

Definition at line 130 of file EshelbianContact.hpp.


The documentation for this struct was generated from the following files:
ContactOps::airplane_ray_distance
double airplane_ray_distance
Definition: EshelbianContact.hpp:25
FTensor::Tensor1< double, 3 >
ContactOps::constrain
double constrain(double sdf, double tn)
constrain function
Definition: ContactOps.hpp:603
EshelbianPlasticity::OpConstrainBoundaryL2Rhs::sdfMapRangePtr
boost::shared_ptr< std::map< int, Range > > sdfMapRangePtr
Definition: EshelbianContact.hpp:130
CHK_THROW_MESSAGE
#define CHK_THROW_MESSAGE(err, msg)
Check and throw MoFEM exception.
Definition: definitions.h:609
EshelbianPlasticity::checkSdf
auto checkSdf(EntityHandle fe_ent, std::map< int, Range > &sdf_map_range)
Definition: EshelbianContact.cpp:17
FTensor::Tensor2< double, 3, 3 >
c
const double c
speed of light (cm/ns)
Definition: initial_diffusion.cpp:39
MoFEM::getFTensor0FromVec
static auto getFTensor0FromVec(ublas::vector< T, A > &data)
Get tensor rank 0 (scalar) form data vector.
Definition: Templates.hpp:135
ContactOps::AssemblyBoundaryEleOp
FormsIntegrators< BoundaryEleOp >::Assembly< A >::OpBase AssemblyBoundaryEleOp
Definition: EshelbianContact.hpp:18
i
FTensor::Index< 'i', SPACE_DIM > i
Definition: hcurl_divergence_operator_2d.cpp:27
ContactOps::alpha_contact_const
double alpha_contact_const
Definition: EshelbianContact.hpp:21
FTensor::Index< 'i', 3 >
ContactOps::cn_contact
double cn_contact
Definition: contact.cpp:100
MOFEM_LOG
#define MOFEM_LOG(channel, severity)
Log.
Definition: LogManager.hpp:308
FTensor::kronecker_delta
Tensor2_Expr< Kronecker_Delta< T >, T, Dim0, Dim1, i, j > kronecker_delta(const Index< i, Dim0 > &, const Index< j, Dim1 > &)
Rank 2.
Definition: Kronecker_Delta.hpp:81
EshelbianPlasticity::multiPointRhs
auto multiPointRhs(ContactTree::FaceData *face_data_ptr, FTensor::Tensor1< T1, 3 > &t_coords, FTensor::Tensor1< T2, 3 > &t_spatial_coords, FTensor::Tensor1< T3, 3 > &t_master_traction, MultiPointRhsType type, bool debug=false)
Definition: EshelbianContact.cpp:206
j
FTensor::Index< 'j', 3 > j
Definition: matrix_function.cpp:19
MOFEM_DATA_INCONSISTENCY
@ MOFEM_DATA_INCONSISTENCY
Definition: definitions.h:31
EshelbianPlasticity::OpConstrainBoundaryL2Rhs::contactTreePtr
boost::shared_ptr< ContactTree > contactTreePtr
Definition: EshelbianContact.hpp:129
MoFEM::PetscOptionsGetScalar
PetscErrorCode PetscOptionsGetScalar(PetscOptions *, const char pre[], const char name[], PetscScalar *dval, PetscBool *set)
Definition: DeprecatedPetsc.hpp:162
k
FTensor::Index< 'k', 3 > k
Definition: matrix_function.cpp:20
ContactOps::alpha_contact_quadratic
double alpha_contact_quadratic
Definition: EshelbianContact.hpp:22
MoFEMFunctionReturn
#define MoFEMFunctionReturn(a)
Last executable line of each PETSc function used for error handling. Replaces return()
Definition: definitions.h:429
EshelbianPlasticity::OpConstrainBoundaryL2Rhs::commonDataPtr
boost::shared_ptr< ContactOps::CommonData > commonDataPtr
Definition: EshelbianContact.hpp:128
EshelbianPlasticity::U
@ U
Definition: EshelbianContact.cpp:201
MoFEMFunctionBegin
#define MoFEMFunctionBegin
First executable line of each MoFEM function, used for error handling. Final line of MoFEM functions ...
Definition: definitions.h:359
l
FTensor::Index< 'l', 3 > l
Definition: matrix_function.cpp:21
EshelbianPlasticity::getSdf
auto getSdf(OP_PTR op_ptr, MatrixDouble &contact_disp, int block_id, bool eval_hessian)
Definition: EshelbianContact.cpp:26