face Class Reference

A face is a list of labels corresponding to mesh vertices. More...

Inheritance diagram for face:
Collaboration diagram for face:

Classes

struct  hasher
 Hashing functor for face. More...
 
struct  symmHasher
 Symmetric hashing functor for face. More...
 

Public Types

enum  proxType { NONE = 0, POINT, EDGE }
 The proximity classifications. More...
 
- Public Types inherited from List< label >
typedef SubList< label > subList
 Declare type of subList. More...
 
- Public Types inherited from UList< label >
typedef label value_type
 The value type the list contains. More...
 
typedef label * pointer
 The pointer type for non-const access to value_type items. More...
 
typedef const label * const_pointer
 The pointer type for const access to value_type items. More...
 
typedef label & reference
 The type used for storing into value_type objects. More...
 
typedef const label & const_reference
 The type used for reading from constant value_type objects. More...
 
typedef label * iterator
 Random access iterator for traversing a UList. More...
 
typedef const label * const_iterator
 Random access iterator for traversing a UList. More...
 
typedef label size_type
 The type to represent the size of a UList. More...
 
typedef label difference_type
 The difference between iterator objects. More...
 
typedef std::reverse_iterator< iteratorreverse_iterator
 Reverse iterator (non-const access) More...
 
typedef std::reverse_iterator< const_iteratorconst_reverse_iterator
 Reverse iterator (const access) More...
 

Public Member Functions

constexpr face () noexcept=default
 Default construct. More...
 
 face (const label sz)
 Construct given size, with invalid vertex labels (-1) More...
 
 face (const labelUList &list)
 Copy construct from list of vertex labels. More...
 
 face (labelList &&list)
 Move construct from list of vertex labels. More...
 
 face (std::initializer_list< label > list)
 Copy construct from an initializer list of vertex labels. More...
 
template<unsigned N>
 face (const FixedList< label, N > &list)
 Copy construct from list of vertex labels. More...
 
 face (const labelUList &list, const labelUList &indices)
 Copy construct from subset of vertex labels. More...
 
template<unsigned N>
 face (const labelUList &list, const FixedList< label, N > &indices)
 Copy construct from subset of vertex labels. More...
 
 face (const triFace &f)
 Copy construct from triFace. More...
 
 face (Istream &is)
 Construct from Istream. More...
 
label collapse ()
 Collapse face by removing duplicate vertex labels. More...
 
void flip ()
 Flip the face in-place. More...
 
pointField points (const UList< point > &pts) const
 Return the points corresponding to this face. More...
 
point centre (const UList< point > &points) const
 Centre point of face. More...
 
template<class Type >
Type average (const UList< point > &meshPoints, const Field< Type > &fld) const
 Calculate average value at centroid of face. More...
 
vector areaNormal (const UList< point > &p) const
 The area normal - with magnitude equal to area of face. More...
 
vector unitNormal (const UList< point > &p) const
 The unit normal. More...
 
 FOAM_DEPRECATED_FOR (2018-12, "areaNormal() or unitNormal()") vector normal(const UList< point > &p) const
 Legacy name for areaNormal() More...
 
scalar mag (const UList< point > &p) const
 Magnitude of face area. More...
 
Pair< pointbox (const UList< point > &pts) const
 The enclosing (bounding) box for the face. More...
 
face reverseFace () const
 Return face with reverse direction. More...
 
label which (const label vertex) const
 Find local vertex on face for the vertex label, same as find() More...
 
label thisLabel (const label i) const
 The vertex on face - identical to operator[], but with naming similar to nextLabel(), prevLabel() More...
 
label nextLabel (const label i) const
 Next vertex on face. More...
 
label prevLabel (const label i) const
 Previous vertex on face. More...
 
scalar sweptVol (const UList< point > &oldPoints, const UList< point > &newPoints) const
 Return the volume swept out by the face when its points move. More...
 
tensor inertia (const UList< point > &p, const point &refPt=vector::zero, scalar density=1.0) const
 Return the inertia tensor, with optional reference point and density specification. More...
 
pointHit ray (const point &p, const vector &n, const UList< point > &meshPoints, const intersection::algorithm alg=intersection::FULL_RAY, const intersection::direction dir=intersection::VECTOR) const
 Return potential intersection with face with a ray starting at p, direction n (does not need to be normalized) More...
 
pointHit intersection (const point &p, const vector &q, const point &ctr, const UList< point > &meshPoints, const intersection::algorithm alg, const scalar tol=0.0) const
 Fast intersection with a ray. More...
 
pointHit nearestPoint (const point &p, const UList< point > &meshPoints) const
 Return nearest point to face. More...
 
pointHit nearestPointClassify (const point &p, const UList< point > &meshPoints, label &nearType, label &nearLabel) const
 Return nearest point to face and classify it: More...
 
int sign (const point &p, const UList< point > &points, const scalar tol=SMALL) const
 The sign for the side of the face plane the point is on, using three evenly distributed face points for the estimated normal. More...
 
scalar contactSphereDiameter (const point &p, const vector &n, const UList< point > &meshPoints) const
 Return contact sphere diameter. More...
 
scalar areaInContact (const UList< point > &meshPoints, const scalarField &v) const
 Return area in contact, given the displacement in vertices. More...
 
label nEdges () const noexcept
 Return number of edges. More...
 
Foam::edge edge (const label edgei) const
 Return i-th face edge (forward walk order). More...
 
vector edge (const label edgei, const UList< point > &pts) const
 Return vector of i-th face edge (forward walk order). More...
 
Foam::edge rcEdge (const label edgei) const
 Return i-th face edge in reverse walk order. More...
 
vector rcEdge (const label edgei, const UList< point > &pts) const
 Return vector of i-th face edge in reverse walk order. More...
 
edgeList edges () const
 Return list of edges in forward walk order. More...
 
edgeList rcEdges () const
 Return list of edges in reverse walk order. More...
 
bool contains (const Foam::edge &e) const
 True if face contains(edge) More...
 
label find (const Foam::edge &e) const
 Find the edge within the face. More...
 
int edgeDirection (const Foam::edge &e) const
 Test the edge direction on the face. More...
 
label longestEdge (const UList< point > &pts) const
 Find the longest edge on a face. More...
 
label nTriangles () const
 Number of triangles after splitting. More...
 
label nTriangles (const UList< point > &unused) const
 Number of triangles after splitting. More...
 
label triangles (const UList< point > &points, label &triI, faceList &triFaces) const
 Split into triangles using existing points. More...
 
template<int SizeMin>
label triangles (const UList< point > &points, DynamicList< face, SizeMin > &triFaces) const
 Split into triangles using existing points. More...
 
label nTrianglesQuads (const UList< point > &points, label &nTris, label &nQuads) const
 Number of triangles and quads after splitting. More...
 
label trianglesQuads (const UList< point > &points, label &triI, label &quadI, faceList &triFaces, faceList &quadFaces) const
 Split into triangles and quads. More...
 
bool connected (const labelUList &other) const
 True if the face has at least one vertex in common with other. More...
 
template<unsigned N>
bool connected (const FixedList< label, N > &other) const
 True if the face has at least one vertex in common with other. More...
 
void operator+= (const label vertexOffset)
 Increment (offset) vertices by given amount. More...
 
unsigned hash_code (unsigned seed=0) const
 The hash value for face. More...
 
unsigned symmhash_code (unsigned seed=0) const
 The symmetric hash value for face. More...
 
Foam::edge faceEdge (label edgei) const
 Identical to edge() More...
 
template<int SizeMin>
Foam::label triangles (const UList< point > &points, DynamicList< face, SizeMin > &triFaces) const
 
- Public Member Functions inherited from List< label >
constexpr List () noexcept
 Default construct. More...
 
 List (const label len)
 Construct with given size. More...
 
 List (const label len, const label &val)
 Construct with given size and value for all elements. More...
 
 List (const label len, const Foam::zero)
 Construct with given size initializing all elements to zero. More...
 
 List (const Foam::one, const label &val)
 Construct with length=1, copying the value as the only content. More...
 
 List (const Foam::one, label &&val)
 Construct with length=1, moving the value as the only content. More...
 
 List (const Foam::one, const Foam::zero)
 Construct with length=1, initializing content to zero. More...
 
 List (const List< label > &list)
 Copy construct from list. More...
 
 List (const UList< label > &list)
 Copy construct contents from list. More...
 
 List (List< label > &list, bool reuse)
 Construct as copy or re-use as specified. More...
 
 List (const UList< label > &list, const labelUList &indices)
 Copy construct subset of list. More...
 
 List (const UList< label > &list, const FixedList< label, N > &indices)
 Copy construct subset of list. More...
 
 List (const FixedList< label, N > &list)
 Construct as copy of FixedList<T, N> More...
 
 List (const PtrList< label > &list)
 Construct as copy of PtrList<T> More...
 
 List (const IndirectListBase< label, Addr > &list)
 Construct as copy of IndirectList contents. More...
 
 List (std::initializer_list< label > list)
 Construct from an initializer list. More...
 
 List (List< label > &&list) noexcept
 Move construct from List. More...
 
 List (DynamicList< label, SizeMin > &&list)
 Move construct from DynamicList. More...
 
 List (Istream &is)
 Construct from Istream. More...
 
 List (const SLList< label > &list)
 Copy construct from SLList. More...
 
autoPtr< List< label > > clone () const
 Clone. More...
 
 ~List ()
 Destructor. More...
 
void clear ()
 Clear the list, i.e. set size to zero. More...
 
void resize (const label len)
 Adjust allocated size of list. More...
 
void resize (const label len, const label &val)
 Adjust allocated size of list and set val for new elements. More...
 
void resize (const label newLen)
 
void resize_fill (const label len, const label &val)
 Adjust allocated size of list and set val for all elements. More...
 
void resize_nocopy (const label len)
 Adjust allocated size of list without necessarily. More...
 
void resize_unsafe (const label len) noexcept
 Change the addressed list size directly without affecting any memory management (advanced usage). More...
 
void setSize (const label n)
 Alias for resize() More...
 
void setSize (const label n, const label &val)
 Alias for resize() More...
 
void transfer (List< label > &list)
 Transfer the contents of the argument List into this list and annul the argument list. More...
 
void transfer (DynamicList< label, SizeMin > &list)
 Transfer the contents of the argument List into this list and annul the argument list. More...
 
label & newElmt (const label i)
 Return subscript-checked element of UList and resizing the list if required. More...
 
label & emplace_back (Args &&... args)
 Construct an element at the end of the list, return reference to the new list element. More...
 
void push_back (const label &val)
 Append an element at the end of the list. More...
 
void push_back (label &&val)
 Move append an element at the end of the list. More...
 
void push_back (const UList< label > &list)
 Append a List to the end of this list. More...
 
void push_back (const IndirectListBase< label, Addr > &list)
 Append IndirectList contents at the end of this list. More...
 
label push_uniq (const label &val)
 Append an element if not already in the list. More...
 
void pop_back (label n=1)
 Reduce size by 1 or more elements. Can be called on an empty list. More...
 
void operator= (const UList< label > &list)
 Assignment to UList operator. Takes linear time. More...
 
void operator= (const List< label > &list)
 Assignment operator. Takes linear time. More...
 
void operator= (const IndirectListBase< label, Addr > &list)
 Assignment from IndirectList. Takes linear time. More...
 
void operator= (const FixedList< label, N > &list)
 Copy assignment from FixedList. More...
 
void operator= (std::initializer_list< label > list)
 Assignment to an initializer list. More...
 
void operator= (const label &val)
 Assignment of all entries to the given value. More...
 
void operator= (const Foam::zero)
 Assignment of all entries to zero. More...
 
void operator= (List< label > &&list)
 Move assignment. Takes constant time. More...
 
void operator= (DynamicList< label, SizeMin > &&list)
 Move assignment. Takes constant time. More...
 
void operator= (const SLList< label > &list)
 Copy assign from SLList in linear time. More...
 
IstreamreadList (Istream &is)
 Read List from Istream, discarding contents of existing List. More...
 
void shallowCopy (const UList< label > &)=delete
 No shallowCopy permitted. More...
 
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type set (const label i, bool val=true)
 A bitSet::set() method for a list of bool. More...
 
void append (const label &val)
 Append an element at the end of the list. More...
 
void append (label &&val)
 Move append an element at the end of the list. More...
 
void append (const UList< label > &list)
 Append a List to the end of this list. More...
 
void append (const IndirectListBase< label, Addr > &list)
 Append IndirectList contents at the end of this list. More...
 
label appendUniq (const label &val)
 Same as push_uniq() More...
 
- Public Member Functions inherited from UList< label >
label size () const noexcept
 The number of elements in the container. More...
 
void writeEntry (const word &keyword, Ostream &os) const
 Write the List as a dictionary entry with keyword. More...
 
void operator= (const label &val)
 Assignment of all entries to the given value. More...
 
void operator= (const Foam::zero)
 Assignment of all entries to zero. More...
 
 UList (const UList< label > &)=default
 Copy construct. More...
 
constexpr UList () noexcept
 Default construct, zero-sized and nullptr. More...
 
 UList (label *__restrict__ v, const label len) noexcept
 Construct from components. More...
 
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. More...
 
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. More...
 
const label & fcValue (const label i) const
 Return forward circular value (ie, next value in the list) More...
 
label & fcValue (const label i)
 Return forward circular value (ie, next value in the list) More...
 
const label & rcValue (const label i) const
 Return reverse circular value (ie, previous value in the list) More...
 
label & rcValue (const label i)
 Return reverse circular value (ie, previous value in the list) More...
 
const label * cdata () const noexcept
 Return pointer to the underlying array serving as data storage. More...
 
label * data () noexcept
 Return pointer to the underlying array serving as data storage. More...
 
const char * cdata_bytes () const noexcept
 Return pointer to the underlying array serving as data storage,. More...
 
char * data_bytes () noexcept
 Return pointer to the underlying array serving as data storage,. More...
 
label & front ()
 Access first element of the list, position [0]. More...
 
const label & front () const
 Access first element of the list. More...
 
label & back ()
 Access last element of the list, position [size()-1]. More...
 
const label & back () const
 Access last element of the list, position [size()-1]. More...
 
std::streamsize size_bytes () const noexcept
 Number of contiguous bytes for the List data. More...
 
std::streamsize byteSize () const
 Number of contiguous bytes for the List data, runtime FatalError if type is not contiguous. More...
 
void checkStart (const label start) const
 Check start is within valid range [0,size) More...
 
void checkSize (const label size) const
 Check size is within valid range [0,size]. More...
 
void checkRange (const label start, const label len) const
 Check that start and length define a valid range. More...
 
void checkIndex (const label i) const
 Check index is within valid range [0,size) More...
 
bool uniform () const
 True if all entries have identical values, and list is non-empty. More...
 
bool contains (const label &val) const
 True if the value is contained in the list. More...
 
bool contains (const label &val, label pos, label len=-1) const
 Is the value contained in the list? More...
 
label find (const label &val) const
 Find index of the first occurrence of the value. More...
 
label find (const label &val, label pos, label len=-1) const
 Find index of the first occurrence of the value. More...
 
label rfind (const label &val, label pos=-1) const
 Find index of the last occurrence of the value. More...
 
void moveFirst (const label i)
 Move element to the first position. More...
 
void moveLast (const label i)
 Move element to the last position. More...
 
void swapFirst (const label i)
 Swap element with the first element. Fatal on an empty list. More...
 
void swapLast (const label i)
 Swap element with the last element. Fatal on an empty list. More...
 
void shallowCopy (label *__restrict__ ptr, const label len) noexcept
 Copy the pointer and size. More...
 
void shallowCopy (const UList< label > &list) noexcept
 Copy the pointer and size held by the given UList. More...
 
void deepCopy (const UList< label > &list)
 Copy elements of the given UList. Sizes must match! More...
 
void deepCopy (const IndirectListBase< label, Addr > &list)
 Copy elements of the given indirect list. Sizes must match! More...
 
SubList< label > slice (const label pos, label len=-1)
 Return SubList slice (non-const access) - no range checking. More...
 
const SubList< label > slice (const label pos, label len=-1) const
 Return SubList slice (const access) - no range checking. More...
 
SubList< label > slice (const labelRange &range)
 Return SubList slice (non-const access) - with range checking. More...
 
const SubList< label > slice (const labelRange &range) const
 Return SubList slice (const access) - with range checking. More...
 
label & operator[] (const label i)
 Return element of UList. More...
 
const label & operator[] (const label i) const
 Return element of constant UList. More...
 
const bool & operator[] (const label i) const
 
UPstream::commsStructoperator[] (const label procID)
 
const UPstream::commsStructoperator[] (const label procID) const
 
Foam::UPstream::commsStructoperator[] (const label procID)
 
const Foam::UPstream::commsStructoperator[] (const label procID) const
 
 operator const Foam::List< label > & () const
 Allow cast to a const List<T>&. More...
 
iterator begin () noexcept
 Return an iterator to begin traversing the UList. More...
 
iterator begin (const label i) noexcept
 Return iterator at offset i from begin, clamped to [0,size] range. More...
 
const_iterator begin () const noexcept
 Return const_iterator to begin traversing the constant UList. More...
 
const_iterator begin (const label i) const noexcept
 Return const_iterator at offset i from begin, clamped to [0,size] range. More...
 
iterator end () noexcept
 Return an iterator to end traversing the UList. More...
 
const_iterator end () const noexcept
 Return const_iterator to end traversing the constant UList. More...
 
const_iterator cbegin () const noexcept
 Return const_iterator to begin traversing the constant UList. More...
 
const_iterator cbegin (const label i) const noexcept
 Return const_iterator at offset i from begin, clamped to [0,size] range. More...
 
const_iterator cend () const noexcept
 Return const_iterator to end traversing the constant UList. More...
 
reverse_iterator rbegin ()
 Return reverse_iterator to begin reverse traversing the UList. More...
 
const_reverse_iterator rbegin () const
 Return const_reverse_iterator to begin reverse traversing the UList. More...
 
reverse_iterator rend ()
 Return reverse_iterator to end reverse traversing the UList. More...
 
const_reverse_iterator rend () const
 Return const_reverse_iterator to end reverse traversing the UList. More...
 
const_reverse_iterator crbegin () const
 Return const_reverse_iterator to begin reverse traversing the UList. More...
 
const_reverse_iterator crend () const
 Return const_reverse_iterator to end reverse traversing the UList. More...
 
bool empty () const noexcept
 True if List is empty (ie, size() is zero) More...
 
label capacity () const noexcept
 Size of the underlying storage. More...
 
void swap (UList< label > &list) noexcept
 Swap content with another UList of the same type in constant time. More...
 
bool operator== (const UList< label > &list) const
 Equality operation on ULists of the same type. More...
 
bool operator!= (const UList< label > &list) const
 The opposite of the equality operation. Takes linear time. More...
 
bool operator< (const UList< label > &list) const
 Compare two ULists lexicographically. Takes linear time. More...
 
bool operator> (const UList< label > &list) const
 Compare two ULists lexicographically. Takes linear time. More...
 
bool operator<= (const UList< label > &list) const
 Return true if !(a > b). Takes linear time. More...
 
bool operator>= (const UList< label > &list) const
 Return true if !(a < b). Takes linear time. More...
 
IstreamreadList (Istream &is)
 Read List contents from Istream. More...
 
OstreamwriteList (Ostream &os, const label shortLen=0) const
 Write List, with line-breaks in ASCII when length exceeds shortLen. More...
 
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type test (const label i) const
 Test bool value at specified position, always false for out-of-range access. More...
 
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type get (const label i) const
 Return bool value at specified position, always false for out-of-range access. More...
 
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type unset (const label i)
 Unset the bool entry at specified position, always false for out-of-range access. More...
 
label & first ()
 Access first element of the list, position [0]. More...
 
const label & first () const
 Access first element of the list. More...
 
label & last ()
 Access last element of the list, position [size()-1]. More...
 
const label & last () const
 Access last element of the list, position [size()-1]. More...
 
bool found (const label &val, label pos=0) const
 Same as contains() More...
 

Static Public Member Functions

static int compare (const face &a, const face &b)
 Compare faces. More...
 
static bool sameVertices (const face &a, const face &b)
 True if the faces have all the same vertices. More...
 
static unsigned symmhash_code (const UList< label > &f, unsigned seed=0)
 The symmetric hash value for face. More...
 
- Static Public Member Functions inherited from List< label >
static const List< label > & null ()
 Return a null List. More...
 
- Static Public Member Functions inherited from UList< label >
static const UList< label > & null ()
 Return a UList reference to a nullObject. More...
 
static constexpr label max_size () noexcept
 The size of the largest possible UList. More...
 

Static Public Attributes

static const char *const typeName = "face"
 

Additional Inherited Members

- Protected Member Functions inherited from UList< label >
void setAddressableSize (const label n) noexcept
 Set addressed size to be inconsistent with allocated storage. More...
 
void size (const label n)
 Older name for setAddressableSize. More...
 
void writeEntry (Ostream &os) const
 Write the UList with its compound type. More...
 
void writeEntry (Ostream &os) const
 Character list writeEntry. More...
 
void writeEntry (Ostream &os) const
 
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. More...
 
void fill_uniform (const label &val)
 Assign all entries to the given value. More...
 
void fill_uniform (const Foam::zero)
 Assign all entries to zero. More...
 
UList< label > & operator= (const UList< label > &)=delete
 No copy assignment (default: shallow copy) More...
 
void operator= (const Foam::zero)
 Character list assign zero - avoids Foam::zero casting ambiguities. More...
 
void operator= (const Foam::zero)
 

Detailed Description

A face is a list of labels corresponding to mesh vertices.

See also
Foam::triFace
Source files

Definition at line 68 of file face.H.

Member Enumeration Documentation

◆ proxType

enum proxType

The proximity classifications.

Enumerator
NONE 

Unknown proximity.

POINT 

Close to point.

EDGE 

Close to edge.

Definition at line 127 of file face.H.

Constructor & Destructor Documentation

◆ face() [1/10]

constexpr face ( )
defaultnoexcept

Default construct.

Referenced by cellShape::face().

Here is the caller graph for this function:

◆ face() [2/10]

face ( const label  sz)
inlineexplicit

Construct given size, with invalid vertex labels (-1)

Definition at line 24 of file faceI.H.

◆ face() [3/10]

face ( const labelUList list)
inlineexplicit

Copy construct from list of vertex labels.

Definition at line 30 of file faceI.H.

◆ face() [4/10]

face ( labelList &&  list)
inlineexplicit

Move construct from list of vertex labels.

Definition at line 36 of file faceI.H.

◆ face() [5/10]

face ( std::initializer_list< label >  list)
inlineexplicit

Copy construct from an initializer list of vertex labels.

Definition at line 42 of file faceI.H.

◆ face() [6/10]

face ( const FixedList< label, N > &  list)
inlineexplicit

Copy construct from list of vertex labels.

Definition at line 49 of file faceI.H.

◆ face() [7/10]

face ( const labelUList list,
const labelUList indices 
)
inline

Copy construct from subset of vertex labels.

Definition at line 55 of file faceI.H.

◆ face() [8/10]

face ( const labelUList list,
const FixedList< label, N > &  indices 
)
inline

Copy construct from subset of vertex labels.

Definition at line 63 of file faceI.H.

◆ face() [9/10]

face ( const triFace f)

Copy construct from triFace.

Definition at line 265 of file face.C.

◆ face() [10/10]

face ( Istream is)
inline

Construct from Istream.

Definition at line 72 of file faceI.H.

Member Function Documentation

◆ collapse()

Foam::label collapse ( )

Collapse face by removing duplicate vertex labels.

Returns
the collapsed size

Definition at line 467 of file face.C.

References setSize().

Here is the call graph for this function:

◆ flip()

void flip ( )

Flip the face in-place.

The starting vertex of the original and flipped face are identical.

Definition at line 492 of file face.C.

References n.

Referenced by createShellMesh::setRefinement().

Here is the caller graph for this function:

◆ points()

Foam::pointField points ( const UList< point > &  pts) const
inline

Return the points corresponding to this face.

Definition at line 80 of file faceI.H.

References UList< T >::begin(), p, and pts.

Referenced by deltaBoundary::cellCenters_d(), NURBS3DVolume::computeControlPointSensitivities(), Bezier::dndbBasedSensitivities(), NURBS3DVolume::dndbBasedSensitivities(), Bezier::dxdbFace(), sensitivitySurfacePoints::finalisePointSensitivities(), NURBS3DVolume::patchDxDbFace(), and advancingFrontAMI::writeIntersectionOBJ().

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

◆ centre()

Foam::point centre ( const UList< point > &  points) const

Centre point of face.

Definition at line 506 of file face.C.

References triangle< Point, PointRef >::centre(), Foam::mag(), nPoints, points, and Foam::Zero.

Here is the call graph for this function:

◆ average()

Type average ( const UList< point > &  meshPoints,
const Field< Type > &  fld 
) const

Calculate average value at centroid of face.

Definition at line 46 of file faceTemplates.C.

References fld, Foam::mag(), nPoints, and Foam::Zero.

Here is the call graph for this function:

◆ areaNormal()

Foam::vector areaNormal ( const UList< point > &  p) const

The area normal - with magnitude equal to area of face.

Definition at line 569 of file face.C.

References triangle< Point, PointRef >::areaNormal(), n, nPoints, p, and Foam::Zero.

Referenced by face::FOAM_DEPRECATED_FOR().

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

◆ unitNormal()

Foam::vector unitNormal ( const UList< point > &  p) const
inline

The unit normal.

Definition at line 97 of file faceI.H.

References n, and p.

◆ FOAM_DEPRECATED_FOR()

FOAM_DEPRECATED_FOR ( 2018-  12,
"areaNormal() or unitNormal()"   
) const &
inline

Legacy name for areaNormal()

Deprecated:
(2018-06) Deprecated for new use

Definition at line 246 of file face.H.

References face::areaNormal(), and p.

Here is the call graph for this function:

◆ mag()

Foam::scalar mag ( const UList< point > &  p) const
inline

Magnitude of face area.

Definition at line 105 of file faceI.H.

References Foam::mag(), and p.

Referenced by polyPatch::areaFraction(), face::areaInContact(), and cyclicACMIFvPatch::movePoints().

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

◆ box()

Foam::Pair< Foam::point > box ( const UList< point > &  pts) const
inline

The enclosing (bounding) box for the face.

Definition at line 112 of file faceI.H.

References Pair< T >::first(), Foam::max(), Foam::min(), pts, and Pair< T >::second().

Here is the call graph for this function:

◆ reverseFace()

Foam::face reverseFace ( ) const

Return face with reverse direction.

The starting vertex of the original and reverse face are identical.

Definition at line 627 of file face.C.

References UList< T >::size().

Referenced by polyMeshAdder::add(), and addPatchCellLayer::setRefinement().

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

◆ which()

Foam::label which ( const label  vertex) const
inline

Find local vertex on face for the vertex label, same as find()

Returns
position in face (0,1,2,...) or -1 if not found.

Definition at line 171 of file faceI.H.

References UList< label >::find().

Here is the call graph for this function:

◆ thisLabel()

Foam::label thisLabel ( const label  i) const
inline

The vertex on face - identical to operator[], but with naming similar to nextLabel(), prevLabel()

Definition at line 177 of file faceI.H.

References UList< label >::operator[]().

Here is the call graph for this function:

◆ nextLabel()

Foam::label nextLabel ( const label  i) const
inline

Next vertex on face.

Definition at line 183 of file faceI.H.

References UList< label >::fcValue().

Referenced by combineFaces::getOutsideFace(), boundaryCutter::setRefinement(), and tetDecomposer::setRefinement().

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

◆ prevLabel()

Foam::label prevLabel ( const label  i) const
inline

Previous vertex on face.

Definition at line 189 of file faceI.H.

References UList< label >::rcValue().

Referenced by tetDecomposer::setRefinement().

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

◆ sweptVol()

Foam::scalar sweptVol ( const UList< point > &  oldPoints,
const UList< point > &  newPoints 
) const

Return the volume swept out by the face when its points move.

Definition at line 650 of file face.C.

References nPoints, and Foam::constant::mathematical::pi().

Here is the call graph for this function:

◆ inertia()

Foam::tensor inertia ( const UList< point > &  p,
const point refPt = vector::zero,
scalar  density = 1.0 
) const

Return the inertia tensor, with optional reference point and density specification.

Definition at line 729 of file face.C.

References forAll, p, and Foam::Zero.

◆ ray()

Foam::pointHit ray ( const point p,
const vector n,
const UList< point > &  meshPoints,
const intersection::algorithm  alg = intersection::FULL_RAY,
const intersection::direction  dir = intersection::VECTOR 
) const

Return potential intersection with face with a ray starting at p, direction n (does not need to be normalized)

Does face-centre decomposition and returns triangle intersection point closest to p. Face-centre is calculated from point average. For a hit, the distance is signed. Positive number represents the point in front of triangle In case of miss the point is the nearest point on the face and the distance is the distance between the intersection point and the original point. The half-ray or full-ray intersection and the contact sphere adjustment of the projection vector is set by the intersection parameters

Definition at line 30 of file faceIntersection.C.

References Foam::average(), PointHit< PointType >::distance(), PointHit< PointType >::eligibleMiss(), f(), PointHit< PointType >::hit(), PointHit< PointType >::hitPoint(), Foam::mag(), n, nPoints, p, PointHit< PointType >::point(), points, PointHit< PointType >::setDistance(), PointHit< PointType >::setMiss(), and PointHit< PointType >::setPoint().

Here is the call graph for this function:

◆ intersection()

Foam::pointHit intersection ( const point p,
const vector q,
const point ctr,
const UList< point > &  meshPoints,
const intersection::algorithm  alg,
const scalar  tol = 0.0 
) const

Fast intersection with a ray.

Does face-centre decomposition and returns triangle intersection point closest to p. See triangle::intersection for details.

Definition at line 130 of file faceIntersection.C.

References PointHit< PointType >::distance(), f(), forAll, PointHit< PointType >::hit(), PointHit< PointType >::hitPoint(), Foam::mag(), p, PointHit< PointType >::point(), and PointHit< PointType >::setDistance().

Here is the call graph for this function:

◆ nearestPoint()

Foam::pointHit nearestPoint ( const point p,
const UList< point > &  meshPoints 
) const

Return nearest point to face.

Definition at line 187 of file faceIntersection.C.

References p.

◆ nearestPointClassify()

Foam::pointHit nearestPointClassify ( const point p,
const UList< point > &  meshPoints,
label &  nearType,
label &  nearLabel 
) const

Return nearest point to face and classify it:

+ near point (nearType=POINT, nearLabel=0, 1, 2) + near edge (nearType=EDGE, nearLabel=0, 1, 2) Note: edges are counted from starting vertex so e.g. edge n is from f[n] to f[0], where the face has n + 1 points

Definition at line 201 of file faceIntersection.C.

References PointHit< PointType >::distance(), f(), PointHit< PointType >::hit(), PointHit< PointType >::hitPoint(), Foam::mag(), triangle< Point, PointRef >::nearestPointClassify(), nPoints, p, PointHit< PointType >::point(), PointHit< PointType >::setDistance(), PointHit< PointType >::setMiss(), and PointHit< PointType >::setPoint().

Here is the call graph for this function:

◆ sign()

int sign ( const point p,
const UList< point > &  points,
const scalar  tol = SMALL 
) const

The sign for the side of the face plane the point is on, using three evenly distributed face points for the estimated normal.

Uses the supplied tolerance for rounding around zero.

Returns
  • 0: on plane
  • +1: front-side
  • -1: back-side

Definition at line 301 of file faceIntersection.C.

References p, and points.

◆ contactSphereDiameter()

Foam::scalar contactSphereDiameter ( const point p,
const vector n,
const UList< point > &  meshPoints 
) const

Return contact sphere diameter.

Definition at line 30 of file faceContactSphere.C.

References Foam::mag(), n, and p.

Here is the call graph for this function:

◆ areaInContact()

Foam::scalar areaInContact ( const UList< point > &  meshPoints,
const scalarField v 
) const

Return area in contact, given the displacement in vertices.

Definition at line 28 of file faceAreaInContact.C.

References faceLabels(), forAll, face::mag(), Foam::mag(), List< T >::setSize(), and UList< T >::size().

Here is the call graph for this function:

◆ nEdges()

Foam::label nEdges ( ) const
inlinenoexcept

Return number of edges.

Definition at line 126 of file faceI.H.

◆ edge() [1/2]

Foam::edge edge ( const label  edgei) const
inline

Return i-th face edge (forward walk order).

The edge 0 is from [0] to [1] and edge 1 is from [1] to [2]

Definition at line 133 of file faceI.H.

Referenced by Foam::checkFireEdges(), and face::faceEdge().

Here is the caller graph for this function:

◆ edge() [2/2]

Foam::vector edge ( const label  edgei,
const UList< point > &  pts 
) const
inline

Return vector of i-th face edge (forward walk order).

The edge 0 is from [0] to [1] and edge 1 is from [1] to [2]

Definition at line 140 of file faceI.H.

References pts.

◆ rcEdge() [1/2]

Foam::edge rcEdge ( const label  edgei) const
inline

Return i-th face edge in reverse walk order.

The rcEdge 0 is from [0] to [n-1] and rcEdge 1 is from [n-1] to [n-2]

Definition at line 149 of file faceI.H.

◆ rcEdge() [2/2]

Foam::vector rcEdge ( const label  edgei,
const UList< point > &  pts 
) const
inline

Return vector of i-th face edge in reverse walk order.

The rcEdge 0 is from [0] to [n-1] and rcEdge 1 is from [n-1] to [n-2]

Definition at line 159 of file faceI.H.

References pts.

◆ edges()

Foam::edgeList edges ( ) const

Return list of edges in forward walk order.

The edge 0 is from [0] to [1] and edge 1 is from [1] to [2]

Definition at line 764 of file face.C.

References UList< T >::back(), UList< T >::first(), UList< T >::front(), and UList< T >::size().

Referenced by Foam::polyMeshZipUpCells().

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

◆ rcEdges()

Foam::edgeList rcEdges ( ) const

Return list of edges in reverse walk order.

The rcEdge 0 is from [0] to [n-1] and rcEdge 1 is from [n-1] to [n-2]

Definition at line 785 of file face.C.

References UList< T >::back(), UList< T >::first(), UList< T >::front(), and UList< T >::size().

Here is the call graph for this function:

◆ contains()

bool contains ( const Foam::edge e) const
inline

True if face contains(edge)

Definition at line 228 of file faceI.H.

References Foam::constant::electromagnetic::e.

◆ find()

Foam::label find ( const Foam::edge e) const

Find the edge within the face.

Returns
the edge index or -1 if not found

Definition at line 806 of file face.C.

References Foam::constant::electromagnetic::e, and UList< label >::find().

Referenced by primitiveMesh::checkCommonOrder(), boundaryCutter::setRefinement(), and tetDecomposer::setRefinement().

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

◆ edgeDirection()

int edgeDirection ( const Foam::edge e) const

Test the edge direction on the face.

Returns
  • 0: edge not found on the face
  • +1: forward (counter-clockwise) on the face
  • -1: reverse (clockwise) on the face

Definition at line 831 of file face.C.

References Foam::constant::electromagnetic::e, and UList< label >::find().

Here is the call graph for this function:

◆ longestEdge()

Foam::label longestEdge ( const UList< point > &  pts) const

Find the longest edge on a face.

Definition at line 900 of file face.C.

References UList< T >::back(), UList< T >::front(), pts, and UList< T >::size().

Here is the call graph for this function:

◆ nTriangles() [1/2]

Foam::label nTriangles ( ) const
inline

Number of triangles after splitting.

Definition at line 195 of file faceI.H.

◆ nTriangles() [2/2]

Foam::label nTriangles ( const UList< point > &  unused) const

Number of triangles after splitting.

Definition at line 853 of file face.C.

◆ triangles() [1/3]

Foam::label triangles ( const UList< point > &  points,
label &  triI,
faceList triFaces 
) const

Split into triangles using existing points.

Result in triFaces[triI..triI+nTri]. Splits intelligently to maximize triangle quality. number of faces created.

Definition at line 860 of file face.C.

References points, and split().

Here is the call graph for this function:

◆ triangles() [2/3]

label triangles ( const UList< point > &  points,
DynamicList< face, SizeMin > &  triFaces 
) const

Split into triangles using existing points.

Append to DynamicList. number of faces created.

◆ nTrianglesQuads()

Foam::label nTrianglesQuads ( const UList< point > &  points,
label &  nTris,
label &  nQuads 
) const

Number of triangles and quads after splitting.

Returns the sum of both

Definition at line 874 of file face.C.

References points, and split().

Here is the call graph for this function:

◆ trianglesQuads()

Foam::label trianglesQuads ( const UList< point > &  points,
label &  triI,
label &  quadI,
faceList triFaces,
faceList quadFaces 
) const

Split into triangles and quads.

Results in triFaces (starting at triI) and quadFaces (starting at quadI). Returns number of new faces created.

Definition at line 888 of file face.C.

References points, and split().

Here is the call graph for this function:

◆ connected() [1/2]

bool connected ( const labelUList other) const
inline

True if the face has at least one vertex in common with other.

Definition at line 201 of file faceI.H.

References UList< T >::contains().

Here is the call graph for this function:

◆ connected() [2/2]

bool connected ( const FixedList< label, N > &  other) const
inline

True if the face has at least one vertex in common with other.

Definition at line 215 of file faceI.H.

References FixedList< T, N >::contains().

Here is the call graph for this function:

◆ compare()

int compare ( const face a,
const face b 
)
static

Compare faces.

Returns
  • 0: different
  • +1: identical
  • -1: same face, but different orientation

Definition at line 273 of file face.C.

References CirculatorBase::ANTICLOCKWISE, Foam::constant::physicoChemical::b, CirculatorIters< Container, true >::circulate(), CirculatorBase::CLOCKWISE, CirculatorIters< Container, true >::setFulcrumToIterator(), CirculatorIters< Container, true >::setIteratorToFulcrum(), and UList< T >::size().

Referenced by Foam::operator!=(), and Foam::operator==().

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

◆ sameVertices()

bool sameVertices ( const face a,
const face b 
)
static

True if the faces have all the same vertices.

Definition at line 374 of file face.C.

References Foam::constant::physicoChemical::b, forAll, and UList< T >::size().

Referenced by blockFace::compare().

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

◆ operator+=()

void operator+= ( const label  vertexOffset)
inline

Increment (offset) vertices by given amount.

Definition at line 237 of file faceI.H.

◆ symmhash_code() [1/2]

unsigned symmhash_code ( const UList< label > &  f,
unsigned  seed = 0 
)
static

The symmetric hash value for face.

Starts with lowest vertex value and walks in the direction of the next lowest value.

Definition at line 414 of file face.C.

References f(), UList< T >::fcIndex(), UList< T >::fcValue(), UList< T >::rcIndex(), UList< T >::rcValue(), and UList< T >::size().

Referenced by face::symmHasher::operator()(), and face::symmhash_code().

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

◆ hash_code()

unsigned hash_code ( unsigned  seed = 0) const
inline

The hash value for face.

Currently hashes as sequential contiguous data, but could/should be commutative

Definition at line 631 of file face.H.

References UList< label >::cdata(), Foam::Hasher(), and UList< label >::size_bytes().

Referenced by face::hasher::operator()().

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

◆ symmhash_code() [2/2]

unsigned symmhash_code ( unsigned  seed = 0) const
inline

The symmetric hash value for face.

Starts with lowest vertex value and walks in the direction of the next lowest value.

Definition at line 642 of file face.H.

References face::symmhash_code().

Here is the call graph for this function:

◆ faceEdge()

Foam::edge faceEdge ( label  edgei) const
inline

Identical to edge()

Definition at line 675 of file face.H.

References face::edge().

Here is the call graph for this function:

◆ triangles() [3/3]

Foam::label triangles ( const UList< point > &  points,
DynamicList< face, SizeMin > &  triFaces 
) const

Definition at line 28 of file faceTemplates.C.

References points, DynamicList< T, SizeMin >::setSize(), UList< T >::size(), and split().

Here is the call graph for this function:

Member Data Documentation

◆ typeName

const char *const typeName = "face"
static

Definition at line 137 of file face.H.


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