NURBS3DSurface Class Reference

A NURBS 3D surface. More...

Inheritance diagram for NURBS3DSurface:
[legend]
Collaboration diagram for NURBS3DSurface:
[legend]

Public Member Functions

 NURBS3DSurface (const List< vector > &CPs, const label nPointsU, const label nPointsV, const NURBSbasis &uBasis, const NURBSbasis &vBasis, const word name="NURBS3DSurface")
 Construct from number of control points and basis functions. More...
 
 NURBS3DSurface (const List< vector > &CPs, const List< scalar > &weights, const label nPointsU, const label nPointsV, const NURBSbasis &uBasis, const NURBSbasis &vBasis, const word name="NURBS3DSurface")
 Construct from number of control points, weights and basis functions. More...
 
 NURBS3DSurface (const List< vector > &CPs, const label nPointsU, const label nPointsV, const label uDegree, const label vDegree, const label nCPsU, const label nCPsV, const word name="NURBS3DSurface")
 Construct from control points, basis degree and number of points. More...
 
 NURBS3DSurface (const List< vector > &CPs, const label nPointsU, const label nPointsV, const label uDegree, const label vDegree, const label nCPsU, const label nCPsV, const scalarField &knotsU, const scalarField &knotsV, const word name="NURBS3DSurface")
 Construct from control points, basis degree, knots and number of. More...
 
 NURBS3DSurface (const List< vector > &CPs, const List< scalar > &weights, const label nPointsU, const label nPointsV, const label uDegree, const label vDegree, const label nCPsU, const label nCPsV, const word name="NURBS3DSurface")
 Construct from control points, weights, basis degree, and number of. More...
 
 NURBS3DSurface (const List< vector > &CPs, const List< scalar > &weights, const label nPointsU, const label nPointsV, const label uDegree, const label vDegree, const label nCPsU, const label nCPsV, const scalarField &knotsU, const scalarField &knotsV, const word name="NURBS3DSurface")
 Construct from control points, weights, basis degree, knots and. More...
 
 NURBS3DSurface (const NURBS3DSurface &)
 Construct as copy. More...
 
 ~NURBS3DSurface ()=default
 Destructor. More...
 
void setNrmOrientation (const vector &givenNrm, const scalar u, const scalar v)
 
void flipNrmOrientation ()
 Flip the orientation of the nrm. More...
 
void setCPs (const List< vector > &CPs)
 
void setWeights (const scalarList &weights)
 
void setName (const word &name)
 
void buildSurface ()
 
void invertU ()
 
void invertV ()
 
void invertUV ()
 
void makeEquidistant (const label lenAcc=25, const label maxIter=10, const label spacingCorrInterval=-1, const scalar tolerance=1.e-5)
 
vector surfacePoint (const scalar &u, const scalar &v)
 
scalarList findClosestSurfacePoint (const vector &targetPoint, const label maxIter=100, const scalar tolerance=1.e-6)
 
tmp< vector2DFieldfindClosestSurfacePoint (const vectorField &targetPoints, const label maxIter=100, const scalar tolerance=1.e-6)
 
scalarList findClosestSurfacePoint (const vector &targetPoint, const scalar &uInitGuess, const scalar &vInitGuess, const label maxIter=100, const scalar tolerance=1.e-6)
 
const vector nrm (scalar u, scalar v)
 
List< scalarListgenEquidistant (const label nUPts=100, const label nVPts=100, const label lenAcc=25, const label maxIter=10, const label spacingCorrInterval=-1, const scalar tolerance=1.e-5)
 Generate points on the surface which are evenly spaced in cartesian. More...
 
bool checkRangeU (const scalar u, const label CPI, const label uDegree) const
 
bool checkRangeU (const scalar u, const label CPI) const
 
bool checkRangeV (const scalar v, const label CPI, const label vDegree) const
 
bool checkRangeV (const scalar v, const label CPI) const
 
bool checkRangeUV (const scalar v, const scalar u, const label CPI, const label uDegree, const label vDegree) const
 
bool checkRangeUV (const scalar v, const scalar u, const label CPI) const
 
scalar lengthU (const label vIConst, const label uIStart, const label uIEnd) const
 
scalar lengthU (const scalar vConst, const scalar uStart, const scalar uEnd, const label nPts) const
 
scalar lengthU (const label vIConst) const
 
scalar lengthU (const scalar vConst) const
 
scalar lengthV (const label uIConst, const label vIStart, const label vIEnd) const
 
scalar lengthV (const scalar uConst, const scalar vStart, const scalar vEnd, const label nPts) const
 
scalar lengthV (const label uIConst) const
 
scalar lengthV (const scalar uConst) const
 
vector surfaceDerivativeU (const scalar u, const scalar v) const
 Surface derivative wrt u at point u,v. More...
 
vector surfaceDerivativeV (const scalar u, const scalar v) const
 Surface derivative wrt v at point u,v. More...
 
vector surfaceDerivativeUV (const scalar u, const scalar v) const
 Surface second derivative wrt u and v at point u,v. More...
 
vector surfaceDerivativeUU (const scalar u, const scalar v) const
 Surface second derivative wrt u at point u,v. More...
 
vector surfaceDerivativeVV (const scalar u, const scalar v) const
 Surface second derivative wrt v at point u,v. More...
 
scalar surfaceDerivativeCP (const scalar u, const scalar v, const label CPI) const
 Surface derivative wrt the weight of CPI at point u,v. More...
 
vector surfaceDerivativeW (const scalar u, const scalar v, const label CPI) const
 Surface derivative wrt WI at point u,v. More...
 
scalar lengthDerivativeU (const scalar vConst, const scalar uStart, const scalar uEnd, const label nPts) const
 Surface derivative wrt u length along v=const contour range. More...
 
scalar lengthDerivativeV (const scalar uConst, const scalar vStart, const scalar vEnd, const label nPts) const
 Surface derivative wrt v length along u=const contour range. More...
 
const NURBSbasisgetBasisFunctionU () const
 Get basis function. More...
 
const NURBSbasisgetBasisFunctionV () const
 
const List< vector > & getCPs () const
 Get CPs. More...
 
const scalarListgetWeights () const
 Get weights. More...
 
const scalarListgetParametricCoordinatesU () const
 Get parametric coordinates. More...
 
const scalarListgetParametricCoordinatesV () const
 
const wordgetName () const
 Get name. More...
 
label getNPtsU () const
 Get number of point in u direction. More...
 
label getNPtsV () const
 Get number of point in u direction. More...
 
const labelListgetBoundaryCPIDs ()
 Get IDs of boundary control points. More...
 
const labelListgetBoundaryCPIs ()
 
const label & whichBoundaryCPI (const label &globalCPI)
 Get the boundary CP ID based on the global CP ID. More...
 
label nrmOrientation () const
 Return the nrm sgn relation to the u=0 nrm. More...
 
const vectorgivenInitNrm () const
 Return the initial nrmal given to compare to the Curve's nrmals. More...
 
const labelListgetCPsUCPIs () const
 Return ID in u direction for a given cp ID. More...
 
const labelListgetCPsVCPIs () const
 Return ID in v direction for a given cp ID. More...
 
void write ()
 Write curve to file. More...
 
void write (const word fileName)
 
void write (const fileName dirName, const fileName fileName)
 
void writeWParses ()
 
void writeWParses (const word fileName)
 
void writeWParses (const fileName dirName, const fileName fileName)
 
void writeVTK (const fileName vtkDirName, const fileName vtkFileName)
 
- Public Member Functions inherited from Field< vector >
constexpr Field () noexcept
 Default construct. More...
 
 Field (const label len)
 Construct given size. More...
 
 Field (const label len, const vector &val)
 Construct given size and initial value. More...
 
 Field (const label len, const Foam::zero)
 Construct given size and initial values of zero. More...
 
 Field (const Foam::one, const vector &val)
 Construct with length=1, copying the value as the only content. More...
 
 Field (const Foam::one, vector &&val)
 Construct with length=1, moving the value as the only content. More...
 
 Field (const Foam::one, const Foam::zero)
 Construct with length=1, initializing content to zero. More...
 
 Field (const Field< vector > &fld)
 Copy construct. More...
 
 Field (const UList< vector > &list)
 Copy construct from UList<Type> More...
 
 Field (const IndirectListBase< vector, Addr > &list)
 Copy construct from IndirectList. More...
 
 Field (Field< vector > &&fld)
 Move construct from Field. More...
 
 Field (List< vector > &&list)
 Move construct from List. More...
 
 Field (DynamicList< vector, SizeMin > &&list)
 Move construct from DynamicList. More...
 
 Field (const UList< vector > &mapF, const labelUList &mapAddressing)
 Construct by 1 to 1 mapping from the given field. More...
 
 Field (const tmp< Field< vector > > &tmapF, const labelUList &mapAddressing)
 Construct by 1 to 1 mapping from the given tmp field. More...
 
 Field (const UList< vector > &mapF, const labelListList &mapAddressing, const scalarListList &weights)
 Construct by interpolative mapping from the given field. More...
 
 Field (const tmp< Field< vector > > &tmapF, const labelListList &mapAddressing, const scalarListList &weights)
 Construct by interpolative mapping from the given tmp field. More...
 
 Field (const UList< vector > &mapF, const FieldMapper &map, const bool applyFlip=true)
 Construct by mapping from the given field. More...
 
 Field (const UList< vector > &mapF, const FieldMapper &map, const vector &defaultValue, const bool applyFlip=true)
 Construct by mapping from the given field. More...
 
 Field (const UList< vector > &mapF, const FieldMapper &map, const UList< vector > &defaultValues, const bool applyFlip=true)
 Construct by mapping from the given field. More...
 
 Field (const tmp< Field< vector > > &tmapF, const FieldMapper &map, const bool applyFlip=true)
 Construct by mapping from the given tmp field. More...
 
 Field (const tmp< Field< vector > > &tmapF, const FieldMapper &map, const vector &defaultValue, const bool applyFlip=true)
 
 Field (const tmp< Field< vector > > &tmapF, const FieldMapper &map, const UList< vector > &defaultValues, const bool applyFlip=true)
 
 Field (Field< vector > &fld, bool reuse)
 Copy construct or re-use as specified. More...
 
 Field (const tmp< Field< vector > > &tfld)
 Copy or move construct from tmp. More...
 
 Field (Istream &is)
 Construct from Istream. More...
 
 Field (const word &keyword, const dictionary &dict, const label len)
 Construct from a dictionary entry. More...
 
tmp< Field< vector > > clone () const
 Clone. More...
 
void map (const UList< vector > &mapF, const labelUList &mapAddressing)
 1 to 1 map from the given field More...
 
void map (const tmp< Field< vector > > &tmapF, const labelUList &mapAddressing)
 1 to 1 map from the given tmp field More...
 
void map (const UList< vector > &mapF, const labelListList &mapAddressing, const scalarListList &weights)
 Interpolative map from the given field. More...
 
void map (const tmp< Field< vector > > &tmapF, const labelListList &mapAddressing, const scalarListList &weights)
 Interpolative map from the given tmp field. More...
 
void map (const UList< vector > &mapF, const FieldMapper &map, const bool applyFlip=true)
 Map from the given field. More...
 
void map (const tmp< Field< vector > > &tmapF, const FieldMapper &map, const bool applyFlip=true)
 Map from the given tmp field. More...
 
void autoMap (const FieldMapper &map, const bool applyFlip=true)
 Map from self. More...
 
void rmap (const UList< vector > &mapF, const labelUList &mapAddressing)
 1 to 1 reverse-map from the given field More...
 
void rmap (const tmp< Field< vector > > &tmapF, const labelUList &mapAddressing)
 1 to 1 reverse-map from the given tmp field More...
 
void rmap (const UList< vector > &mapF, const labelUList &mapAddressing, const UList< scalar > &weights)
 Interpolative reverse map from the given field. More...
 
void rmap (const tmp< Field< vector > > &tmapF, const labelUList &mapAddressing, const UList< scalar > &weights)
 Interpolative reverse map from the given tmp field. More...
 
void negate ()
 Inplace negate this field (negative). More...
 
void normalise ()
 
void normalise ()
 
void normalise ()
 
void normalise ()
 Inplace normalise (float) vector field. More...
 
void normalise ()
 Inplace normalise (double) vector field. More...
 
tmp< Field< cmptType > > component (const direction) const
 Return a component field of the field. More...
 
void replace (const direction, const UList< cmptType > &)
 Replace a component field of the field. More...
 
void replace (const direction, const tmp< Field< cmptType > > &)
 Replace a component field of the field. More...
 
void replace (const direction, const cmptType &)
 Replace a component field of the field. More...
 
VSForm block (const label start) const
 
tmp< Field< vector > > T () const
 Return the field transpose (only defined for second rank tensors) More...
 
void writeEntry (const word &keyword, Ostream &os) const
 Write the field as a dictionary entry. More...
 
SubField< vectorslice (const label pos, label len=-1)
 Return SubField slice (non-const access) - no range checking. More...
 
const SubField< vectorslice (const label pos, label len=-1) const
 Return SubField slice (const access) - no range checking. More...
 
SubField< vectorslice (const labelRange &range)
 Return SubField slice (non-const access) - with range checking. More...
 
const SubField< vectorslice (const labelRange &range) const
 Return SubField slice (const access) - with range checking. More...
 
void operator= (const Field< vector > &)
 Copy assignment. More...
 
void operator= (const tmp< Field< vector > > &)
 
void operator= (const UList< vector > &rhs)
 
void operator= (const SubField< vector > &rhs)
 
void operator= (const IndirectListBase< vector, Addr > &rhs)
 Copy assign from IndirectList. More...
 
void operator= (Field< vector > &&rhs)
 Move assignment. More...
 
void operator= (List< vector > &&rhs)
 
void operator= (DynamicList< vector, SizeMin > &&rhs)
 
void operator= (const vector &val)
 Value assignment. More...
 
void operator= (const Foam::zero)
 
void operator= (const VectorSpace< Form, Cmpt, nCmpt > &)
 
void operator= (const tmp< Field > &rhs)
 
void operator+= (const UList< vector > &)
 
void operator+= (const tmp< Field< vector > > &)
 
void operator+= (const vector &)
 
void operator-= (const UList< vector > &)
 
void operator-= (const tmp< Field< vector > > &)
 
void operator-= (const vector &)
 
void operator*= (const UList< scalar > &)
 
void operator*= (const tmp< Field< scalar > > &)
 
void operator*= (const scalar &)
 
void operator/= (const UList< scalar > &)
 
void operator/= (const tmp< Field< scalar > > &)
 
void operator/= (const scalar &)
 
- Public Member Functions inherited from FieldBase
constexpr FieldBase () noexcept
 Default construct, refCount zero. More...
 
- Public Member Functions inherited from refCount
constexpr refCount () noexcept
 Default construct, initializing count to 0. More...
 
int count () const noexcept
 Return the current reference count. More...
 
bool unique () const noexcept
 Return true if the reference count is zero. More...
 
void operator++ () noexcept
 Increment the reference count. More...
 
void operator++ (int) noexcept
 Increment the reference count. More...
 
void operator-- () noexcept
 Decrement the reference count. More...
 
void operator-- (int) noexcept
 Decrement the reference count. More...
 
- Public Member Functions inherited from List< T >
constexpr List () noexcept
 Default construct. More...
 
 List (const label len)
 Construct with given size. More...
 
 List (const label len, const T &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 T &val)
 Construct with length=1, copying the value as the only content. More...
 
 List (const Foam::one, T &&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< T > &a)
 Copy construct from list. More...
 
 List (const UList< T > &a)
 Copy construct contents from list. More...
 
 List (List< T > &a, bool reuse)
 Construct as copy or re-use as specified. More...
 
 List (const UList< T > &list, const labelUList &indices)
 Copy construct subset of list. More...
 
template<unsigned N>
 List (const UList< T > &list, const FixedList< label, N > &indices)
 Copy construct subset of list. More...
 
template<unsigned N>
 List (const FixedList< T, N > &list)
 Construct as copy of FixedList<T, N> More...
 
 List (const PtrList< T > &list)
 Construct as copy of PtrList<T> More...
 
 List (const SLList< T > &list)
 Construct as copy of SLList<T> More...
 
template<class Addr >
 List (const IndirectListBase< T, Addr > &list)
 Construct as copy of IndirectList contents. More...
 
 List (std::initializer_list< T > list)
 Construct from an initializer list. More...
 
 List (List< T > &&list)
 Move construct from List. More...
 
template<int SizeMin>
 List (DynamicList< T, SizeMin > &&list)
 Move construct from DynamicList. More...
 
 List (SLList< T > &&list)
 Move construct from SLList. More...
 
 List (Istream &is)
 Construct from Istream. More...
 
autoPtr< List< T > > 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 T &val)
 Adjust allocated size of list and set val for new elements. More...
 
void resize_nocopy (const label len)
 Adjust allocated size of list without necessarily. More...
 
void setSize (const label n)
 Alias for resize() More...
 
void setSize (const label n, const T &val)
 Alias for resize() More...
 
void append (const T &val)
 Append an element at the end of the list. More...
 
void append (T &&val)
 Move append an element at the end of the list. More...
 
void append (const UList< T > &list)
 Append a List to the end of this list. More...
 
template<class Addr >
void append (const IndirectListBase< T, Addr > &list)
 Append IndirectList contents at the end of this list. More...
 
label appendUniq (const T &val)
 Append an element if not already in the list. More...
 
void transfer (List< T > &list)
 
template<int SizeMin>
void transfer (DynamicList< T, SizeMin > &list)
 
TnewElmt (const label i)
 
void operator= (const UList< T > &a)
 Assignment to UList operator. Takes linear time. More...
 
void operator= (const List< T > &list)
 Assignment operator. Takes linear time. More...
 
void operator= (const SLList< T > &list)
 Assignment to SLList operator. Takes linear time. More...
 
template<class Addr >
void operator= (const IndirectListBase< T, Addr > &list)
 Assignment from IndirectList. Takes linear time. More...
 
template<unsigned N>
void operator= (const FixedList< T, N > &list)
 Copy assignment from FixedList. More...
 
void operator= (std::initializer_list< T > list)
 Assignment to an initializer list. More...
 
void operator= (const T &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< T > &&list)
 Move assignment. Takes constant time. More...
 
template<int SizeMin>
void operator= (DynamicList< T, SizeMin > &&list)
 Move assignment. Takes constant time. More...
 
void operator= (SLList< T > &&list)
 Move assignment. Takes constant time. More...
 
IstreamreadList (Istream &is)
 Read List from Istream, discarding contents of existing List. More...
 
void shallowCopy (const UList< T > &)=delete
 No shallowCopy permitted. More...
 
template<class TypeT = T>
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...
 
IstreamreadList (Istream &is)
 
void resize (const label newLen)
 
IstreamreadList (Istream &is)
 
- Public Member Functions inherited from UList< T >
 UList (const UList< T > &)=default
 Copy construct. More...
 
constexpr UList () noexcept
 Default construct, zero-sized and nullptr. More...
 
 UList (T *__restrict__ v, const label len) noexcept
 Construct from components. More...
 
label fcIndex (const label i) const noexcept
 
label rcIndex (const label i) const noexcept
 
const TfcValue (const label i) const
 Return forward circular value (ie, next value in the list) More...
 
TfcValue (const label i)
 Return forward circular value (ie, next value in the list) More...
 
const TrcValue (const label i) const
 Return reverse circular value (ie, previous value in the list) More...
 
TrcValue (const label i)
 Return reverse circular value (ie, previous value in the list) More...
 
const Tcdata () const noexcept
 Return pointer to the underlying array serving as data storage. More...
 
Tdata () 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...
 
Tfirst ()
 Return the first element of the list. More...
 
const Tfirst () const
 Return first element of the list. More...
 
Tlast ()
 Return the last element of the list. More...
 
const Tlast () const
 Return the last element of the list. More...
 
std::streamsize size_bytes () const noexcept
 Number of contiguous bytes for the List data. More...
 
std::streamsize byteSize () const
 
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...
 
label find (const T &val, label pos=0) const
 Find index of the first occurrence of the value. More...
 
label rfind (const T &val, label pos=-1) const
 Find index of the last occurrence of the value. More...
 
bool found (const T &val, label pos=0) const
 True if the value if found in the list. 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 (const UList< T > &list)
 Copy the pointer and size held by the given UList. More...
 
void deepCopy (const UList< T > &list)
 Copy elements of the given UList. Sizes must match! More...
 
template<class Addr >
void deepCopy (const IndirectListBase< T, Addr > &list)
 Copy elements of the given indirect list. Sizes must match! More...
 
SubList< Tslice (const label pos, label len=-1)
 Return SubList slice (non-const access) - no range checking. More...
 
const SubList< Tslice (const label pos, label len=-1) const
 Return SubList slice (const access) - no range checking. More...
 
SubList< Tslice (const labelRange &range)
 Return SubList slice (non-const access) - with range checking. More...
 
const SubList< Tslice (const labelRange &range) const
 Return SubList slice (const access) - with range checking. More...
 
Toperator[] (const label i)
 Return element of UList. More...
 
const Toperator[] (const label i) const
 Return element of constant UList. More...
 
 operator const Foam::List< T > & () const
 Allow cast to a const List<T>&. More...
 
void operator= (const T &val)
 Assignment of all entries to the given value. More...
 
void operator= (const Foam::zero)
 Assignment of all entries to zero. More...
 
iterator begin () noexcept
 Return an iterator to begin traversing the UList. More...
 
iterator end () noexcept
 Return an iterator to end traversing the UList. More...
 
const_iterator cbegin () const noexcept
 Return const_iterator to begin traversing the constant UList. More...
 
const_iterator cend () const noexcept
 Return const_iterator to end traversing the constant UList. More...
 
const_iterator begin () const noexcept
 Return const_iterator to begin traversing the constant UList. More...
 
const_iterator end () 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...
 
reverse_iterator rend ()
 Return 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...
 
const_reverse_iterator rbegin () const
 Return const_reverse_iterator to begin reverse traversing the UList. More...
 
const_reverse_iterator rend () const
 Return const_reverse_iterator to end reverse traversing the UList. More...
 
label size () const noexcept
 The number of elements in the UList. More...
 
bool empty () const noexcept
 True if the UList is empty (ie, size() is zero) More...
 
void swap (UList< T > &list)
 Swap content with another UList of the same type in constant time. More...
 
bool operator== (const UList< T > &a) const
 Equality operation on ULists of the same type. More...
 
bool operator!= (const UList< T > &a) const
 The opposite of the equality operation. Takes linear time. More...
 
bool operator< (const UList< T > &list) const
 Compare two ULists lexicographically. Takes linear time. More...
 
bool operator> (const UList< T > &a) const
 Compare two ULists lexicographically. Takes linear time. More...
 
bool operator<= (const UList< T > &a) const
 Return true if !(a > b). Takes linear time. More...
 
bool operator>= (const UList< T > &a) const
 Return true if !(a < b). Takes linear time. More...
 
IstreamreadList (Istream &is)
 Read List contents from Istream. More...
 
void writeEntry (const word &keyword, Ostream &os) const
 Write the List as a dictionary entry with keyword. More...
 
OstreamwriteList (Ostream &os, const label shortLen=0) const
 Write List, with line-breaks in ASCII when length exceeds shortLen. More...
 
template<class TypeT = T>
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type test (const label i) const
 
template<class TypeT = T>
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type get (const label i) const
 
template<class TypeT = T>
std::enable_if< std::is_same< bool, TypeT >::value, bool >::type unset (const label i)
 
IstreamreadList (Istream &is)
 
OstreamwriteList (Ostream &os, const label) const
 
const booloperator[] (const label i) const
 
Foam::UPstream::commsStructoperator[] (const label procID)
 
const Foam::UPstream::commsStructoperator[] (const label procID) const
 
UPstream::commsStructoperator[] (const label procID)
 
const UPstream::commsStructoperator[] (const label procID) const
 
OstreamwriteList (Ostream &os, const label) const
 
IstreamreadList (Istream &is)
 

Additional Inherited Members

- Public Types inherited from Field< vector >
typedef pTraits< vector >::cmptType cmptType
 Component type. More...
 
typedef SubField< vectorsubField
 Declare type of subField. More...
 
- Public Types inherited from List< T >
typedef SubList< TsubList
 Declare type of subList. More...
 
- Public Types inherited from UList< T >
typedef T value_type
 The value type the list contains. More...
 
typedef Tpointer
 The pointer type for non-const access to value_type items. More...
 
typedef const Tconst_pointer
 The pointer type for const access to value_type items. More...
 
typedef Treference
 The type used for storing into value_type objects. More...
 
typedef const Tconst_reference
 The type used for reading from constant value_type objects. More...
 
typedef Titerator
 Random access iterator for traversing a UList. More...
 
typedef const Tconst_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...
 
- Static Public Member Functions inherited from Field< vector >
static const Field< vector > & null ()
 Return nullObject reference Field. More...
 
static autoPtr< Field< vector > > New (Istream &is)
 Return a pointer to a new Field created on freestore. More...
 
static tmp< Field< vector > > NewCalculatedType (const Field< Type2 > &f)
 
- Static Public Member Functions inherited from List< T >
static const List< T > & null ()
 Return a null List. More...
 
- Static Public Member Functions inherited from UList< T >
static const UList< T > & 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 inherited from FieldBase
static const char *const typeName
 Typename for Field. More...
 
static bool allowConstructFromLargerSize = false
 Permit read construct from a larger size. More...
 
- Protected Member Functions inherited from UList< T >
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...
 
labelRange validateRange (const labelRange &requestedRange) const
 
UList< T > & operator= (const UList< T > &)=delete
 No copy assignment (default: shallow copy) More...
 
void writeEntry (Ostream &os) const
 
void writeEntry (Ostream &os) const
 

Detailed Description

A NURBS 3D surface.

Source files

Definition at line 54 of file NURBS3DSurface.H.

Constructor & Destructor Documentation

◆ NURBS3DSurface() [1/7]

NURBS3DSurface ( const List< vector > &  CPs,
const label  nPointsU,
const label  nPointsV,
const NURBSbasis uBasis,
const NURBSbasis vBasis,
const word  name = "NURBS3DSurface" 
)

Construct from number of control points and basis functions.

Definition at line 307 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface().

Here is the call graph for this function:

◆ NURBS3DSurface() [2/7]

NURBS3DSurface ( const List< vector > &  CPs,
const List< scalar > &  weights,
const label  nPointsU,
const label  nPointsV,
const NURBSbasis uBasis,
const NURBSbasis vBasis,
const word  name = "NURBS3DSurface" 
)

Construct from number of control points, weights and basis functions.

Definition at line 344 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface().

Here is the call graph for this function:

◆ NURBS3DSurface() [3/7]

NURBS3DSurface ( const List< vector > &  CPs,
const label  nPointsU,
const label  nPointsV,
const label  uDegree,
const label  vDegree,
const label  nCPsU,
const label  nCPsV,
const word  name = "NURBS3DSurface" 
)

Construct from control points, basis degree and number of points.

Definition at line 382 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, and UList< T >::size().

Here is the call graph for this function:

◆ NURBS3DSurface() [4/7]

NURBS3DSurface ( const List< vector > &  CPs,
const label  nPointsU,
const label  nPointsV,
const label  uDegree,
const label  vDegree,
const label  nCPsU,
const label  nCPsV,
const scalarField knotsU,
const scalarField knotsV,
const word  name = "NURBS3DSurface" 
)

Construct from control points, basis degree, knots and number of.

points

Definition at line 430 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, and UList< T >::size().

Here is the call graph for this function:

◆ NURBS3DSurface() [5/7]

NURBS3DSurface ( const List< vector > &  CPs,
const List< scalar > &  weights,
const label  nPointsU,
const label  nPointsV,
const label  uDegree,
const label  vDegree,
const label  nCPsU,
const label  nCPsV,
const word  name = "NURBS3DSurface" 
)

Construct from control points, weights, basis degree, and number of.

points

Definition at line 480 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, and UList< T >::size().

Here is the call graph for this function:

◆ NURBS3DSurface() [6/7]

NURBS3DSurface ( const List< vector > &  CPs,
const List< scalar > &  weights,
const label  nPointsU,
const label  nPointsV,
const label  uDegree,
const label  vDegree,
const label  nCPsU,
const label  nCPsV,
const scalarField knotsU,
const scalarField knotsV,
const word  name = "NURBS3DSurface" 
)

Construct from control points, weights, basis degree, knots and.

number of points

Definition at line 530 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, and UList< T >::size().

Here is the call graph for this function:

◆ NURBS3DSurface() [7/7]

Construct as copy.

◆ ~NURBS3DSurface()

~NURBS3DSurface ( )
default

Destructor.

Member Function Documentation

◆ setNrmOrientation()

void setNrmOrientation ( const vector givenNrm,
const scalar  u,
const scalar  v 
)

Definition at line 584 of file NURBS3DSurface.C.

References Foam::endl(), Foam::Info, Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), and NURBS3DSurface::surfaceDerivativeV().

Here is the call graph for this function:

◆ flipNrmOrientation()

void flipNrmOrientation ( )

Flip the orientation of the nrm.

Definition at line 613 of file NURBS3DSurface.C.

◆ setCPs()

void setCPs ( const List< vector > &  CPs)

Definition at line 626 of file NURBS3DSurface.C.

◆ setWeights()

void setWeights ( const scalarList weights)

Definition at line 632 of file NURBS3DSurface.C.

◆ setName()

void setName ( const word name)

Definition at line 638 of file NURBS3DSurface.C.

References Foam::name().

Here is the call graph for this function:

◆ buildSurface()

void buildSurface ( )

Definition at line 644 of file NURBS3DSurface.C.

References NURBSbasis::basisValue(), NURBSbasis::degree(), field(), NURBSbasis::nCPs(), UList< T >::operator[](), and Foam::Zero.

Referenced by NURBS3DSurface::invertU(), NURBS3DSurface::invertUV(), NURBS3DSurface::invertV(), NURBS3DSurface::makeEquidistant(), NURBS3DSurface::NURBS3DSurface(), and NURBS3DSurface::writeVTK().

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

◆ invertU()

void invertU ( )

Definition at line 703 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::endl(), Foam::Info, NURBSbasis::nCPs(), UList< T >::size(), and Foam::Zero.

Here is the call graph for this function:

◆ invertV()

void invertV ( )

Definition at line 732 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::endl(), Foam::Info, NURBSbasis::nCPs(), UList< T >::size(), and Foam::Zero.

Here is the call graph for this function:

◆ invertUV()

void invertUV ( )

Definition at line 761 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::endl(), Foam::Info, NURBSbasis::nCPs(), UList< T >::size(), and Foam::Zero.

Here is the call graph for this function:

◆ makeEquidistant()

void makeEquidistant ( const label  lenAcc = 25,
const label  maxIter = 10,
const label  spacingCorrInterval = -1,
const scalar  tolerance = 1.e-5 
)

Definition at line 791 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), forAll, and Foam::Zero.

Here is the call graph for this function:

◆ surfacePoint()

vector surfacePoint ( const scalar &  u,
const scalar &  v 
)

Definition at line 877 of file NURBS3DSurface.C.

References NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Referenced by NURBS3DSurface::findClosestSurfacePoint().

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

◆ findClosestSurfacePoint() [1/3]

scalarList findClosestSurfacePoint ( const vector targetPoint,
const label  maxIter = 100,
const scalar  tolerance = 1.e-6 
)

Definition at line 924 of file NURBS3DSurface.C.

References b, Foam::endl(), forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), NURBS3DSurface::surfaceDerivativeUU(), NURBS3DSurface::surfaceDerivativeUV(), NURBS3DSurface::surfaceDerivativeV(), NURBS3DSurface::surfaceDerivativeVV(), NURBS3DSurface::surfacePoint(), and WarningInFunction.

Here is the call graph for this function:

◆ findClosestSurfacePoint() [2/3]

tmp< vector2DField > findClosestSurfacePoint ( const vectorField targetPoints,
const label  maxIter = 100,
const scalar  tolerance = 1.e-6 
)

◆ findClosestSurfacePoint() [3/3]

scalarList findClosestSurfacePoint ( const vector targetPoint,
const scalar &  uInitGuess,
const scalar &  vInitGuess,
const label  maxIter = 100,
const scalar  tolerance = 1.e-6 
)

Definition at line 1208 of file NURBS3DSurface.C.

References Foam::endl(), Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), NURBS3DSurface::surfaceDerivativeUU(), NURBS3DSurface::surfaceDerivativeV(), NURBS3DSurface::surfaceDerivativeVV(), NURBS3DSurface::surfacePoint(), and WarningInFunction.

Here is the call graph for this function:

◆ nrm()

const vector nrm ( scalar  u,
scalar  v 
)

Definition at line 1265 of file NURBS3DSurface.C.

References Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), NURBS3DSurface::surfaceDerivativeV(), and Foam::Zero.

Here is the call graph for this function:

◆ genEquidistant()

List< scalarList > genEquidistant ( const label  nUPts = 100,
const label  nVPts = 100,
const label  lenAcc = 25,
const label  maxIter = 10,
const label  spacingCorrInterval = -1,
const scalar  tolerance = 1.e-5 
)

Generate points on the surface which are evenly spaced in cartesian.

coordinate distances.

Definition at line 1284 of file NURBS3DSurface.C.

References forAll, U, and Foam::Zero.

◆ checkRangeU() [1/2]

bool checkRangeU ( const scalar  u,
const label  CPI,
const label  uDegree 
) const

Definition at line 1380 of file NURBS3DSurface.C.

References NURBSbasis::checkRange().

Referenced by NURBS3DSurface::checkRangeU(), and NURBS3DSurface::checkRangeUV().

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

◆ checkRangeU() [2/2]

bool checkRangeU ( const scalar  u,
const label  CPI 
) const

Definition at line 1393 of file NURBS3DSurface.C.

References NURBS3DSurface::checkRangeU(), and NURBSbasis::degree().

Here is the call graph for this function:

◆ checkRangeV() [1/2]

bool checkRangeV ( const scalar  v,
const label  CPI,
const label  vDegree 
) const

Definition at line 1405 of file NURBS3DSurface.C.

References NURBSbasis::checkRange().

Referenced by NURBS3DSurface::checkRangeUV(), and NURBS3DSurface::checkRangeV().

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

◆ checkRangeV() [2/2]

bool checkRangeV ( const scalar  v,
const label  CPI 
) const

Definition at line 1418 of file NURBS3DSurface.C.

References NURBS3DSurface::checkRangeV(), and NURBSbasis::degree().

Here is the call graph for this function:

◆ checkRangeUV() [1/2]

bool checkRangeUV ( const scalar  v,
const scalar  u,
const label  CPI,
const label  uDegree,
const label  vDegree 
) const

Definition at line 1430 of file NURBS3DSurface.C.

References NURBS3DSurface::checkRangeU(), and NURBS3DSurface::checkRangeV().

Referenced by NURBS3DSurface::checkRangeUV().

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

◆ checkRangeUV() [2/2]

bool checkRangeUV ( const scalar  v,
const scalar  u,
const label  CPI 
) const

Definition at line 1448 of file NURBS3DSurface.C.

References NURBS3DSurface::checkRangeUV(), and NURBSbasis::degree().

Here is the call graph for this function:

◆ lengthU() [1/4]

scalar lengthU ( const label  vIConst,
const label  uIStart,
const label  uIEnd 
) const

Definition at line 1462 of file NURBS3DSurface.C.

References forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), and Foam::Zero.

Referenced by NURBS3DSurface::lengthU().

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

◆ lengthU() [2/4]

scalar lengthU ( const scalar  vConst,
const scalar  uStart,
const scalar  uEnd,
const label  nPts 
) const

Definition at line 1496 of file NURBS3DSurface.C.

References forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), and Foam::Zero.

Here is the call graph for this function:

◆ lengthU() [3/4]

scalar lengthU ( const label  vIConst) const

Definition at line 1527 of file NURBS3DSurface.C.

References NURBS3DSurface::lengthU().

Here is the call graph for this function:

◆ lengthU() [4/4]

scalar lengthU ( const scalar  vConst) const

Definition at line 1533 of file NURBS3DSurface.C.

References NURBS3DSurface::lengthU().

Here is the call graph for this function:

◆ lengthV() [1/4]

scalar lengthV ( const label  uIConst,
const label  vIStart,
const label  vIEnd 
) const

Definition at line 1539 of file NURBS3DSurface.C.

References forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeV(), and Foam::Zero.

Referenced by NURBS3DSurface::lengthV().

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

◆ lengthV() [2/4]

scalar lengthV ( const scalar  uConst,
const scalar  vStart,
const scalar  vEnd,
const label  nPts 
) const

Definition at line 1573 of file NURBS3DSurface.C.

References forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeV(), and Foam::Zero.

Here is the call graph for this function:

◆ lengthV() [3/4]

scalar lengthV ( const label  uIConst) const

Definition at line 1604 of file NURBS3DSurface.C.

References NURBS3DSurface::lengthV().

Here is the call graph for this function:

◆ lengthV() [4/4]

scalar lengthV ( const scalar  uConst) const

Definition at line 1610 of file NURBS3DSurface.C.

References NURBS3DSurface::lengthV().

Here is the call graph for this function:

◆ surfaceDerivativeU()

vector surfaceDerivativeU ( const scalar  u,
const scalar  v 
) const

Surface derivative wrt u at point u,v.

Definition at line 1618 of file NURBS3DSurface.C.

References NURBSbasis::basisDerivativeU(), NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Referenced by NURBS3DSurface::findClosestSurfacePoint(), NURBS3DSurface::lengthDerivativeU(), NURBS3DSurface::lengthU(), NURBS3DSurface::nrm(), and NURBS3DSurface::setNrmOrientation().

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

◆ surfaceDerivativeV()

vector surfaceDerivativeV ( const scalar  u,
const scalar  v 
) const

Surface derivative wrt v at point u,v.

Definition at line 1660 of file NURBS3DSurface.C.

References NURBSbasis::basisDerivativeU(), NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Referenced by NURBS3DSurface::findClosestSurfacePoint(), NURBS3DSurface::lengthDerivativeV(), NURBS3DSurface::lengthV(), NURBS3DSurface::nrm(), and NURBS3DSurface::setNrmOrientation().

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

◆ surfaceDerivativeUV()

vector surfaceDerivativeUV ( const scalar  u,
const scalar  v 
) const

Surface second derivative wrt u and v at point u,v.

Definition at line 1702 of file NURBS3DSurface.C.

References NURBSbasis::basisDerivativeU(), NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Referenced by NURBS3DSurface::findClosestSurfacePoint().

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

◆ surfaceDerivativeUU()

vector surfaceDerivativeUU ( const scalar  u,
const scalar  v 
) const

Surface second derivative wrt u at point u,v.

Definition at line 1764 of file NURBS3DSurface.C.

References NURBSbasis::basisDerivativeU(), NURBSbasis::basisDerivativeUU(), NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Referenced by NURBS3DSurface::findClosestSurfacePoint(), and NURBS3DSurface::lengthDerivativeU().

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

◆ surfaceDerivativeVV()

vector surfaceDerivativeVV ( const scalar  u,
const scalar  v 
) const

Surface second derivative wrt v at point u,v.

Definition at line 1820 of file NURBS3DSurface.C.

References NURBSbasis::basisDerivativeU(), NURBSbasis::basisDerivativeUU(), NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Referenced by NURBS3DSurface::findClosestSurfacePoint(), and NURBS3DSurface::lengthDerivativeV().

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

◆ surfaceDerivativeCP()

scalar surfaceDerivativeCP ( const scalar  u,
const scalar  v,
const label  CPI 
) const

Surface derivative wrt the weight of CPI at point u,v.

Definition at line 1876 of file NURBS3DSurface.C.

References NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Here is the call graph for this function:

◆ surfaceDerivativeW()

vector surfaceDerivativeW ( const scalar  u,
const scalar  v,
const label  CPI 
) const

Surface derivative wrt WI at point u,v.

Definition at line 1918 of file NURBS3DSurface.C.

References NURBSbasis::basisValue(), NURBSbasis::degree(), NURBSbasis::nCPs(), and Foam::Zero.

Here is the call graph for this function:

◆ lengthDerivativeU()

scalar lengthDerivativeU ( const scalar  vConst,
const scalar  uStart,
const scalar  uEnd,
const label  nPts 
) const

Surface derivative wrt u length along v=const contour range.

Definition at line 1961 of file NURBS3DSurface.C.

References forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeU(), NURBS3DSurface::surfaceDerivativeUU(), and Foam::Zero.

Here is the call graph for this function:

◆ lengthDerivativeV()

scalar lengthDerivativeV ( const scalar  uConst,
const scalar  vStart,
const scalar  vEnd,
const label  nPts 
) const

Surface derivative wrt v length along u=const contour range.

Definition at line 1999 of file NURBS3DSurface.C.

References forAll, Foam::mag(), NURBS3DSurface::surfaceDerivativeV(), NURBS3DSurface::surfaceDerivativeVV(), and Foam::Zero.

Here is the call graph for this function:

◆ getBasisFunctionU()

const NURBSbasis & getBasisFunctionU ( ) const
inline

Get basis function.

Definition at line 457 of file NURBS3DSurface.H.

◆ getBasisFunctionV()

const NURBSbasis & getBasisFunctionV ( ) const
inline

Definition at line 462 of file NURBS3DSurface.H.

◆ getCPs()

const List< vector > & getCPs ( ) const
inline

Get CPs.

Definition at line 468 of file NURBS3DSurface.H.

◆ getWeights()

const scalarList & getWeights ( ) const
inline

Get weights.

Definition at line 474 of file NURBS3DSurface.H.

◆ getParametricCoordinatesU()

const scalarList & getParametricCoordinatesU ( ) const
inline

Get parametric coordinates.

Definition at line 480 of file NURBS3DSurface.H.

◆ getParametricCoordinatesV()

const scalarList & getParametricCoordinatesV ( ) const
inline

Definition at line 485 of file NURBS3DSurface.H.

◆ getName()

const word & getName ( ) const
inline

Get name.

Definition at line 491 of file NURBS3DSurface.H.

◆ getNPtsU()

label getNPtsU ( ) const
inline

Get number of point in u direction.

Definition at line 497 of file NURBS3DSurface.H.

◆ getNPtsV()

label getNPtsV ( ) const
inline

Get number of point in u direction.

Definition at line 503 of file NURBS3DSurface.H.

◆ getBoundaryCPIDs()

const labelList & getBoundaryCPIDs ( )

Get IDs of boundary control points.

Definition at line 2039 of file NURBS3DSurface.C.

References NURBSbasis::nCPs().

Referenced by NURBS3DSurface::getBoundaryCPIs(), and NURBS3DSurface::whichBoundaryCPI().

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

◆ getBoundaryCPIs()

const labelList & getBoundaryCPIs ( )

Definition at line 2077 of file NURBS3DSurface.C.

References NURBS3DSurface::getBoundaryCPIDs().

Here is the call graph for this function:

◆ whichBoundaryCPI()

const label & whichBoundaryCPI ( const label &  globalCPI)

Get the boundary CP ID based on the global CP ID.

Definition at line 2083 of file NURBS3DSurface.C.

References NURBS3DSurface::getBoundaryCPIDs().

Here is the call graph for this function:

◆ nrmOrientation()

label nrmOrientation ( ) const
inline

Return the nrm sgn relation to the u=0 nrm.

Definition at line 517 of file NURBS3DSurface.H.

◆ givenInitNrm()

const vector & givenInitNrm ( ) const
inline

Return the initial nrmal given to compare to the Curve's nrmals.

Definition at line 523 of file NURBS3DSurface.H.

◆ getCPsUCPIs()

const labelList & getCPsUCPIs ( ) const
inline

Return ID in u direction for a given cp ID.

Definition at line 529 of file NURBS3DSurface.H.

◆ getCPsVCPIs()

const labelList & getCPsVCPIs ( ) const
inline

Return ID in v direction for a given cp ID.

Definition at line 535 of file NURBS3DSurface.H.

◆ write() [1/3]

void write ( )

Write curve to file.

Definition at line 2096 of file NURBS3DSurface.C.

References NURBS3DSurface::write().

Referenced by NURBS3DSurface::write().

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

◆ write() [2/3]

void write ( const word  fileName)

Definition at line 2102 of file NURBS3DSurface.C.

References Foam::endl(), forAll, and splitCell::master().

Here is the call graph for this function:

◆ write() [3/3]

void write ( const fileName  dirName,
const fileName  fileName 
)

Definition at line 2159 of file NURBS3DSurface.C.

References Foam::endl(), forAll, and splitCell::master().

Here is the call graph for this function:

◆ writeWParses() [1/3]

void writeWParses ( )

Definition at line 2216 of file NURBS3DSurface.C.

References NURBS3DSurface::writeWParses().

Referenced by NURBS3DSurface::writeWParses().

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

◆ writeWParses() [2/3]

void writeWParses ( const word  fileName)

Definition at line 2222 of file NURBS3DSurface.C.

References Foam::endl(), forAll, and splitCell::master().

Here is the call graph for this function:

◆ writeWParses() [3/3]

void writeWParses ( const fileName  dirName,
const fileName  fileName 
)

Definition at line 2281 of file NURBS3DSurface.C.

References Foam::endl(), forAll, and splitCell::master().

Here is the call graph for this function:

◆ writeVTK()

void writeVTK ( const fileName  vtkDirName,
const fileName  vtkFileName 
)

Definition at line 2344 of file NURBS3DSurface.C.

References NURBS3DSurface::buildSurface(), Foam::exit(), fileName::ext(), Foam::FatalError, FatalErrorInFunction, splitCell::master(), NURBSbasis::nCPs(), and writer().

Here is the call graph for this function:

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