combineFaces Class Reference

Combines boundary faces into single face. The faces get the patch of the first face ('the master') More...

Public Member Functions

 ClassName ("combineFaces")
 Runtime type information. More...
 
 combineFaces (const polyMesh &mesh, const bool undoable=false)
 Construct from mesh. More...
 
const labelListmasterFace () const
 If undoable: masterface for every set. More...
 
const labelListsavedPointLabels () const
 If undoable: set of original point labels of stored points. More...
 
labelListList getMergeSets (const scalar featureCos, const scalar minConcaveCos, const labelHashSet &boundaryCells, const bool mergeAcrossPatches=false) const
 Extract lists of all (non-coupled) boundary faces on selected. More...
 
labelListList getMergeSets (const scalar featureCos, const scalar minConcaveCos, const bool mergeAcrossPatches=false) const
 Extract lists of all (non-coupled) boundary faces that can. More...
 
void setRefinement (const labelListList &, polyTopoChange &)
 Play commands into polyTopoChange to combine faces. Gets. More...
 
void updateMesh (const mapPolyMesh &)
 Force recalculation of locally stored data on topological change. More...
 
void setUnrefinement (const labelList &masterFaces, polyTopoChange &meshMod, Map< label > &restoredPoints, Map< label > &restoredFaces, Map< label > &restoredCells)
 Play commands into polyTopoChange to reinsert original faces. More...
 

Static Public Member Functions

static face getOutsideFace (const indirectPrimitivePatch &)
 Gets outside of patch as a face (in mesh point labels) More...
 

Detailed Description

Combines boundary faces into single face. The faces get the patch of the first face ('the master')

Source files

Definition at line 58 of file combineFaces.H.

Constructor & Destructor Documentation

◆ combineFaces()

combineFaces ( const polyMesh mesh,
const bool  undoable = false 
)
explicit

Construct from mesh.

Definition at line 282 of file combineFaces.C.

Member Function Documentation

◆ ClassName()

ClassName ( "combineFaces"  )

Runtime type information.

◆ masterFace()

const labelList & masterFace ( ) const
inline

If undoable: masterface for every set.

Definition at line 142 of file combineFaces.H.

Referenced by meshRefinement::mergePatchFacesUndo().

Here is the caller graph for this function:

◆ savedPointLabels()

const labelList & savedPointLabels ( ) const
inline

If undoable: set of original point labels of stored points.

Definition at line 148 of file combineFaces.H.

Referenced by meshRefinement::mergePatchFacesUndo().

Here is the caller graph for this function:

◆ getMergeSets() [1/2]

Foam::labelListList getMergeSets ( const scalar  featureCos,
const scalar  minConcaveCos,
const labelHashSet boundaryCells,
const bool  mergeAcrossPatches = false 
) const

Extract lists of all (non-coupled) boundary faces on selected.

cells that can be merged. Uses getFaceRegions. Optionally allow faces-on-different-patches to be merged (into the largest area face - could be improved). Note: causes a problem in undoing - all restored faces get the patch/zone from the master face.

Definition at line 299 of file combineFaces.C.

References DynamicList< T, SizeMin >::append(), HashTable< T, Key, Hash >::find(), forAllConstIters, forAllIters, HashTable< T, Key, Hash >::insert(), Foam::magSqr(), Foam::maxMagSqr(), List< T >::setSize(), DynamicList< T, SizeMin >::shrink(), HashTable< T, Key, Hash >::size(), and UList< T >::size().

Referenced by meshRefinement::mergePatchFaces(), and meshRefinement::mergePatchFacesUndo().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ getMergeSets() [2/2]

Foam::labelListList getMergeSets ( const scalar  featureCos,
const scalar  minConcaveCos,
const bool  mergeAcrossPatches = false 
) const

Extract lists of all (non-coupled) boundary faces that can.

be merged. Uses getFaceRegions. See note above about mergeAcrossPatches.

Definition at line 416 of file combineFaces.C.

References forAll, HashSet< Key, Hash >::insert(), and patches.

Here is the call graph for this function:

◆ getOutsideFace()

◆ setRefinement()

void setRefinement ( const labelListList faceSets,
polyTopoChange meshMod 
)

Play commands into polyTopoChange to combine faces. Gets.

labelListList of sets of faces to combine. Does no check for whether resulting face is legal.

Definition at line 582 of file combineFaces.C.

References Foam::abort(), coupled(), PrimitivePatch< FaceList, PointField >::edgeLoops(), f(), Foam::FatalError, FatalErrorInFunction, faceZone::flipMap(), forAll, HashTable< T, Key, Hash >::insert(), n, Foam::nl, patches, polyTopoChange::setAction(), UList< T >::size(), syncTools::syncPointList(), faceZone::whichFace(), polyBoundaryMesh::whichPatch(), Foam::Zero, and zoneID.

Referenced by meshRefinement::mergePatchFaces(), and meshRefinement::mergePatchFacesUndo().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ updateMesh()

void updateMesh ( const mapPolyMesh map)

Force recalculation of locally stored data on topological change.

Definition at line 808 of file combineFaces.C.

References Foam::abort(), f(), Foam::FatalError, FatalErrorInFunction, forAll, Foam::inplaceRenumber(), Foam::nl, mapPolyMesh::reverseFaceMap(), and mapPolyMesh::reversePointMap().

Referenced by meshRefinement::mergePatchFaces(), and meshRefinement::mergePatchFacesUndo().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ setUnrefinement()

void setUnrefinement ( const labelList masterFaces,
polyTopoChange meshMod,
Map< label > &  restoredPoints,
Map< label > &  restoredFaces,
Map< label > &  restoredCells 
)

Play commands into polyTopoChange to reinsert original faces.

No other topo changes can be done inbetween setRefinement and setUnrefinement. Can be called multiple times to undo parts of the last setRefinement call. Gets the master face labels whose sets need to be restored. Returns maps from added restored point to original point label (i.e. content of savedPointLabels_). (only restoredPoints are actually set; rest are just for generalness). See note above about restoring faces from different patches (mergeAcrossPatches)

Definition at line 856 of file combineFaces.C.

References Foam::abort(), HashTable< T, Key, Hash >::cfind(), UList< T >::empty(), Foam::exit(), f(), Foam::FatalError, FatalErrorInFunction, faceZone::flipMap(), forAll, HashTable< T, Key, Hash >::insert(), polyTopoChange::setAction(), UList< T >::size(), faceZone::whichFace(), and zoneID.

Referenced by meshRefinement::mergePatchFacesUndo().

Here is the call graph for this function:
Here is the caller graph for this function:

The documentation for this class was generated from the following files: