Loading...
Searching...
No Matches
triSurface Class Reference

Triangulated surface description with patch information. More...

#include <triSurface.H>

Inheritance diagram for triSurface:
Collaboration diagram for triSurface:

Public Types

typedef bool BoundaryMesh
 Placeholder only, but do not remove - it is needed for GeoMesh.
typedef labelledTri face_type
 The face type (same as the underlying PrimitivePatch).
typedef point point_type
 The point type (same as the underlying PrimitivePatch).
Public Types inherited from PrimitivePatch<::Foam::List< labelledTri >, pointField >
enum  surfaceTopo
 Enumeration defining the surface type. Used in check routines. More...
typedef std::remove_reference< ::Foam::List< labelledTri > >::type::value_type face_type
 The face type.
typedef std::remove_reference< pointField >::type::value_type point_type
 The point type.
typedef ::Foam::List< labelledTriFaceListType
 The face list type.
typedef pointField PointFieldType
 The point field type.
typedef face_type FaceType
 Deprecated(2020-03) prefer face_type typedef.
Public Types inherited from List< T >
typedef SubList< TsubList
 Declare type of subList.
Public Types inherited from UList< T >
typedef T value_type
 The value type the list contains.
typedef Tpointer
 The pointer type for non-const access to value_type items.
typedef const Tconst_pointer
 The pointer type for const access to value_type items.
typedef Treference
 The type used for storing into value_type objects.
typedef const Tconst_reference
 The type used for reading from constant value_type objects.
typedef Titerator
 Random access iterator for traversing a UList.
typedef const Tconst_iterator
 Random access iterator for traversing a UList.
typedef label size_type
 The type to represent the size of a UList.
typedef label difference_type
 The difference between iterator objects.
typedef std::reverse_iterator< iteratorreverse_iterator
 Reverse iterator (non-const access).
typedef std::reverse_iterator< const_iteratorconst_reverse_iterator
 Reverse iterator (const access).
using is_List = void
 Have unique tag.

Public Member Functions

 ClassName ("triSurface")
 Runtime type information.
 triSurface ()
 Default construct.
 triSurface (const triSurface &surf)
 Copy construct.
 triSurface (triSurface &&surf)
 Move construct.
 triSurface (const List< labelledTri > &triangles, const geometricSurfacePatchList &patches, const pointField &pts)
 Construct from triangles, patches, points.
 triSurface (List< labelledTri > &triangles, const geometricSurfacePatchList &patches, pointField &pts, const bool reuse)
 Construct from triangles, patches, points. Reuse storage.
 triSurface (const List< labelledTri > &triangles, const pointField &pts)
 Construct from triangles, points. Set patch names to default.
 triSurface (const triFaceList &triangles, const pointField &pts)
 Construct from triangles, points. Set region to 0 and default patchName.
 triSurface (const fileName &name, const scalar scaleFactor=-1)
 Construct from file name (uses extension to determine type).
 triSurface (const fileName &name, const word &fileType, const scalar scaleFactor=-1)
 Construct from file name with given format type.
 triSurface (Istream &is)
 Construct from Istream.
 triSurface (const Time &d)
 Construct from objectRegistry by reading an ".ftr" file.
 triSurface (const IOobject &io, const dictionary &dict, const bool isGlobal=true)
 Read construct using IO to find the file location.
virtual ~triSurface ()
 Destructor.
void clearOut ()
void clearTopology ()
void clearPatchMeshAddr ()
void swap (triSurface &surf)
const geometricSurfacePatchListpatches () const noexcept
geometricSurfacePatchListpatches () noexcept
const List< labelledTri > & surfFaces () const noexcept
 Return const access to the faces.
const labelListListsortedEdgeFaces () const
 Return edge-face addressing sorted (for edges with more than.
const labelListedgeOwner () const
 If 2 face neighbours: label of face where ordering of edge.
const vectorFieldSf () const
 Face area vectors (normals).
const scalarFieldmagSf () const
 Face area magnitudes.
const vectorFieldCf () const
 Face centres.
List< surfZonesortedZones (labelList &faceMap) const
 Sort faces according to zoneIds.
void triFaceFaces (List< face > &plainFaceList) const
 Create a list of faces from the triFaces.
virtual void movePoints (const pointField &pts)
 Move points.
virtual void swapPoints (pointField &pts)
 Swap points. Similar to movePoints, but returns the old points.
virtual void scalePoints (const scalar scaleFactor)
 Scale points. A non-positive factor is ignored.
void checkTriangles (const bool verbose)
 Check/remove duplicate/degenerate triangles.
void checkEdges (const bool verbose)
 Check triply (or more) connected edges.
void cleanup (const bool verbose)
 Remove non-valid triangles.
void compactPoints (labelList &pointMap=const_cast< labelList & >(labelList::null()))
 Remove unused points and renumber faces in local visit order.
void markZone (const boolList &borderEdge, const label facei, const label currentZone, labelList &faceZone) const
 Fill faceZone with currentZone for every face reachable.
label markZones (const boolList &borderEdge, labelList &faceZone) const
 (size and) fills faceZone with zone of face. Zone is area
template<class BoolListType>
void subsetMeshMap (const BoolListType &include, labelList &pointMap, labelList &faceMap) const
 Create mappings for a sub-surface.
triSurface subsetMesh (const UList< bool > &include, labelList &pointMap, labelList &faceMap) const
 Return a new surface subsetted on the selected faces.
triSurface subsetMesh (const bitSet &include, labelList &pointMap, labelList &faceMap) const
 Return a new surface subsetted on the selected faces.
triSurface subsetMesh (const UList< bool > &include) const
 Return a new surface subsetted on the selected faces.
triSurface subsetMesh (const bitSet &include) const
 Return a new surface subsetted on the selected faces.
triSurface subsetMesh (const wordRes &includeNames, const wordRes &excludeNames=wordRes()) const
 Return a new surface subsetted on the selected patch names.
void swapFaces (List< labelledTri > &faceLst)
 Swap the list of faces being addressed.
void transfer (triSurface &surf)
 Alter contents by transferring (triangles, points) components.
void transfer (MeshedSurface< labelledTri > &surf)
 Alter contents by transferring (triangles, points) components.
void write (Ostream &os) const
 Write to Ostream in simple OpenFOAM format.
void write (const fileName &, const bool sortByRegion=false) const
 Generic write routine (uses extension to determine type).
void write (const fileName &filename, const word &fileType, const bool sortByRegion=false) const
 Generic write routine for given format type.
void write (const Time &d) const
 Write to database.
void writeStats (Ostream &os) const
 Write some statistics.
void operator= (const triSurface &surf)
 Copy assignment.
void operator= (triSurface &&surf)
 Move assignment.
void operator= (MeshedSurface< labelledTri > &&surf)
 Move assignment.
Public Member Functions inherited from PrimitivePatch<::Foam::List< labelledTri >, pointField >
 PrimitivePatch (const ::Foam::List< labelledTri > &faces, const pointField &points)
 Construct from components.
 PrimitivePatch (::Foam::List< labelledTri > &&faces, const pointField &points)
 Construct from components, transferring faces.
 PrimitivePatch (::Foam::List< labelledTri > &faces, pointField &points, const bool reuse)
 Construct from components, reuse storage.
 PrimitivePatch (const PrimitivePatch< ::Foam::List< labelledTri >, pointField > &pp)
 Copy construct.
virtual ~PrimitivePatch ()
 Destructor.
void clearOut ()
void clearGeom ()
void clearTopology ()
void clearPatchMeshAddr ()
void swap (PrimitivePatch &)=delete
 Suppress direct swapping, since storage containers may be const.
const Field< point_type > & points () const noexcept
 Return reference to global points.
label nFaces () const noexcept
 Number of faces in the patch.
label nPoints () const
 Number of points supporting patch faces.
label nEdges () const
 Number of edges in patch.
const edgeListedges () const
 Return list of edges, address into LOCAL point list.
const edgeList::subList internalEdges () const
 Return sub-list of internal edges, address into LOCAL point list.
const edgeList::subList boundaryEdges () const
 Return sub-list of boundary edges, address into LOCAL point list.
label nInternalEdges () const
 Number of internal edges.
label nBoundaryEdges () const
 Number of boundary edges == (nEdges() - nInternalEdges()).
bool isInternalEdge (const label edgei) const
 Is internal edge?
const labelListboundaryPoints () const
 Return list of boundary points, address into LOCAL point list.
const labelListListfaceFaces () const
 Return face-face addressing.
const labelListListedgeFaces () const
 Return edge-face addressing.
const labelListListfaceEdges () const
 Return face-edge addressing.
const labelListListpointEdges () const
 Return point-edge addressing.
const labelListListpointFaces () const
 Return point-face addressing.
const List< face_type > & localFaces () const
 Return patch faces addressing into local point list.
labelList boundaryFaces () const
 Extract list of local faces corresponding to the boundary edges.
labelList uniqBoundaryFaces () const
 Extract sorted list of unique local faces associated with the boundary edges.
const labelListmeshPoints () const
 Return labelList of mesh points in patch.
const Map< label > & meshPointMap () const
 Mesh point map.
const Field< point_type > & localPoints () const
 Return pointField of points in patch.
const labelListlocalPointOrder () const
 Return orders the local points for most efficient search.
label whichPoint (const label gp) const
 Given a global point index, return the local point index.
edge meshEdge (const label edgei) const
 From patch edge to global edge using meshPoints.
edge meshEdge (const edge &e) const
 From patch edge to global edge using meshPoints.
label findEdge (const edge &e) const
 Search for edge (local point labels) and return its index in the edge list or -1 if not found.
labelList meshEdges (const edgeList &allEdges, const labelListList &cellEdges, const labelList &faceCells) const
 Return labels of patch edges in the global edge list using cell addressing.
labelList meshEdges (const edgeList &allEdges, const labelListList &pointEdges) const
 Return labels of patch edges into the global edge list using basic edge addressing.
label meshEdge (const label edgei, const edgeList &allEdges, const labelListList &pointEdges) const
 Return label of the local patch edge into the global edge list using basic edge addressing.
labelList meshEdges (const labelUList &edgeLabels, const edgeList &allEdges, const labelListList &pointEdges) const
 Return labels of specified patch edges into the global edge list using basic edge addressing.
const Field< point_type > & faceCentres () const
 Return face centres for patch.
const Field< point_type > & faceAreas () const
 Return face area vectors for patch.
const Field< scalar > & magFaceAreas () const
 Return face area magnitudes for patch.
const Field< point_type > & faceNormals () const
 Return face unit normals for patch.
const Field< point_type > & pointNormals () const
 Return point normals for patch.
Pair< point_typebox () const
 The enclosing (bounding) box for the patch points.
scalar sphere (const label facei) const
 The enclosing (bounding) sphere radius^2 for specified face.
bool hasFaceAreas () const
bool hasFaceCentres () const
bool hasFaceNormals () const
bool hasPointNormals () const
bool hasBoundaryPoints () const
bool hasEdges () const
bool hasFaceFaces () const
bool hasEdgeFaces () const
bool hasFaceEdges () const
bool hasPointEdges () const
bool hasPointFaces () const
bool hasMeshPoints () const
bool hasMeshPointMap () const
List< objectHitprojectPoints (const ToPatch &targetPatch, const Field< point_type > &projectionDirection, const intersection::algorithm=intersection::FULL_RAY, const intersection::direction=intersection::VECTOR) const
 Project vertices of patch onto another patch.
List< objectHitprojectFaceCentres (const ToPatch &targetPatch, const Field< point_type > &projectionDirection, const intersection::algorithm=intersection::FULL_RAY, const intersection::direction=intersection::VECTOR) const
 Project vertices of patch onto another patch.
const labelListListedgeLoops () const
 Return list of closed loops of boundary vertices.
surfaceTopo surfaceType (labelHashSet *badEdgesPtr=nullptr) const
 Calculate surface type formed by patch, optionally recording the indices of illegal edges.
bool checkTopology (const bool report=false, labelHashSet *pointSetPtr=nullptr) const
 Check surface formed by patch for manifoldness (see above).
bool checkPointManifold (const bool report=false, labelHashSet *pointSetPtr=nullptr) const
 Checks primitivePatch for faces sharing point but not edge.
virtual void movePoints (const Field< point_type > &)
 Correct patch after moving points.
void operator= (const PrimitivePatch< ::Foam::List< labelledTri >, pointField > &rhs)
 Copy assign faces. Leave points alone (could be a reference).
void operator= (PrimitivePatch< ::Foam::List< labelledTri >, pointField > &&rhs)
 Move assign faces. Leave points alone (could be a reference).
label whichEdge (const edge &e) const
 Identical to findEdge.
Foam::List< Foam::objectHitprojectPoints (const ToPatch &targetPatch, const Field< typename Foam::PrimitivePatch< ::Foam::List< labelledTri >, pointField >::point_type > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const
Foam::List< Foam::objectHitprojectFaceCentres (const ToPatch &targetPatch, const Field< typename Foam::PrimitivePatch< ::Foam::List< labelledTri >, pointField >::point_type > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const
Public Member Functions inherited from PrimitivePatchBase
 ClassName ("PrimitivePatch")
 Runtime type information.
 PrimitivePatchBase ()=default
 Default construct.
Public Member Functions inherited from List< T >
constexpr List () noexcept
 Default construct.
 List (const label len)
 Construct with given size.
 List (const label len, const T &val)
 Construct with given size and value for all elements.
 List (const label len, Foam::zero)
 Construct with given size initializing all elements to zero.
 List (Foam::one, const T &val)
 Construct with length=1, copying the value as the only content.
 List (Foam::one, T &&val)
 Construct with length=1, moving the value as the only content.
 List (Foam::one, Foam::zero)
 Construct with length=1, initializing content to zero.
 List (const List< T > &list)
 Copy construct from list.
 List (const UList< T > &list)
 Copy construct contents from list.
 List (List< T > &list, bool reuse)
 Construct as copy or re-use as specified.
 List (const UList< T > &list, const labelUList &indices)
 Copy construct subset of list.
template<unsigned N>
 List (const UList< T > &list, const FixedList< label, N > &indices)
 Copy construct subset of list.
template<unsigned N>
 List (const FixedList< T, N > &list)
 Construct as copy of FixedList<T, N>.
 List (const UPtrList< T > &list)
 Construct as copy of UPtrList<T> content.
template<class Addr>
 List (const IndirectListBase< T, Addr > &list)
 Construct as copy of IndirectList contents.
 List (std::initializer_list< T > list)
 Construct from an initializer list.
 List (List< T > &&list) noexcept
 Move construct from List.
template<int SizeMin>
 List (DynamicList< T, SizeMin > &&list)
 Move construct from DynamicList.
 List (Istream &is)
 Construct from Istream.
autoPtr< List< T > > clone () const
 Clone.
 ~List ()
 Destructor.
void clear ()
 Clear the list, i.e. set size to zero.
void resize (const label len)
 Adjust allocated size of list.
void resize (const label len, const T &val)
 Adjust allocated size of list and set val for new elements.
void resize_copy (label count, const label len)
 Change allocated size of list, retaining the first count elements.
void resize_fill (const label len, const T &val)
 Adjust allocated size of list and set val for all elements.
void resize_nocopy (const label len)
 Adjust allocated size of list without necessarily.
void transfer (List< T > &list)
 Transfer the contents of the argument List into this list and annul the argument list.
template<int SizeMin>
void transfer (DynamicList< T, SizeMin > &list)
 Transfer the contents of the argument List into this list and annul the argument list.
TnewElmt (const label i)
 Return subscript-checked element of UList and resizing the list if required.
template<class... Args>
Templace_back (Args &&... args)
 Construct an element at the end of the list, return reference to the new list element.
void push_back (const T &val)
 Append an element at the end of the list.
void push_back (T &&val)
 Move append an element at the end of the list.
void push_back (const UList< T > &list)
 Append a List to the end of this list.
template<class Addr>
void push_back (const IndirectListBase< T, Addr > &list)
 Append IndirectList contents at the end of this list.
label push_uniq (const T &val)
 Append an element if not already in the list.
void pop_back (label n=1)
 Reduce size by 1 or more elements. Can be called on an empty list.
void operator= (const UList< T > &list)
 Assignment to UList operator. Takes linear time.
void operator= (const List< T > &list)
 Assignment operator. Takes linear time.
template<class Addr>
void operator= (const IndirectListBase< T, Addr > &list)
 Assignment from IndirectList. Takes linear time.
template<unsigned N>
void operator= (const FixedList< T, N > &list)
 Copy assignment from FixedList.
void operator= (std::initializer_list< T > list)
 Assignment to an initializer list.
void operator= (const T &val)
 Assignment of all entries to the given value.
void operator= (Foam::zero)
 Assignment of all entries to zero.
void operator= (List< T > &&list)
 Move assignment. Takes constant time.
template<int SizeMin>
void operator= (DynamicList< T, SizeMin > &&list)
 Move assignment. Takes constant time.
IstreamreadList (Istream &is)
 Read List from Istream, discarding contents of existing List.
void shallowCopy (const UList< T > &)=delete
 No shallowCopy permitted.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool set (const label i, bool val=true)
 A bitSet::set() method for a list of bool.
void append (const T &val)
 Append an element at the end of the list.
void append (T &&val)
 Move append an element at the end of the list.
void append (const UList< T > &list)
 Append a List to the end of this list.
template<class Addr>
void append (const IndirectListBase< T, Addr > &list)
 Append IndirectList contents at the end of this list.
label appendUniq (const T &val)
 Same as push_uniq().
void setSize (label n)
 Alias for resize().
void setSize (label n, const T &val)
 Alias for resize().
template<typename E>
 List (const Expression::ListExpression< E > &expr)
 Construct from value expression.
template<typename E>
void operator= (const Expression::ListExpression< E > &expr)
 Assign values from expression.
void resize (const label len)
Public Member Functions inherited from UList< T >
 UList (const UList< T > &) noexcept=default
 Copy construct, shallow copy.
 UList (UList< T > &&) noexcept=default
 Move construct, shallow copy.
UList< T > & operator= (const UList< T > &)=delete
 No copy assignment (default: shallow copy).
UList< T > & operator= (UList< T > &&) noexcept=default
 Move assignment, shallow copy.
constexpr UList () noexcept
 Default construct, zero-sized and nullptr.
 UList (T *__restrict__ ptr, const label len) noexcept
 Construct from components.
 UList (SubList< T > &&) noexcept
 Move construct from a SubList, shallow copy.
label fcIndex (const label i) const noexcept
 The forward circular index. The next index in the list which returns to the first at the end of the list.
label rcIndex (const label i) const noexcept
 The reverse circular index. The previous index in the list which returns to the last at the beginning of the list.
const TfcValue (const label i) const
 Return forward circular value (ie, next value in the list).
TfcValue (const label i)
 Return forward circular value (ie, next value in the list).
const TrcValue (const label i) const
 Return reverse circular value (ie, previous value in the list).
TrcValue (const label i)
 Return reverse circular value (ie, previous value in the list).
const Tcdata () const noexcept
 Return pointer to the underlying array serving as data storage.
Tdata () noexcept
 Return pointer to the underlying array serving as data storage.
const char * cdata_bytes () const noexcept
 Return pointer to the underlying array serving as data storage,.
char * data_bytes () noexcept
 Return pointer to the underlying array serving as data storage,.
Tfront ()
 Access first element of the list, position [0].
const Tfront () const
 Access first element of the list.
Tback ()
 Access last element of the list, position [size()-1].
const Tback () const
 Access last element of the list, position [size()-1].
std::streamsize size_bytes () const noexcept
 Number of contiguous bytes for the List data.
std::streamsize byteSize () const
 Number of contiguous bytes for the List data, runtime FatalError if type is not contiguous.
void checkStart (const label start) const
 Check start is within valid range [0,size).
void checkSize (const label size) const
 Check size is within valid range [0,size].
void checkRange (const label start, const label len) const
 Check that start and length define a valid range.
void checkIndex (const label i) const
 Check index is within valid range [0,size).
bool uniform () const
 True if all entries have identical values, and list is non-empty.
bool contains (const T &val) const
 True if the value is contained in the list.
bool contains (const T &val, label pos, label len=-1) const
 Is the value contained in the list?
label find (const T &val) const
 Find index of the first occurrence of the value.
label find (const T &val, label pos, label len=-1) const
 Find index of the first occurrence of the value.
label rfind (const T &val, label pos=-1) const
 Find index of the last occurrence of the value.
void moveFirst (const label i)
 Move element to the first position.
void moveLast (const label i)
 Move element to the last position.
void swapFirst (const label i)
 Swap element with the first element. Fatal on an empty list.
void swapLast (const label i)
 Swap element with the last element. Fatal on an empty list.
void shallowCopy (T *__restrict__ ptr, const label len) noexcept
 Copy the pointer and size.
void shallowCopy (std::nullptr_t) noexcept
 Copy nullptr and zero size.
void shallowCopy (const UList< T > &list) noexcept
 Copy the pointer and size held by the given UList.
void deepCopy (const UList< T > &list)
 Copy elements of the given UList. Sizes must match!
template<class Addr>
void deepCopy (const IndirectListBase< T, Addr > &list)
 Copy elements of the given indirect list. Sizes must match!
SubList< Tslice (const label pos, label len=-1)
 Return SubList slice (non-const access) - no range checking.
const SubList< Tslice (const label pos, label len=-1) const
 Return SubList slice (const access) - no range checking.
SubList< Tslice (const labelRange &range)
 Return SubList slice (non-const access) - with range checking.
const SubList< Tslice (const labelRange &range) const
 Return SubList slice (const access) - with range checking.
Toperator[] (const label i)
 Return element of UList.
const Toperator[] (const label i) const
 Return element of constant UList.
 operator const Foam::List< T > & () const
 Allow cast to a const List<T>&.
void operator= (const T &val)
 Assignment of all entries to the given value.
void operator= (Foam::zero)
 Assignment of all entries to zero.
iterator begin () noexcept
 Return an iterator to begin traversing the UList.
iterator end () noexcept
 Return an iterator to end traversing the UList.
iterator begin (const label i) noexcept
 Return iterator at offset i from begin, clamped to [0,size] range.
const_iterator cbegin () const noexcept
 Return const_iterator to begin traversing the constant UList.
const_iterator cend () const noexcept
 Return const_iterator to end traversing the constant UList.
const_iterator begin () const noexcept
 Return const_iterator to begin traversing the constant UList.
const_iterator end () const noexcept
 Return const_iterator to end traversing the constant UList.
const_iterator cbegin (const label i) const noexcept
 Return const_iterator at offset i from begin, clamped to [0,size] range.
const_iterator begin (const label i) const noexcept
 Return const_iterator at offset i from begin, clamped to [0,size] range.
reverse_iterator rbegin ()
 Return reverse_iterator to begin reverse traversing the UList.
reverse_iterator rend ()
 Return reverse_iterator to end reverse traversing the UList.
const_reverse_iterator crbegin () const
 Return const_reverse_iterator to begin reverse traversing the UList.
const_reverse_iterator crend () const
 Return const_reverse_iterator to end reverse traversing the UList.
const_reverse_iterator rbegin () const
 Return const_reverse_iterator to begin reverse traversing the UList.
const_reverse_iterator rend () const
 Return const_reverse_iterator to end reverse traversing the UList.
bool empty () const noexcept
 True if List is empty (ie, size() is zero).
label size () const noexcept
 The number of elements in the container.
label capacity () const noexcept
 Size of the underlying storage.
void swap (UList< T > &list) noexcept
 Swap content with another UList of the same type in constant time.
bool operator== (const UList< T > &list) const
 Equality operation on ULists of the same type.
bool operator!= (const UList< T > &list) const
 The opposite of the equality operation. Takes linear time.
bool operator< (const UList< T > &list) const
 Compare two ULists lexicographically. Takes linear time.
bool operator> (const UList< T > &list) const
 Compare two ULists lexicographically. Takes linear time.
bool operator<= (const UList< T > &list) const
 Return true if !(a > b). Takes linear time.
bool operator>= (const UList< T > &list) const
 Return true if !(a < b). Takes linear time.
IstreamreadList (Istream &is)
 Read List contents from Istream.
void writeEntry (const word &keyword, Ostream &os) const
 Write the List as a dictionary entry with keyword.
OstreamwriteList (Ostream &os, const label shortLen=0) const
 Write List, with line-breaks in ASCII when length exceeds shortLen.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool all () const
 True if all entries are 'true' or if the list is empty.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool any () const
 True if any entries are 'true'.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool none () const
 True if no entries are 'true'.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool test (const label i) const
 Test bool value at specified position, always false for out-of-range access.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool get (const label i) const
 Return bool value at specified position, always false for out-of-range access.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_bool_v<TypeT>>>
bool unset (const label i)
 Unset the bool entry at specified position, always false for out-of-range access.
template<class TypeT = T, class = std::enable_if_t<stdFoam::is_char_v<TypeT>>>
std::string_view view () const
 Return a string_view of the charList. Content is non-modifiable.
Tfirst ()
 Access first element of the list, position [0].
const Tfirst () const
 Access first element of the list.
Tlast ()
 Access last element of the list, position [size()-1].
const Tlast () const
 Access last element of the list, position [size()-1].
bool found (const T &val, label pos=0) const
 Same as contains().
auto expr () const
 Wrap value as expression.
template<typename E>
void operator= (const Expression::ListExpression< E > &expr)
 Assign values from expression.

Static Public Member Functions

static fileName triSurfInstance (const Time &)
 Name of triSurface directory to use.
static wordHashSet readTypes ()
 Known readable file-types, including via friends or proxies.
static wordHashSet writeTypes ()
 Known writable file-types, including via friends or proxies.
static bool canReadType (const word &fileType, bool verbose=false)
 Can we read this file format?
static bool canWriteType (const word &fileType, bool verbose=false)
 Can we write this file format?
static bool canRead (const fileName &name, bool verbose=false)
 Can we read this file format?
static fileName relativeFilePath (const IOobject &io, const fileName &f, const bool isGlobal=true)
 Return fileName.
static fileName checkFile (const IOobject &io, const bool isGlobal=true)
 Return fileName to load IOobject from.
static fileName checkFile (const IOobject &io, const dictionary &dict, const bool isGlobal=true)
 Return fileName to load IOobject from.
static fileName findFile (const IOobject &io, const bool isGlobal=true)
 Use IOobject information to resolve file to load from, or empty if the file does not exist.
static fileName findFile (const IOobject &io, const dictionary &dict, const bool isGlobal=true)
 Use IOobject information to resolve file to load from, or empty if the file does not exist.
static autoPtr< triSurfaceNew (const fileName &name, const word &fileType)
 Read construct from filename with given file type.
static autoPtr< triSurfaceNew (const fileName &name)
 Read construct from filename (file type implicit from extension).
Static Public Member Functions inherited from List< T >
static const List< T > & null () noexcept
 Return a null List (reference to a nullObject). Behaves like an empty List.
Static Public Member Functions inherited from UList< T >
static const UList< T > & null () noexcept
 Return a null UList (reference to a nullObject). Behaves like an empty UList.
static constexpr label max_size () noexcept
 The size of the largest possible UList.

Protected Member Functions

pointFieldstoredPoints ()
 Non-const access to global points.
List< labelledTri > & storedFaces ()
 Non-const access to the faces.
Protected Member Functions inherited from UList< T >
void setAddressableSize (const label n) noexcept
 Set addressed size to be inconsistent with allocated storage.
void size (const label n)
 Older name for setAddressableSize.
void writeEntry (Ostream &os) const
 Write the UList with its compound type.
labelRange validateRange (const labelRange &requestedRange) const
 Return a validated (start,size) subset range, which means that it always addresses a valid section of the list.
void fill_uniform (const T &val)
 Assign all entries to the given value.
void fill_uniform (Foam::zero)
 Assign all entries to zero.

Friends

Istreamoperator>> (Istream &is, triSurface &s)
Ostreamoperator<< (Ostream &os, const triSurface &s)

Detailed Description

Triangulated surface description with patch information.

Source files

Definition at line 71 of file triSurface.H.

Member Typedef Documentation

◆ BoundaryMesh

typedef bool BoundaryMesh

Placeholder only, but do not remove - it is needed for GeoMesh.

Definition at line 251 of file triSurface.H.

◆ face_type

The face type (same as the underlying PrimitivePatch).

Definition at line 256 of file triSurface.H.

◆ point_type

typedef point point_type

The point type (same as the underlying PrimitivePatch).

Definition at line 261 of file triSurface.H.

Constructor & Destructor Documentation

◆ triSurface() [1/12]

◆ triSurface() [2/12]

triSurface ( const triSurface & surf)

Copy construct.

Definition at line 435 of file triSurface.C.

References patches(), PrimitivePatch<::Foam::List< labelledTri >, pointField >::points(), and triSurface().

Here is the call graph for this function:

◆ triSurface() [3/12]

triSurface ( triSurface && surf)

Move construct.

Definition at line 444 of file triSurface.C.

References transfer(), and triSurface().

Here is the call graph for this function:

◆ triSurface() [4/12]

triSurface ( const List< labelledTri > & triangles,
const geometricSurfacePatchList & patches,
const pointField & pts )

Construct from triangles, patches, points.

Definition at line 452 of file triSurface.C.

References patches(), pts, and triangles.

Here is the call graph for this function:

◆ triSurface() [5/12]

triSurface ( List< labelledTri > & triangles,
const geometricSurfacePatchList & patches,
pointField & pts,
const bool reuse )

Construct from triangles, patches, points. Reuse storage.

Definition at line 466 of file triSurface.C.

References patches(), pts, and triangles.

Here is the call graph for this function:

◆ triSurface() [6/12]

triSurface ( const List< labelledTri > & triangles,
const pointField & pts )

Construct from triangles, points. Set patch names to default.

Definition at line 481 of file triSurface.C.

References pts, and triangles.

◆ triSurface() [7/12]

triSurface ( const triFaceList & triangles,
const pointField & pts )

Construct from triangles, points. Set region to 0 and default patchName.

Definition at line 496 of file triSurface.C.

References pts, and triangles.

◆ triSurface() [8/12]

triSurface ( const fileName & name,
const scalar scaleFactor = -1 )
explicit

Construct from file name (uses extension to determine type).

Optional (positive, non-zero) point scaling is possible.

Definition at line 511 of file triSurface.C.

References Foam::name(), and triSurface().

Here is the call graph for this function:

◆ triSurface() [9/12]

triSurface ( const fileName & name,
const word & fileType,
const scalar scaleFactor = -1 )

Construct from file name with given format type.

If the format type is "", uses the file extension.

Definition at line 521 of file triSurface.C.

References Foam::name(), scalePoints(), and triSurface().

Here is the call graph for this function:

◆ triSurface() [10/12]

triSurface ( Istream & is)
explicit

Construct from Istream.

Definition at line 275 of file triSurfaceIO.C.

References triSurface().

Here is the call graph for this function:

◆ triSurface() [11/12]

triSurface ( const Time & d)
explicit

Construct from objectRegistry by reading an ".ftr" file.

Definition at line 285 of file triSurfaceIO.C.

References Time::caseName(), Foam::GlobalIOList< Tuple2< scalar, vector > >::typeName, Time::path(), triSurface(), and triSurfInstance().

Here is the call graph for this function:

◆ triSurface() [12/12]

triSurface ( const IOobject & io,
const dictionary & dict,
const bool isGlobal = true )

Read construct using IO to find the file location.

Dictionary may contain the following entries:

  • file = alternative file name (default is dictionary name)
  • fileType = file format (default is from file extension)
  • scale (eg, 0.001: mm to m)
Parameters
isGlobalresolve as a global file

Definition at line 300 of file triSurfaceIO.C.

References checkFile(), dict, io, word::null, scalePoints(), and triSurface().

Here is the call graph for this function:

◆ ~triSurface()

~triSurface ( )
virtual

Destructor.

Definition at line 538 of file triSurface.C.

References clearOut().

Here is the call graph for this function:

Member Function Documentation

◆ storedPoints()

pointField & storedPoints ( )
inlineprotected

Non-const access to global points.

Definition at line 230 of file triSurface.H.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::points().

Referenced by movePoints(), operator=(), scalePoints(), swap(), swapPoints(), and transfer().

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

◆ storedFaces()

List< labelledTri > & storedFaces ( )
inlineprotected

Non-const access to the faces.

Definition at line 238 of file triSurface.H.

Referenced by compactPoints(), operator=(), swap(), swapFaces(), and transfer().

Here is the caller graph for this function:

◆ ClassName()

ClassName ( "triSurface" )

Runtime type information.

References dict, f(), io, Foam::name(), patches(), pts, triangles, and triSurface().

Here is the call graph for this function:

◆ triSurfInstance()

Foam::fileName triSurfInstance ( const Time & d)
static

Name of triSurface directory to use.

Definition at line 67 of file triSurface.C.

References Time::caseName(), TimePaths::constant(), Foam::endl(), Foam::GlobalIOList< Tuple2< scalar, vector > >::typeName, Foam::isFile(), Time::path(), Foam::Pout, UList< T >::size(), TimeState::timeOutputValue(), and TimePaths::times().

Referenced by triSurface(), and write().

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

◆ readTypes()

Foam::wordHashSet readTypes ( )
static

Known readable file-types, including via friends or proxies.

Definition at line 33 of file triSurfaceIO.C.

References HashSet< Key, Hash >::insert(), MeshedSurface< Face >::readTypes(), and UnsortedMeshedSurface< Face >::readTypes().

Referenced by canReadType(), and New().

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

◆ writeTypes()

Foam::wordHashSet writeTypes ( )
static

Known writable file-types, including via friends or proxies.

Definition at line 51 of file triSurfaceIO.C.

References HashSet< Key, Hash >::insert(), and MeshedSurfaceProxy< Face >::writeTypes().

Referenced by canWriteType(), and write().

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

◆ canReadType()

bool canReadType ( const word & fileType,
bool verbose = false )
static

Can we read this file format?

Definition at line 68 of file triSurfaceIO.C.

References surfaceFormatsCore::checkSupport(), and readTypes().

Referenced by canRead().

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

◆ canWriteType()

bool canWriteType ( const word & fileType,
bool verbose = false )
static

Can we write this file format?

Definition at line 80 of file triSurfaceIO.C.

References surfaceFormatsCore::checkSupport(), and writeTypes().

Here is the call graph for this function:

◆ canRead()

bool canRead ( const fileName & name,
bool verbose = false )
static

Can we read this file format?

Definition at line 92 of file triSurfaceIO.C.

References canReadType(), and Foam::name().

Referenced by triSurfaceLoader::readDir().

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

◆ relativeFilePath()

Foam::fileName relativeFilePath ( const IOobject & io,
const fileName & f,
const bool isGlobal = true )
static

Return fileName.

If fileName is relative gets treated as local to IOobject.

Parameters
isGlobalresolve as a global file

Definition at line 105 of file triSurfaceIO.C.

References f(), io, and surfaceFormatsCore::relativeFilePath().

Here is the call graph for this function:

◆ checkFile() [1/2]

Foam::fileName checkFile ( const IOobject & io,
const bool isGlobal = true )
static

Return fileName to load IOobject from.

Fatal if the file does not exist

Parameters
isGlobalresolve as a global file

Definition at line 116 of file triSurfaceIO.C.

References surfaceFormatsCore::checkFile(), and io.

Referenced by triSurface().

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

◆ checkFile() [2/2]

Foam::fileName checkFile ( const IOobject & io,
const dictionary & dict,
const bool isGlobal = true )
static

Return fileName to load IOobject from.

Supports optional override of fileName with "file" entry Fatal if the file does not exist

Parameters
isGlobalresolve as a global file

Definition at line 126 of file triSurfaceIO.C.

References surfaceFormatsCore::checkFile(), dict, and io.

Here is the call graph for this function:

◆ findFile() [1/2]

Foam::fileName findFile ( const IOobject & io,
const bool isGlobal = true )
static

Use IOobject information to resolve file to load from, or empty if the file does not exist.

Parameters
isGlobalresolve as a global file

Definition at line 137 of file triSurfaceIO.C.

References surfaceFormatsCore::findFile(), and io.

Referenced by distributedTriSurfaceMesh::distributedTriSurfaceMesh(), and distributedTriSurfaceMesh::distributedTriSurfaceMesh().

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

◆ findFile() [2/2]

Foam::fileName findFile ( const IOobject & io,
const dictionary & dict,
const bool isGlobal = true )
static

Use IOobject information to resolve file to load from, or empty if the file does not exist.

Supports optional override of fileName with "file" entry

Parameters
isGlobalresolve as a global file

Definition at line 147 of file triSurfaceIO.C.

References dict, surfaceFormatsCore::findFile(), and io.

Here is the call graph for this function:

◆ New() [1/2]

Foam::autoPtr< Foam::triSurface > New ( const fileName & name,
const word & fileType )
static

Read construct from filename with given file type.

Definition at line 29 of file triSurfaceNew.C.

References Foam::exit(), Foam::FatalError, FatalErrorInFunction, Foam::flatOutput(), found, Foam::name(), autoPtr< T >::New(), New(), Foam::nl, and readTypes().

Referenced by New().

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

◆ New() [2/2]

Foam::autoPtr< Foam::triSurface > New ( const fileName & name)
static

Read construct from filename (file type implicit from extension).

Definition at line 133 of file triSurfaceNew.C.

References Foam::name(), and Foam::New().

Here is the call graph for this function:

◆ clearOut()

◆ clearTopology()

void clearTopology ( )

Definition at line 546 of file triSurface.C.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::clearTopology().

Referenced by clearOut(), and scalePoints().

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

◆ clearPatchMeshAddr()

void clearPatchMeshAddr ( )

Definition at line 554 of file triSurface.C.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::clearPatchMeshAddr().

Referenced by clearOut().

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

◆ swap()

void swap ( triSurface & surf)

Definition at line 568 of file triSurface.C.

References clearOut(), patches(), storedFaces(), storedPoints(), and triSurface().

Referenced by transfer().

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

◆ patches() [1/2]

◆ patches() [2/2]

geometricSurfacePatchList & patches ( )
inlinenoexcept

Definition at line 514 of file triSurface.H.

References Foam::noexcept.

◆ surfFaces()

const List< labelledTri > & surfFaces ( ) const
inlinenoexcept

Return const access to the faces.

Definition at line 522 of file triSurface.H.

References Foam::noexcept.

Referenced by write().

Here is the caller graph for this function:

◆ sortedEdgeFaces()

const Foam::labelListList & sortedEdgeFaces ( ) const

Return edge-face addressing sorted (for edges with more than.

2 faces) according to the angle around the edge. Orientation is anticlockwise looking from edge.vec(localPoints())

Definition at line 584 of file triSurface.C.

◆ edgeOwner()

const Foam::labelList & edgeOwner ( ) const

If 2 face neighbours: label of face where ordering of edge.

is consistent with righthand walk. If 1 neighbour: label of only face. If >2 neighbours: undetermined.

Definition at line 595 of file triSurface.C.

◆ Sf()

const vectorField & Sf ( ) const
inline

Face area vectors (normals).

Definition at line 549 of file triSurface.H.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::faceAreas().

Here is the call graph for this function:

◆ magSf()

const scalarField & magSf ( ) const
inline

Face area magnitudes.

Definition at line 557 of file triSurface.H.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::magFaceAreas().

Here is the call graph for this function:

◆ Cf()

const vectorField & Cf ( ) const
inline

Face centres.

Definition at line 565 of file triSurface.H.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::faceCentres().

Here is the call graph for this function:

◆ sortedZones()

Foam::List< Foam::surfZone > sortedZones ( labelList & faceMap) const

Sort faces according to zoneIds.

Returns a surfZoneList and sets faceMap to index within faces() (i.e. map from original,unsorted to sorted)

Definition at line 703 of file triSurface.C.

References Foam::faceMap(), forAll, patches(), and patches.

Referenced by write().

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

◆ triFaceFaces()

void triFaceFaces ( List< face > & plainFaceList) const

Create a list of faces from the triFaces.

Definition at line 717 of file triSurface.C.

References forAll, UList< T >::operator[](), List< T >::setSize(), and UList< T >::size().

Referenced by isoSurfaceCell::isoSurfaceCell(), and isoSurfacePoint::isoSurfacePoint().

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

◆ movePoints()

void movePoints ( const pointField & pts)
virtual

Move points.

Reimplemented in triSurfaceMesh.

Definition at line 606 of file triSurface.C.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::movePoints(), pts, and storedPoints().

Referenced by triSurfaceMesh::movePoints().

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

◆ swapPoints()

void swapPoints ( pointField & pts)
virtual

Swap points. Similar to movePoints, but returns the old points.

Definition at line 619 of file triSurface.C.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::movePoints(), pts, and storedPoints().

Referenced by compactPoints(), isoSurfaceCell::isoSurfaceCell(), isoSurfacePoint::isoSurfacePoint(), and triSurfaceLoader::load().

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

◆ scalePoints()

void scalePoints ( const scalar scaleFactor)
virtual

Scale points. A non-positive factor is ignored.

Definition at line 632 of file triSurface.C.

References clearTopology(), Foam::equal(), PrimitivePatch<::Foam::List< labelledTri >, pointField >::movePoints(), and storedPoints().

Referenced by triSurface(), and triSurface().

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

◆ checkTriangles()

void checkTriangles ( const bool verbose)

◆ checkEdges()

void checkEdges ( const bool verbose)

Check triply (or more) connected edges.

Definition at line 295 of file triSurface.C.

References PrimitivePatch<::Foam::List< labelledTri >, pointField >::edgeFaces(), PrimitivePatch<::Foam::List< labelledTri >, pointField >::edges(), UList< T >::empty(), Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, forAll, UList< T >::size(), and WarningInFunction.

Referenced by cleanup().

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

◆ cleanup()

void cleanup ( const bool verbose)

Remove non-valid triangles.

Definition at line 649 of file triSurface.C.

References checkEdges(), checkTriangles(), and clearOut().

Here is the call graph for this function:

◆ compactPoints()

void compactPoints ( labelList & pointMap = const_cast<labelList&>(labelList::null()))

Remove unused points and renumber faces in local visit order.

Parameters
[out]pointMapfrom new to old points (optional)

Definition at line 663 of file triSurface.C.

References DynamicList< T, SizeMin >::append(), clearOut(), f(), Foam::notNull(), points, UList< T >::size(), storedFaces(), swapPoints(), and List< T >::transfer().

Here is the call graph for this function:

◆ markZone()

void markZone ( const boolList & borderEdge,
const label facei,
const label currentZone,
labelList & faceZone ) const

Fill faceZone with currentZone for every face reachable.

from facei without crossing edge marked in borderEdge. Note: faceZone has to be sized nFaces before calling this fun.

Definition at line 730 of file triSurface.C.

References Foam::abort(), DynamicList< T, SizeMin >::append(), PrimitivePatch<::Foam::List< labelledTri >, pointField >::edgeFaces(), UList< T >::empty(), PrimitivePatch<::Foam::List< labelledTri >, pointField >::faceEdges(), Foam::FatalError, FatalErrorInFunction, and UList< T >::size().

Referenced by markZones().

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

◆ markZones()

Foam::label markZones ( const boolList & borderEdge,
labelList & faceZone ) const

(size and) fills faceZone with zone of face. Zone is area

reachable by edge crossing without crossing borderEdge (bool for every edge in surface). Returns number of zones.

Definition at line 789 of file triSurface.C.

References Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, markZone(), PrimitivePatch<::Foam::List< labelledTri >, pointField >::nEdges(), List< T >::setSize(), and UList< T >::size().

Referenced by booleanSurface::booleanSurface().

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

◆ subsetMeshMap()

template<class BoolListType>
void subsetMeshMap ( const BoolListType & include,
labelList & pointMap,
labelList & faceMap ) const
inline

Create mappings for a sub-surface.

Parameters
[in]includethe faces to select
[out]pointMapfrom new to old localPoints
[out]faceMapfrom new to old localFaces

Definition at line 665 of file triSurface.H.

References Foam::faceMap(), and PatchTools::subsetMap().

Referenced by subsetMesh(), and subsetMesh().

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

◆ subsetMesh() [1/5]

Foam::triSurface subsetMesh ( const UList< bool > & include,
labelList & pointMap,
labelList & faceMap ) const

Return a new surface subsetted on the selected faces.

Parameters
[in]includethe faces to select
[out]pointMapfrom new to old localPoints
[out]faceMapfrom new to old localFaces

Definition at line 872 of file triSurface.C.

References Foam::faceMap(), and subsetMeshMap().

Referenced by booleanSurface::booleanSurface(), booleanSurface::booleanSurface(), subsetMesh(), subsetMesh(), and subsetMesh().

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

◆ subsetMesh() [2/5]

Foam::triSurface subsetMesh ( const bitSet & include,
labelList & pointMap,
labelList & faceMap ) const

Return a new surface subsetted on the selected faces.

Parameters
[in]includethe faces to select
[out]pointMapfrom subsetMeshMap
[out]faceMapfrom subsetMeshMap

Definition at line 885 of file triSurface.C.

References Foam::faceMap(), and subsetMeshMap().

Here is the call graph for this function:

◆ subsetMesh() [3/5]

Foam::triSurface subsetMesh ( const UList< bool > & include) const

Return a new surface subsetted on the selected faces.

Parameters
[in]includethe faces to select

Definition at line 898 of file triSurface.C.

References Foam::faceMap(), and subsetMesh().

Here is the call graph for this function:

◆ subsetMesh() [4/5]

Foam::triSurface subsetMesh ( const bitSet & include) const

Return a new surface subsetted on the selected faces.

Parameters
[in]includethe faces to select

Definition at line 906 of file triSurface.C.

References Foam::faceMap(), and subsetMesh().

Here is the call graph for this function:

◆ subsetMesh() [5/5]

Foam::triSurface subsetMesh ( const wordRes & includeNames,
const wordRes & excludeNames = wordRes() ) const

Return a new surface subsetted on the selected patch names.

Parameters
[in]includeNamessurface patch names to include
[in]excludeNamessurface patch names to exclude
See also
Foam::stringListOps::findMatching for details about matching

Definition at line 914 of file triSurface.C.

References Foam::stringListOps::findMatching(), forAll, bitSet::set(), UList< T >::size(), subsetMesh(), and bitSet::test().

Here is the call graph for this function:

◆ swapFaces()

void swapFaces ( List< labelledTri > & faceLst)

Swap the list of faces being addressed.

Definition at line 947 of file triSurface.C.

References clearOut(), and storedFaces().

Referenced by triSurfaceLoader::load().

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

◆ transfer() [1/2]

void transfer ( triSurface & surf)

Alter contents by transferring (triangles, points) components.

Patch information is small and therefore just copied.

Definition at line 955 of file triSurface.C.

References clearOut(), patches(), storedFaces(), storedPoints(), and triSurface().

Referenced by operator=(), operator=(), triSurface(), triSurfaceMesh::triSurfaceMesh(), and triSurfaceMesh::triSurfaceMesh().

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

◆ transfer() [2/2]

void transfer ( MeshedSurface< labelledTri > & surf)

Alter contents by transferring (triangles, points) components.

Patch information is small and therefore just copied.

Definition at line 967 of file triSurface.C.

References MeshedSurface< Face >::clear(), clearOut(), Foam::ListOps::create(), patches(), pts, s(), MeshedSurface< Face >::surfZones(), swap(), MeshedSurface< Face >::swapFaces(), MeshedSurface< Face >::swapPoints(), and triSurface().

Here is the call graph for this function:

◆ write() [1/4]

void write ( Ostream & os) const

Write to Ostream in simple OpenFOAM format.

Definition at line 331 of file triSurfaceIO.C.

References os().

Referenced by booleanSurface::booleanSurface(), booleanSurface::booleanSurface(), isoSurfacePoint::isoSurfacePoint(), distributedTriSurfaceMesh::writeObject(), triSurfaceMesh::writeObject(), and boundaryMesh::writeTriSurface().

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

◆ write() [2/4]

void write ( const fileName & name,
const bool sortByRegion = false ) const

Generic write routine (uses extension to determine type).

The sort option may not have an effect.

Definition at line 321 of file triSurfaceIO.C.

References Foam::name(), and write().

Here is the call graph for this function:

◆ write() [3/4]

void write ( const fileName & filename,
const word & fileType,
const bool sortByRegion = false ) const

Generic write routine for given format type.

If the format type is "", uses the file extension. The sort option may not have an effect.

Definition at line 201 of file triSurfaceIO.C.

References MeshedSurfaceProxy< Face >::canWriteType(), Foam::exit(), Foam::faceMap(), Foam::FatalError, FatalErrorInFunction, Foam::flatOutput(), Foam::name(), Foam::nl, os(), points, sortedZones(), surfFaces(), MeshedSurfaceProxy< Face >::write(), write(), and writeTypes().

Here is the call graph for this function:

◆ write() [4/4]

void write ( const Time & d) const

Write to database.

Definition at line 337 of file triSurfaceIO.C.

References Time::caseName(), Foam::GlobalIOList< Tuple2< scalar, vector > >::typeName, os(), Time::path(), and triSurfInstance().

Here is the call graph for this function:

◆ writeStats()

void writeStats ( Ostream & os) const

Write some statistics.

Definition at line 348 of file triSurfaceIO.C.

References boundBox::add(), bitSet::count(), Foam::endl(), f(), HashSet< Key, Hash >::insert(), Foam::nl, os(), points, bitSet::set(), HashTable< T, Key, Hash >::size(), and UList< T >::size().

Referenced by booleanSurface::booleanSurface(), and booleanSurface::booleanSurface().

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

◆ operator=() [1/3]

void operator= ( const triSurface & surf)

Copy assignment.

Definition at line 993 of file triSurface.C.

References clearOut(), patches(), PrimitivePatch< FaceList, PointField >::points(), storedFaces(), storedPoints(), and triSurface().

Referenced by booleanSurface::booleanSurface(), and distributedTriSurfaceMesh::distribute().

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

◆ operator=() [2/3]

void operator= ( triSurface && surf)

Move assignment.

Definition at line 1003 of file triSurface.C.

References transfer(), and triSurface().

Here is the call graph for this function:

◆ operator=() [3/3]

void operator= ( MeshedSurface< labelledTri > && surf)

Move assignment.

Definition at line 1009 of file triSurface.C.

References transfer().

Here is the call graph for this function:

◆ operator>>

Istream & operator>> ( Istream & is,
triSurface & s )
friend

References s(), and triSurface().

◆ operator<<

Ostream & operator<< ( Ostream & os,
const triSurface & s )
friend

References os(), s(), and triSurface().


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