v0.15.5
Loading...
Searching...
No Matches
Classes | Public Types | Public Member Functions | Public Attributes | Private Attributes | Static Private Attributes | List of all members
EshelbianPlasticity::SetIntegrationAtFrontVolume Struct Reference
Collaboration diagram for EshelbianPlasticity::SetIntegrationAtFrontVolume:
[legend]

Classes

struct  Fe
 

Public Types

using FunRule = boost::function< int(int)>
 

Public Member Functions

 SetIntegrationAtFrontVolume (boost::shared_ptr< Range > front_nodes, boost::shared_ptr< Range > front_edges, boost::shared_ptr< CGGUserPolynomialBase::CachePhi > cache_phi=nullptr)
 
 SetIntegrationAtFrontVolume (boost::shared_ptr< Range > front_nodes, boost::shared_ptr< Range > front_edges, FunRule fun_rule, boost::shared_ptr< CGGUserPolynomialBase::CachePhi > cache_phi=nullptr)
 
MoFEMErrorCode operator() (ForcesAndSourcesCore *fe_raw_ptr, int order_row, int order_col, int order_data)
 

Public Attributes

FunRule funRule = [](int p) { return 2 * p + 1; }
 

Private Attributes

boost::shared_ptr< RangefrontNodes
 
boost::shared_ptr< RangefrontEdges
 
boost::shared_ptr< CGGUserPolynomialBase::CachePhicachePhi
 

Static Private Attributes

static std::map< long int, MatrixDouble > mapRefCoords
 

Detailed Description

Definition at line 384 of file EshelbianPlasticity.cpp.

Member Typedef Documentation

◆ FunRule

Constructor & Destructor Documentation

◆ SetIntegrationAtFrontVolume() [1/2]

EshelbianPlasticity::SetIntegrationAtFrontVolume::SetIntegrationAtFrontVolume ( boost::shared_ptr< Range front_nodes,
boost::shared_ptr< Range front_edges,
boost::shared_ptr< CGGUserPolynomialBase::CachePhi cache_phi = nullptr 
)
inline

Definition at line 389 of file EshelbianPlasticity.cpp.

393 : frontNodes(front_nodes), frontEdges(front_edges), cachePhi(cache_phi){};
boost::shared_ptr< CGGUserPolynomialBase::CachePhi > cachePhi

◆ SetIntegrationAtFrontVolume() [2/2]

EshelbianPlasticity::SetIntegrationAtFrontVolume::SetIntegrationAtFrontVolume ( boost::shared_ptr< Range front_nodes,
boost::shared_ptr< Range front_edges,
FunRule  fun_rule,
boost::shared_ptr< CGGUserPolynomialBase::CachePhi cache_phi = nullptr 
)
inline

Definition at line 395 of file EshelbianPlasticity.cpp.

399 : frontNodes(front_nodes), frontEdges(front_edges), funRule(fun_rule),
400 cachePhi(cache_phi){};

Member Function Documentation

◆ operator()()

MoFEMErrorCode EshelbianPlasticity::SetIntegrationAtFrontVolume::operator() ( ForcesAndSourcesCore fe_raw_ptr,
int  order_row,
int  order_col,
int  order_data 
)
inline
Examples
/home/lk58p/mofem_install/vanilla_dev_release/mofem-cephas/mofem/users_modules/eshelbian_plasticity/src/impl/EshelbianPlasticity.cpp.

Definition at line 402 of file EshelbianPlasticity.cpp.

403 {
405
406 constexpr bool debug = false;
407
408 constexpr int numNodes = 4;
409 constexpr int numEdges = 6;
410 constexpr int refinementLevels = 6;
411
412 auto &m_field = fe_raw_ptr->mField;
413 auto fe_ptr = static_cast<Fe *>(fe_raw_ptr);
414 auto fe_handle = fe_ptr->getFEEntityHandle();
415
416 auto set_base_quadrature = [&]() {
418 int rule = funRule(order_data);
419 if (rule < QUAD_3D_TABLE_SIZE) {
420 if (QUAD_3D_TABLE[rule]->dim != 3) {
421 SETERRQ(m_field.get_comm(), MOFEM_DATA_INCONSISTENCY,
422 "wrong dimension");
423 }
424 if (QUAD_3D_TABLE[rule]->order < rule) {
425 SETERRQ(m_field.get_comm(), MOFEM_DATA_INCONSISTENCY,
426 "wrong order %d != %d", QUAD_3D_TABLE[rule]->order, rule);
427 }
428 const size_t nb_gauss_pts = QUAD_3D_TABLE[rule]->npoints;
429 auto &gauss_pts = fe_ptr->gaussPts;
430 gauss_pts.resize(4, nb_gauss_pts, false);
431 cblas_dcopy(nb_gauss_pts, &QUAD_3D_TABLE[rule]->points[1], 4,
432 &gauss_pts(0, 0), 1);
433 cblas_dcopy(nb_gauss_pts, &QUAD_3D_TABLE[rule]->points[2], 4,
434 &gauss_pts(1, 0), 1);
435 cblas_dcopy(nb_gauss_pts, &QUAD_3D_TABLE[rule]->points[3], 4,
436 &gauss_pts(2, 0), 1);
437 cblas_dcopy(nb_gauss_pts, QUAD_3D_TABLE[rule]->weights, 1,
438 &gauss_pts(3, 0), 1);
439 auto &data = fe_ptr->dataOnElement[H1];
440 data->dataOnEntities[MBVERTEX][0].getN(NOBASE).resize(nb_gauss_pts, 4,
441 false);
442 double *shape_ptr =
443 &*data->dataOnEntities[MBVERTEX][0].getN(NOBASE).data().begin();
444 cblas_dcopy(4 * nb_gauss_pts, QUAD_3D_TABLE[rule]->points, 1, shape_ptr,
445 1);
446 } else {
447 SETERRQ(PETSC_COMM_SELF, MOFEM_DATA_INCONSISTENCY,
448 "rule > quadrature order %d < %d", rule, QUAD_3D_TABLE_SIZE);
449 }
451 };
452
453 CHKERR set_base_quadrature();
454
456
457 auto get_singular_nodes = [&]() {
458 int num_nodes;
459 const EntityHandle *conn;
460 CHKERR m_field.get_moab().get_connectivity(fe_handle, conn, num_nodes,
461 true);
462 std::bitset<numNodes> singular_nodes;
463 for (auto nn = 0; nn != numNodes; ++nn) {
464 if (frontNodes->find(conn[nn]) != frontNodes->end()) {
465 singular_nodes.set(nn);
466 } else {
467 singular_nodes.reset(nn);
468 }
469 }
470 return singular_nodes;
471 };
472
473 auto get_singular_edges = [&]() {
474 std::bitset<numEdges> singular_edges;
475 for (int ee = 0; ee != numEdges; ee++) {
476 EntityHandle edge;
477 CHKERR m_field.get_moab().side_element(fe_handle, 1, ee, edge);
478 if (frontEdges->find(edge) != frontEdges->end()) {
479 singular_edges.set(ee);
480 } else {
481 singular_edges.reset(ee);
482 }
483 }
484 return singular_edges;
485 };
486
487 auto set_gauss_pts = [&](auto &ref_gauss_pts) {
489 fe_ptr->gaussPts.swap(ref_gauss_pts);
490 const size_t nb_gauss_pts = fe_ptr->gaussPts.size2();
491 auto &data = fe_ptr->dataOnElement[H1];
492 data->dataOnEntities[MBVERTEX][0].getN(NOBASE).resize(nb_gauss_pts, 4);
493 double *shape_ptr =
494 &*data->dataOnEntities[MBVERTEX][0].getN(NOBASE).data().begin();
495 CHKERR ShapeMBTET(shape_ptr, &fe_ptr->gaussPts(0, 0),
496 &fe_ptr->gaussPts(1, 0), &fe_ptr->gaussPts(2, 0),
497 nb_gauss_pts);
499 };
500
501 auto singular_nodes = get_singular_nodes();
502 if (singular_nodes.count()) {
503 auto it_map_ref_coords = mapRefCoords.find(singular_nodes.to_ulong());
504 if (it_map_ref_coords != mapRefCoords.end()) {
505 CHKERR set_gauss_pts(it_map_ref_coords->second);
507 } else {
508
509 auto refine_quadrature = [&]() {
511
512 const int max_level = refinementLevels;
513 EntityHandle tet;
514
515 moab::Core moab_ref;
516 double base_coords[] = {0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1};
517 EntityHandle nodes[4];
518 for (int nn = 0; nn != 4; nn++)
519 CHKERR moab_ref.create_vertex(&base_coords[3 * nn], nodes[nn]);
520 CHKERR moab_ref.create_element(MBTET, nodes, 4, tet);
521 MoFEM::CoreTmp<-1> mofem_ref_core(moab_ref, PETSC_COMM_SELF, -2);
522 MoFEM::Interface &m_field_ref = mofem_ref_core;
523 {
524 Range tets(tet, tet);
525 Range edges;
526 CHKERR m_field_ref.get_moab().get_adjacencies(
527 tets, 1, true, edges, moab::Interface::UNION);
528 CHKERR m_field_ref.getInterface<BitRefManager>()->setBitRefLevel(
529 tets, BitRefLevel().set(0), false, VERBOSE);
530 }
531
532 Range nodes_at_front;
533 for (int nn = 0; nn != numNodes; nn++) {
534 if (singular_nodes[nn]) {
535 EntityHandle ent;
536 CHKERR moab_ref.side_element(tet, 0, nn, ent);
537 nodes_at_front.insert(ent);
538 }
539 }
540
541 auto singular_edges = get_singular_edges();
542
543 EntityHandle meshset;
544 CHKERR moab_ref.create_meshset(MESHSET_SET, meshset);
545 for (int ee = 0; ee != numEdges; ee++) {
546 if (singular_edges[ee]) {
547 EntityHandle ent;
548 CHKERR moab_ref.side_element(tet, 1, ee, ent);
549 CHKERR moab_ref.add_entities(meshset, &ent, 1);
550 }
551 }
552
553 // refine mesh
554 auto *m_ref = m_field_ref.getInterface<MeshRefinement>();
555 for (int ll = 0; ll != max_level; ll++) {
556 Range edges;
557 CHKERR m_field_ref.getInterface<BitRefManager>()
558 ->getEntitiesByTypeAndRefLevel(BitRefLevel().set(ll),
559 BitRefLevel().set(), MBEDGE,
560 edges);
561 Range ref_edges;
562 CHKERR moab_ref.get_adjacencies(
563 nodes_at_front, 1, true, ref_edges, moab::Interface::UNION);
564 ref_edges = intersect(ref_edges, edges);
565 Range ents;
566 CHKERR moab_ref.get_entities_by_type(meshset, MBEDGE, ents, true);
567 ref_edges = intersect(ref_edges, ents);
568 Range tets;
569 CHKERR m_field_ref.getInterface<BitRefManager>()
570 ->getEntitiesByTypeAndRefLevel(
571 BitRefLevel().set(ll), BitRefLevel().set(), MBTET, tets);
572 CHKERR m_ref->addVerticesInTheMiddleOfEdges(
573 ref_edges, BitRefLevel().set(ll + 1));
574 CHKERR m_ref->refineTets(tets, BitRefLevel().set(ll + 1));
575 CHKERR m_field_ref.getInterface<BitRefManager>()
576 ->updateMeshsetByEntitiesChildren(meshset,
577 BitRefLevel().set(ll + 1),
578 meshset, MBEDGE, true);
579 }
580
581 // get ref coords
582 Range tets;
583 CHKERR m_field_ref.getInterface<BitRefManager>()
584 ->getEntitiesByTypeAndRefLevel(BitRefLevel().set(max_level),
585 BitRefLevel().set(), MBTET,
586 tets);
587
588 if (debug) {
589 CHKERR save_range(moab_ref, "ref_tets.vtk", tets);
590 }
591
592 MatrixDouble ref_coords(tets.size(), 12, false);
593 int tt = 0;
594 for (Range::iterator tit = tets.begin(); tit != tets.end();
595 tit++, tt++) {
596 int num_nodes;
597 const EntityHandle *conn;
598 CHKERR moab_ref.get_connectivity(*tit, conn, num_nodes, false);
599 CHKERR moab_ref.get_coords(conn, num_nodes, &ref_coords(tt, 0));
600 }
601
602 auto &data = fe_ptr->dataOnElement[H1];
603 const size_t nb_gauss_pts = fe_ptr->gaussPts.size2();
604 MatrixDouble ref_gauss_pts(4, nb_gauss_pts * ref_coords.size1());
605 MatrixDouble &shape_n =
606 data->dataOnEntities[MBVERTEX][0].getN(NOBASE);
607 int gg = 0;
608 for (size_t tt = 0; tt != ref_coords.size1(); tt++) {
609 double *tet_coords = &ref_coords(tt, 0);
610 double det = Tools::tetVolume(tet_coords);
611 det *= 6;
612 for (size_t ggg = 0; ggg != nb_gauss_pts; ++ggg, ++gg) {
613 for (int dd = 0; dd != 3; dd++) {
614 ref_gauss_pts(dd, gg) =
615 shape_n(ggg, 0) * tet_coords[3 * 0 + dd] +
616 shape_n(ggg, 1) * tet_coords[3 * 1 + dd] +
617 shape_n(ggg, 2) * tet_coords[3 * 2 + dd] +
618 shape_n(ggg, 3) * tet_coords[3 * 3 + dd];
619 }
620 ref_gauss_pts(3, gg) = fe_ptr->gaussPts(3, ggg) * det;
621 }
622 }
623
624 mapRefCoords[singular_nodes.to_ulong()].swap(ref_gauss_pts);
625 CHKERR set_gauss_pts(mapRefCoords[singular_nodes.to_ulong()]);
626
627 // clear cache bubble
628 cachePhi->get<0>() = 0;
629 cachePhi->get<1>() = 0;
630 // tet base cache
631 TetPolynomialBase::switchCacheBaseOff<HDIV>({fe_raw_ptr});
632 TetPolynomialBase::switchCacheBaseOn<HDIV>({fe_raw_ptr});
633
635 };
636
637 CHKERR refine_quadrature();
638 }
639 }
640 }
641
643 }
@ VERBOSE
@ NOBASE
Definition definitions.h:59
#define MoFEMFunctionReturnHot(a)
Last executable line of each PETSc function used for error handling. Replaces return()
@ H1
continuous field
Definition definitions.h:85
#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.
constexpr int order
static const bool debug
PetscErrorCode ShapeMBTET(double *N, const double *G_X, const double *G_Y, const double *G_Z, int DIM)
calculate shape functions
Definition fem_tools.c:306
const Tensor2_symmetric_Expr< const ddTensor0< T, Dim, i, j >, typename promote< T, double >::V, Dim, i, j > dd(const Tensor0< T * > &a, const Index< i, Dim > index1, const Index< j, Dim > index2, const Tensor1< int, Dim > &d_ijk, const Tensor1< double, Dim > &d_xyz)
Definition ddTensor0.hpp:33
std::bitset< BITREFLEVEL_SIZE > BitRefLevel
Bit structure attached to each entity identifying to what mesh entity is attached.
Definition Types.hpp:40
#define QUAD_3D_TABLE_SIZE
Definition quad.h:186
static QUAD *const QUAD_3D_TABLE[]
Definition quad.h:187
static PetscBool setSingularity
static std::map< long int, MatrixDouble > mapRefCoords
Managing BitRefLevels.
virtual moab::Interface & get_moab()=0
Deprecated interface functions.
Mesh refinement interface.
static double tetVolume(const double *coords)
Calculate volume of tetrahedron.
Definition Tools.cpp:30
MoFEMErrorCode getInterface(IFACE *&iface) const
Get interface reference to pointer of interface.
int order
Definition quad.h:28
int npoints
Definition quad.h:29
auto save_range

Member Data Documentation

◆ cachePhi

boost::shared_ptr<CGGUserPolynomialBase::CachePhi> EshelbianPlasticity::SetIntegrationAtFrontVolume::cachePhi
private

◆ frontEdges

boost::shared_ptr<Range> EshelbianPlasticity::SetIntegrationAtFrontVolume::frontEdges
private

◆ frontNodes

boost::shared_ptr<Range> EshelbianPlasticity::SetIntegrationAtFrontVolume::frontNodes
private

◆ funRule

FunRule EshelbianPlasticity::SetIntegrationAtFrontVolume::funRule = [](int p) { return 2 * p + 1; }

◆ mapRefCoords

std::map<long int, MatrixDouble> EshelbianPlasticity::SetIntegrationAtFrontVolume::mapRefCoords
inlinestaticprivate

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