Go to the documentation of this file.
22 EFAElement(
unsigned int eid,
unsigned int n_nodes);
35 std::vector<EFAElement *>
40 unsigned int id()
const;
75 std::vector<EFANode *> & master_nodes,
76 std::vector<double> & master_weights)
const = 0;
85 virtual void initCrackTip(std::set<EFAElement *> & CrackTipElements) = 0;
90 virtual bool willCrackTipExtend(std::vector<unsigned int> & split_neighbors)
const = 0;
95 virtual void updateFragments(
const std::set<EFAElement *> & CrackTipElements,
96 std::map<unsigned int, EFANode *> & EmbeddedNodes) = 0;
98 unsigned int n_old_frag_cuts)
const = 0;
101 virtual void createChild(
const std::set<EFAElement *> & CrackTipElements,
102 std::map<unsigned int, EFAElement *> & Elements,
103 std::map<unsigned int, EFAElement *> & newChildElements,
104 std::vector<EFAElement *> & ChildElements,
105 std::vector<EFAElement *> & ParentElements,
106 std::map<unsigned int, EFANode *> & TempNodes) = 0;
110 std::map<unsigned int, EFANode *> & TempNodes,
111 std::map<
EFANode *, std::set<EFAElement *>> & InverseConnectivityMap,
112 bool merge_phantom_edges) = 0;
118 EFANode *& childOfNeighborNode,
120 std::map<unsigned int, EFANode *> & PermanentNodes,
121 std::map<unsigned int, EFANode *> & TempNodes);
virtual void switchNode(EFANode *new_node, EFANode *old_node, bool descend_to_parent)=0
unsigned int getCrackTipNeighbor(unsigned int index) const
virtual unsigned int numFragments() const =0
EFANode * getNode(unsigned int node_id) const
EFAElement * getGeneralNeighbor(unsigned int index) const
virtual void switchEmbeddedNode(EFANode *new_node, EFANode *old_node)=0
virtual unsigned int getNumCuts() const =0
virtual void initCrackTip(std::set< EFAElement * > &CrackTipElements)=0
virtual void connectNeighbors(std::map< unsigned int, EFANode * > &PermanentNodes, std::map< unsigned int, EFANode * > &TempNodes, std::map< EFANode *, std::set< EFAElement * >> &InverseConnectivityMap, bool merge_phantom_edges)=0
virtual void restoreFragment(const EFAElement *const from_elem)=0
virtual void getNonPhysicalNodes(std::set< EFANode * > &non_physical_nodes) const =0
virtual void clearNeighbors()=0
virtual void printElement(std::ostream &ostream)=0
virtual void removePhantomEmbeddedNode()=0
void mergeNodes(EFANode *&childNode, EFANode *&childOfNeighborNode, EFAElement *childOfNeighborElem, std::map< unsigned int, EFANode * > &PermanentNodes, std::map< unsigned int, EFANode * > &TempNodes)
unsigned int numNodes() const
void findGeneralNeighbors(std::map< EFANode *, std::set< EFAElement * >> &InverseConnectivity)
unsigned int getLocalNodeIndex(EFANode *node) const
virtual bool shouldDuplicateForPhantomCorner()=0
EFAElement * getParent() const
EFANode * createLocalNodeFromGlobalNode(const EFANode *global_node) const
std::vector< unsigned int > _crack_tip_neighbors
virtual void fragmentSanityCheck(unsigned int n_old_frag_edges, unsigned int n_old_frag_cuts) const =0
void setNode(unsigned int node_id, EFANode *node)
void addCrackTipNeighbor(EFAElement *neighbor_elem)
std::vector< EFAElement * > _general_neighbors
std::vector< EFANode * > _local_nodes
virtual bool willCrackTipExtend(std::vector< unsigned int > &split_neighbors) const =0
std::vector< EFAElement * > _children
virtual bool isFinalCut() const =0
void clearParentAndChildren()
virtual bool shouldDuplicateForCrackTip(const std::set< EFAElement * > &CrackTipElements)=0
bool _crack_tip_split_element
virtual void updateFragments(const std::set< EFAElement * > &CrackTipElements, std::map< unsigned int, EFANode * > &EmbeddedNodes)=0
virtual bool shouldDuplicateCrackTipSplitElement(const std::set< EFAElement * > &CrackTipElements)=0
unsigned int numCrackTipNeighbors() const
bool isCrackTipSplit() const
virtual void getMasterInfo(EFANode *node, std::vector< EFANode * > &master_nodes, std::vector< double > &master_weights) const =0
virtual unsigned int numInteriorNodes() const =0
unsigned int numChildren() const
virtual void setupNeighbors(std::map< EFANode *, std::set< EFAElement * >> &InverseConnectivityMap)=0
EFAElement(unsigned int eid, unsigned int n_nodes)
virtual bool isCrackTipElement() const =0
virtual void createChild(const std::set< EFAElement * > &CrackTipElements, std::map< unsigned int, EFAElement * > &Elements, std::map< unsigned int, EFAElement * > &newChildElements, std::vector< EFAElement * > &ChildElements, std::vector< EFAElement * > &ParentElements, std::map< unsigned int, EFANode * > &TempNodes)=0
virtual unsigned int getNeighborIndex(const EFAElement *neighbor_elem) const =0
void addChild(EFAElement *child)
EFANode * getGlobalNodeFromLocalNode(const EFANode *local_node) const
virtual bool isPartial() const =0
EFAElement * getChild(unsigned int child_id) const
std::vector< EFANode * > _nodes
unsigned int numGeneralNeighbors() const
bool containsNode(EFANode *node) const
void printNodes(std::ostream &ostream) const
void setParent(EFAElement *parent)
virtual void neighborSanityCheck() const =0
virtual void updateFragmentNode()=0