Cyclic patch for Arbitrary Mesh Interface (AMI) More...
Public Member Functions | |
TypeName ("cyclicAMI") | |
Runtime type information. More... | |
cyclicAMIPolyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType, const transformType transform=UNKNOWN, const word &defaultAMIMethod=faceAreaWeightAMI::typeName) | |
Construct from (base coupled patch) components. More... | |
cyclicAMIPolyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType, const word &defaultAMIMethod=faceAreaWeightAMI::typeName) | |
Construct from dictionary. More... | |
cyclicAMIPolyPatch (const cyclicAMIPolyPatch &, const polyBoundaryMesh &) | |
Construct as copy, resetting the boundary mesh. More... | |
cyclicAMIPolyPatch (const cyclicAMIPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart, const word &nbrPatchName) | |
Construct given the original patch and resetting the. More... | |
cyclicAMIPolyPatch (const cyclicAMIPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) | |
Construct given the original patch and a map. More... | |
virtual autoPtr< polyPatch > | clone (const polyBoundaryMesh &bm) const |
Construct and return a clone, resetting the boundary mesh. More... | |
virtual autoPtr< polyPatch > | clone (const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart) const |
Construct and return a clone, resetting the face list. More... | |
virtual autoPtr< polyPatch > | clone (const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) const |
Construct and return a clone, resetting the face list. More... | |
virtual | ~cyclicAMIPolyPatch ()=default |
Destructor. More... | |
bool | canResetAMI () const |
Flag to indicate whether the AMI can be reset. More... | |
bool | createAMIFaces () const |
Return access to the createAMIFaces flag. More... | |
bool | updatingAMI () const |
Return access to the updated flag. More... | |
virtual bool | changeTopology () const |
Return true if this patch changes the mesh topology. More... | |
virtual bool | setTopology (polyTopoChange &topoChange) |
Set topology changes in the polyTopoChange object. More... | |
virtual bool | coupled () const |
const word & | neighbPatchName () const |
Neighbour patch name. More... | |
virtual label | neighbPatchID () const |
Neighbour patch ID. More... | |
virtual bool | owner () const |
Does this side own the patch? More... | |
virtual const cyclicAMIPolyPatch & | neighbPatch () const |
Return a reference to the neighbour patch. More... | |
const AMIPatchToPatchInterpolation & | AMI () const |
Return a reference to the AMI interpolator. More... | |
const scalarListList & | weights () const |
Helper function to return the weights. More... | |
const scalarField & | weightsSum () const |
Helper function to return the weights sum. More... | |
bool | applyLowWeightCorrection () const |
Return true if applying the low weight correction. More... | |
vectorField & | faceAreas0 () const |
Return access to the initial face areas. More... | |
vectorField & | faceCentres0 () const |
Return access to the initial face centres. More... | |
const vector & | rotationAxis () const |
Axis of rotation for rotational cyclic AMI. More... | |
const point & | rotationCentre () const |
Point on axis of rotation for rotational cyclic AMI. More... | |
const vector & | separationVector () const |
Translation vector for translational cyclic AMI. More... | |
virtual void | transformPosition (pointField &) const |
Transform patch-based positions from nbr side to this side. More... | |
virtual void | transformPosition (point &l, const label facei) const |
Transform a patch-based position from nbr side to this side. More... | |
virtual void | reverseTransformPosition (point &l, const label facei) const |
Transform a patch-based position from this side to nbr side. More... | |
virtual void | reverseTransformDirection (vector &d, const label facei) const |
Transform a patch-based direction from this side to nbr side. More... | |
template<class Type > | |
tmp< Field< Type > > | interpolate (const Field< Type > &fld, const UList< Type > &defaultValues=UList< Type >()) const |
Interpolate field. More... | |
template<class Type > | |
tmp< Field< Type > > | interpolate (const tmp< Field< Type >> &tFld, const UList< Type > &defaultValues=UList< Type >()) const |
Interpolate tmp field. More... | |
template<class Type , class CombineOp > | |
void | interpolate (const UList< Type > &fld, const CombineOp &cop, List< Type > &result, const UList< Type > &defaultValues=UList< Type >()) const |
Low-level interpolate List. More... | |
virtual void | calcGeometry (const primitivePatch &referPatch, const pointField &thisCtrs, const vectorField &thisAreas, const pointField &thisCc, const pointField &nbrCtrs, const vectorField &nbrAreas, const pointField &nbrCc) |
Calculate the patch geometry. More... | |
virtual void | initOrder (PstreamBuffers &, const primitivePatch &) const |
virtual bool | order (PstreamBuffers &, const primitivePatch &, labelList &faceMap, labelList &rotation) const |
Return new ordering for primitivePatch. More... | |
label | pointFace (const label facei, const vector &n, point &p) const |
virtual void | write (Ostream &) const |
Write the polyPatch data as a dictionary. More... | |
template<class Type > | |
Foam::tmp< Foam::Field< Type > > | interpolate (const Field< Type > &fld, const UList< Type > &defaultValues) const |
template<class Type > | |
Foam::tmp< Foam::Field< Type > > | interpolate (const tmp< Field< Type >> &tFld, const UList< Type > &defaultValues) const |
Public Member Functions inherited from coupledPolyPatch | |
TypeName ("coupled") | |
Runtime type information. More... | |
coupledPolyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType, const transformType transform) | |
Construct from components. More... | |
coupledPolyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType) | |
Construct from dictionary. More... | |
coupledPolyPatch (const coupledPolyPatch &, const polyBoundaryMesh &) | |
Construct as copy, resetting the boundary mesh. More... | |
coupledPolyPatch (const coupledPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart) | |
Construct given the original patch and resetting the. More... | |
coupledPolyPatch (const coupledPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) | |
Construct given the original patch and a map. More... | |
virtual | ~coupledPolyPatch () |
Destructor. More... | |
virtual bool | neighbour () const |
Does the coupled side own the patch ? More... | |
virtual transformType | transform () const |
Type of transform. More... | |
virtual transformType & | transform () |
Type of transform. More... | |
virtual bool | separated () const |
Are the planes separated. More... | |
virtual const vectorField & | separation () const |
If the planes are separated the separation vector. More... | |
virtual bool | parallel () const |
Are the cyclic planes parallel. More... | |
virtual const tensorField & | forwardT () const |
Return face transformation tensor. More... | |
virtual const tensorField & | reverseT () const |
Return neighbour-cell transformation tensor. More... | |
virtual const boolList & | collocated () const |
Are faces collocated. Either size 0,1 or length of patch. More... | |
scalar | matchTolerance () const |
Public Member Functions inherited from polyPatch | |
TypeName ("patch") | |
Runtime type information. More... | |
declareRunTimeSelectionTable (autoPtr, polyPatch, word,(const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType),(name, size, start, index, bm, patchType)) | |
declareRunTimeSelectionTable (autoPtr, polyPatch, dictionary,(const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType),(name, dict, index, bm, patchType)) | |
polyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType) | |
Construct from components. More... | |
polyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &physicalType, const wordList &inGroups) | |
Construct from components. More... | |
polyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType) | |
Construct from dictionary. More... | |
polyPatch (const polyPatch &, const polyBoundaryMesh &) | |
Construct as copy, resetting the boundary mesh. More... | |
polyPatch (const polyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart) | |
Construct given the original patch and resetting the. More... | |
polyPatch (const polyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) | |
Construct given the original patch and a map. More... | |
polyPatch (const polyPatch &) | |
Construct as copy. More... | |
virtual | ~polyPatch () |
Destructor. More... | |
label | offset () const |
The offset where this patch starts in the boundary face list. More... | |
label | start () const |
Return start label of this patch in the polyMesh face list. More... | |
labelRange | range () const |
Return start/size range of this patch. More... | |
const polyBoundaryMesh & | boundaryMesh () const |
Return boundaryMesh reference. More... | |
template<class T > | |
const UIndirectList< T > | patchInternalList (const UList< T > &internalValues) const |
Extract face cell data. More... | |
template<class T > | |
const List< T >::subList | patchSlice (const UList< T > &l) const |
Slice list to patch. More... | |
template<class T > | |
const Field< T >::subField | patchSlice (const Field< T > &l) const |
Slice Field to patch. More... | |
const vectorField::subField | faceCentres () const |
Return face centres. More... | |
const vectorField::subField | faceAreas () const |
Return face normals. More... | |
tmp< vectorField > | faceCellCentres () const |
Return face cell centres. More... | |
tmp< scalarField > | areaFraction () const |
const labelUList & | faceCells () const |
Return face-cell addressing. More... | |
const labelList & | meshEdges () const |
Return global edge index for local edges. More... | |
virtual void | clearAddressing () |
Clear addressing. More... | |
label | whichFace (const label l) const |
Return label of face in patch from global face label. More... | |
void | operator= (const polyPatch &) |
Assignment. More... | |
Public Member Functions inherited from patchIdentifier | |
patchIdentifier (const patchIdentifier &)=default | |
Copy construct. More... | |
patchIdentifier & | operator= (const patchIdentifier &)=default |
Copy assignment. More... | |
virtual | ~patchIdentifier ()=default |
Destructor. More... | |
patchIdentifier () | |
Default construct, with index zero. More... | |
patchIdentifier (const word &name, const label index) | |
Construct from mandatory components. More... | |
patchIdentifier (const word &name, const label index, const word &physicalType, const wordList &inGroups=wordList()) | |
Construct from components. More... | |
patchIdentifier (const word &name, const dictionary &dict, const label index) | |
Construct from dictionary. More... | |
patchIdentifier (const patchIdentifier &p, const label index) | |
Copy construct, resetting the index. More... | |
const word & | name () const |
The patch name. More... | |
word & | name () |
Modifiable patch name. More... | |
const word & | physicalType () const |
The (optional) physical type of the patch. More... | |
word & | physicalType () |
Modifiable (optional) physical type of the patch. More... | |
label | index () const |
The index of this patch in the boundaryMesh. More... | |
label & | index () |
Modifiable index of this patch in the boundaryMesh. More... | |
const wordList & | inGroups () const |
The (optional) groups that the patch belongs to. More... | |
wordList & | inGroups () |
Modifiable (optional) groups that the patch belongs to. More... | |
bool | inGroup (const word &name) const |
True if the patch is in named group. More... | |
void | write (Ostream &os) const |
Public Member Functions inherited from PrimitivePatch< FaceList, PointField > | |
PrimitivePatch (const FaceList &faces, const PointField &points) | |
Construct from components. More... | |
PrimitivePatch (FaceList &&faces, const PointField &points) | |
Construct from components, transferring faces. More... | |
PrimitivePatch (FaceList &faces, PointField &points, const bool reuse) | |
Construct from components, reuse storage. More... | |
PrimitivePatch (const PrimitivePatch< FaceList, PointField > &pp) | |
Copy construct. More... | |
virtual | ~PrimitivePatch () |
Destructor. More... | |
void | clearOut () |
void | clearGeom () |
void | clearTopology () |
void | clearPatchMeshAddr () |
void | swap (PrimitivePatch &)=delete |
Suppress direct swapping, since storage containers may be const. More... | |
const Field< point_type > & | points () const |
Return reference to global points. More... | |
label | nPoints () const |
Return number of points supporting patch faces. More... | |
label | nEdges () const |
Return number of edges in patch. More... | |
const edgeList & | edges () const |
Return list of edges, address into LOCAL point list. More... | |
label | nInternalEdges () const |
Number of internal edges. More... | |
bool | isInternalEdge (const label edgei) const |
Is internal edge? More... | |
const labelList & | boundaryPoints () const |
Return list of boundary points, address into LOCAL point list. More... | |
const labelListList & | faceFaces () const |
Return face-face addressing. More... | |
const labelListList & | edgeFaces () const |
Return edge-face addressing. More... | |
const labelListList & | faceEdges () const |
Return face-edge addressing. More... | |
const labelListList & | pointEdges () const |
Return point-edge addressing. More... | |
const labelListList & | pointFaces () const |
Return point-face addressing. More... | |
const List< face_type > & | localFaces () const |
Return patch faces addressing into local point list. More... | |
const labelList & | meshPoints () const |
Return labelList of mesh points in patch. More... | |
const Map< label > & | meshPointMap () const |
Mesh point map. More... | |
const Field< point_type > & | localPoints () const |
Return pointField of points in patch. More... | |
const labelList & | localPointOrder () const |
Return orders the local points for most efficient search. More... | |
label | whichPoint (const label gp) const |
Given a global point index, return the local point index. More... | |
label | whichEdge (const edge &) const |
labelList | meshEdges (const edgeList &allEdges, const labelListList &cellEdges, const labelList &faceCells) const |
labelList | meshEdges (const edgeList &allEdges, const labelListList &pointEdges) const |
const Field< point_type > & | faceCentres () const |
Return face centres for patch. More... | |
const Field< point_type > & | faceAreas () const |
Return face area vectors for patch. More... | |
const Field< scalar > & | magFaceAreas () const |
Return face area magnitudes for patch. More... | |
const Field< point_type > & | faceNormals () const |
Return face unit normals for patch. More... | |
const Field< point_type > & | pointNormals () const |
Return point normals for patch. More... | |
bool | hasFaceAreas () const |
bool | hasFaceCentres () const |
bool | hasFaceNormals () const |
bool | hasPointNormals () const |
template<class ToPatch > | |
List< objectHit > | projectPoints (const ToPatch &targetPatch, const Field< point_type > &projectionDirection, const intersection::algorithm=intersection::FULL_RAY, const intersection::direction=intersection::VECTOR) const |
Project vertices of patch onto another patch. More... | |
template<class ToPatch > | |
List< objectHit > | projectFaceCentres (const ToPatch &targetPatch, const Field< point_type > &projectionDirection, const intersection::algorithm=intersection::FULL_RAY, const intersection::direction=intersection::VECTOR) const |
Project vertices of patch onto another patch. More... | |
const labelListList & | edgeLoops () const |
Return list of closed loops of boundary vertices. More... | |
surfaceTopo | surfaceType () const |
Calculate surface type formed by patch. More... | |
bool | checkTopology (const bool report=false, labelHashSet *setPtr=nullptr) const |
Check surface formed by patch for manifoldness (see above). More... | |
bool | checkPointManifold (const bool report=false, labelHashSet *setPtr=nullptr) const |
Checks primitivePatch for faces sharing point but not edge. More... | |
virtual void | movePoints (const Field< point_type > &) |
Correct patch after moving points. More... | |
void | operator= (const PrimitivePatch< FaceList, PointField > &rhs) |
Copy assign faces. Leave points alone (could be a reference). More... | |
void | operator= (PrimitivePatch< FaceList, PointField > &&rhs) |
Move assign faces. Leave points alone (could be a reference). More... | |
template<class ToPatch > | |
Foam::List< Foam::objectHit > | projectPoints (const ToPatch &targetPatch, const Field< typename Foam::PrimitivePatch< FaceList, PointField >::point_type > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const |
template<class ToPatch > | |
Foam::List< Foam::objectHit > | projectFaceCentres (const ToPatch &targetPatch, const Field< typename Foam::PrimitivePatch< FaceList, PointField >::point_type > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const |
Static Public Attributes | |
static const scalar | tolerance_ = 1e-10 |
Tolerance used e.g. for area calculations/limits. More... | |
Static Public Attributes inherited from coupledPolyPatch | |
static const Enum< transformType > | transformTypeNames |
Static Public Attributes inherited from polyPatch | |
static int | disallowGenericPolyPatch |
Debug switch to disallow the use of genericPolyPatch. More... | |
Protected Member Functions | |
virtual bool | removeAMIFaces (polyTopoChange &topoChange) |
Collect faces to remove in the topoChange container. More... | |
virtual bool | addAMIFaces (polyTopoChange &topoChange) |
Collect faces to add in the topoChange container. More... | |
virtual void | setAMIFaces () |
Set properties of newly inserted faces after topological changes. More... | |
virtual void | restoreScaledGeometry () |
const autoPtr< searchableSurface > & | surfPtr () const |
Create and return pointer to the projection surface. More... | |
virtual void | resetAMI (const UList< point > &points) const |
Reset the AMI interpolator, supply patch points. More... | |
virtual void | resetAMI () const |
Reset the AMI interpolator, use current patch points. More... | |
virtual void | calcTransforms () |
Recalculate the transformation tensors. More... | |
virtual void | initGeometry (PstreamBuffers &) |
Initialise the calculation of the patch geometry. More... | |
virtual void | calcGeometry (PstreamBuffers &) |
Calculate the patch geometry. More... | |
virtual void | initMovePoints (PstreamBuffers &pBufs, const pointField &) |
Initialise the patches for moving points. More... | |
virtual void | movePoints (PstreamBuffers &pBufs, const pointField &) |
Correct patches after moving points. More... | |
virtual void | initUpdateMesh (PstreamBuffers &) |
Initialise the update of the patch topology. More... | |
virtual void | updateMesh (PstreamBuffers &) |
Update of the patch topology. More... | |
virtual void | clearGeom () |
Clear geometry. More... | |
Protected Member Functions inherited from coupledPolyPatch | |
void | calcTransformTensors (const vectorField &Cf, const vectorField &Cr, const vectorField &nf, const vectorField &nr, const scalarField &smallDist, const scalar absTol, const transformType=UNKNOWN) const |
Calculate the transformation tensors. More... | |
Protected Member Functions inherited from polyPatch | |
virtual void | movePoints (const Field< point_type > &) |
Inherit movePoints from primitivePatch. More... | |
Protected Attributes | |
word | nbrPatchName_ |
Name of other half. More... | |
const coupleGroupIdentifier | coupleGroup_ |
Optional patchGroup to find neighbPatch. More... | |
label | nbrPatchID_ |
Index of other half. More... | |
vector | rotationAxis_ |
Axis of rotation for rotational cyclics. More... | |
point | rotationCentre_ |
Point on axis of rotation for rotational cyclics. More... | |
bool | rotationAngleDefined_ |
Flag to show whether the rotation angle is defined. More... | |
scalar | rotationAngle_ |
Rotation angle. More... | |
vector | separationVector_ |
Translation vector. More... | |
autoPtr< AMIPatchToPatchInterpolation > | AMIPtr_ |
AMI interpolation class. More... | |
const dictionary | surfDict_ |
Dictionary used during projection surface construction. More... | |
autoPtr< searchableSurface > | surfPtr_ |
Projection surface. More... | |
bool | createAMIFaces_ |
Flag to indicate that new AMI faces will created. More... | |
bool | moveFaceCentres_ |
Move face centres (default = no) More... | |
bool | updatingAMI_ |
labelListList | srcFaceIDs_ |
labelListList | tgtFaceIDs_ |
vectorField | faceAreas0_ |
Temporary storage for AMI face areas. More... | |
vectorField | faceCentres0_ |
Temporary storage for AMI face centres. More... | |
Additional Inherited Members | |
Public Types inherited from coupledPolyPatch | |
enum | transformType { UNKNOWN, ROTATIONAL, TRANSLATIONAL, COINCIDENTFULLMATCH, NOORDERING } |
Public Types inherited from PrimitivePatch< FaceList, PointField > | |
enum | surfaceTopo { MANIFOLD, OPEN, ILLEGAL } |
Enumeration defining the surface type. Used in check routines. More... | |
typedef std::remove_reference< FaceList >::type::value_type | face_type |
The face type. More... | |
typedef std::remove_reference< PointField >::type::value_type | point_type |
The point type. More... | |
typedef FaceList | FaceListType |
The face list type. More... | |
typedef PointField | PointFieldType |
The point field type. More... | |
typedef face_type | FaceType |
Deprecated(2020-03) prefer face_type typedef. More... | |
Static Public Member Functions inherited from coupledPolyPatch | |
static scalarField | calcFaceTol (const UList< face > &faces, const pointField &points, const pointField &faceCentres) |
Calculate typical tolerance per face. Is currently max distance. More... | |
Static Public Member Functions inherited from polyPatch | |
static autoPtr< polyPatch > | New (const word &patchType, const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm) |
Return a pointer to a new patch created on freestore from. More... | |
static autoPtr< polyPatch > | New (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm) |
Return a pointer to a new patch created on freestore from. More... | |
static autoPtr< polyPatch > | New (const word &patchType, const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm) |
Return a pointer to a new patch created on freestore from. More... | |
static bool | constraintType (const word &pt) |
Return true if the given type is a constraint type. More... | |
static wordList | constraintTypes () |
Return a list of all the constraint patch types. More... | |
Static Public Member Functions inherited from patchIdentifier | |
static word | defaultName (const label n=-1) |
Default patch name: "patch" or "patchN". More... | |
Static Protected Member Functions inherited from coupledPolyPatch | |
static void | writeOBJ (Ostream &os, const point &pt) |
Write point in OBJ format. More... | |
static void | writeOBJ (Ostream &, const pointField &, const labelList &) |
Write selected points in OBJ format. More... | |
static void | writeOBJ (const fileName &, const UList< face > &, const pointField &) |
Write patch. More... | |
static void | writeOBJ (Ostream &os, const point &p0, const point &p1, label &vertI) |
Write edge in OBJ format. More... | |
static pointField | getAnchorPoints (const UList< face > &, const pointField &, const transformType) |
Get a unique anchor point for all faces. More... | |
static label | getRotation (const pointField &points, const face &f, const point &anchor, const scalar tol) |
Get the number of vertices face f needs to be rotated such that. More... | |
Cyclic patch for Arbitrary Mesh Interface (AMI)
Includes provision for updating the patch topology to enforce a 1-to-1 face match across the interface, based on the createAMIFaces
flag.
The manipulations are based on the reference:
H.J. Aguerre, S. Márquez Damián, J.M. Gimenez, N.M.Nigro, Conservative handling of arbitrary non-conformal interfaces using an efficient supermesh, Journal of Computational Physics 335(15) 21-49. 2017. https://doi.org/10.1016/j.jcp.2017.01.018.
Definition at line 67 of file cyclicAMIPolyPatch.H.
cyclicAMIPolyPatch | ( | const word & | name, |
const label | size, | ||
const label | start, | ||
const label | index, | ||
const polyBoundaryMesh & | bm, | ||
const word & | patchType, | ||
const transformType | transform = UNKNOWN , |
||
const word & | defaultAMIMethod = faceAreaWeightAMI::typeName |
||
) |
Construct from (base coupled patch) components.
Definition at line 557 of file cyclicAMIPolyPatch.C.
cyclicAMIPolyPatch | ( | const word & | name, |
const dictionary & | dict, | ||
const label | index, | ||
const polyBoundaryMesh & | bm, | ||
const word & | patchType, | ||
const word & | defaultAMIMethod = faceAreaWeightAMI::typeName |
||
) |
Construct from dictionary.
Definition at line 593 of file cyclicAMIPolyPatch.C.
References Foam::expressions::patchExpr::debug, Foam::degToRad(), dict, Foam::endl(), Foam::exit(), Foam::FatalIOError, FatalIOErrorInFunction, dictionary::get(), dictionary::getOrDefault(), Foam::Info, Foam::mag(), Foam::name(), word::null, dictionary::readEntry(), dictionary::readIfPresent(), Foam::transform(), and word::valid().
cyclicAMIPolyPatch | ( | const cyclicAMIPolyPatch & | pp, |
const polyBoundaryMesh & | bm | ||
) |
Construct as copy, resetting the boundary mesh.
Definition at line 701 of file cyclicAMIPolyPatch.C.
cyclicAMIPolyPatch | ( | const cyclicAMIPolyPatch & | pp, |
const polyBoundaryMesh & | bm, | ||
const label | index, | ||
const label | newSize, | ||
const label | newStart, | ||
const word & | nbrPatchName | ||
) |
Construct given the original patch and resetting the.
face list and boundary mesh information
Definition at line 732 of file cyclicAMIPolyPatch.C.
References Foam::exit(), Foam::FatalError, FatalErrorInFunction, and Foam::name().
cyclicAMIPolyPatch | ( | const cyclicAMIPolyPatch & | pp, |
const polyBoundaryMesh & | bm, | ||
const label | index, | ||
const labelUList & | mapAddressing, | ||
const label | newStart | ||
) |
Construct given the original patch and a map.
Definition at line 775 of file cyclicAMIPolyPatch.C.
|
virtualdefault |
Destructor.
|
protectedvirtual |
Collect faces to remove in the topoChange container.
Definition at line 82 of file cyclicAMIPolyPatchTopologyChange.C.
References Foam::abort(), DebugInFunction, Foam::endl(), Foam::FatalError, FatalErrorInFunction, polyTopoChange::removeFace(), and polyPatch::start().
|
protectedvirtual |
Collect faces to add in the topoChange container.
Definition at line 137 of file cyclicAMIPolyPatchTopologyChange.C.
References Foam::abort(), polyTopoChange::addFace(), Foam::expressions::patchExpr::debug, DebugInFunction, Foam::endl(), polyMesh::faceOwner(), polyMesh::faces(), polyMesh::faceZones(), Foam::FatalError, FatalErrorInFunction, forAll, patchIdentifier::index(), Foam::Info, mesh, boundaryMesh::mesh(), patchIdentifier::name(), Foam::name(), Foam::nl, Foam::Pout, Foam::returnReduce(), List< T >::setSize(), polyPatch::start(), and ZoneMesh< ZoneType, MeshType >::whichZone().
|
protectedvirtual |
Set properties of newly inserted faces after topological changes.
Definition at line 261 of file cyclicAMIPolyPatchTopologyChange.C.
References Foam::abort(), Foam::expressions::patchExpr::debug, DebugInFunction, Foam::endl(), polyPatch::faceAreas(), cyclicAMIPolyPatch::faceAreas0(), polyPatch::faceCentres(), cyclicAMIPolyPatch::faceCentres0(), Foam::FatalError, FatalErrorInFunction, forAll, Foam::identity(), Foam::mag(), Foam::name(), Foam::nl, Foam::Pout, and autoPtr< T >::reset().
|
protectedvirtual |
Helper to re-apply the geometric scaling lost during mesh updates
Definition at line 35 of file cyclicAMIPolyPatchTopologyChange.C.
References Foam::abort(), polyPatch::boundaryMesh(), cyclicAMIPolyPatch::createAMIFaces_, DebugInfo, DebugInFunction, Foam::endl(), polyPatch::faceAreas(), cyclicAMIPolyPatch::faceAreas0_, polyPatch::faceCentres(), cyclicAMIPolyPatch::faceCentres0_, Foam::FatalError, FatalErrorInFunction, Foam::gSum(), Foam::mag(), mesh, cyclicAMIPolyPatch::moveFaceCentres_, patchIdentifier::name(), Foam::nl, and WarningInFunction.
|
protected |
Create and return pointer to the projection surface.
Definition at line 292 of file cyclicAMIPolyPatch.C.
References TimePaths::constant(), mesh, boundaryMesh::mesh(), IOobject::MUST_READ, Foam::name(), searchableSurface::New(), IOobject::NO_WRITE, and fvMesh::time().
Reset the AMI interpolator, supply patch points.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 329 of file cyclicAMIPolyPatch.C.
References Foam::expressions::patchExpr::debug, DebugInFunction, Foam::endl(), PrimitivePatch< FaceList, PointField >::localFaces(), PrimitivePatch< FaceList, PointField >::localPoints(), boundaryMesh::mesh(), Foam::name(), Time::path(), and Foam::meshTools::writeOBJ().
|
protectedvirtual |
Reset the AMI interpolator, use current patch points.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 323 of file cyclicAMIPolyPatch.C.
Referenced by cyclicACMIPolyPatch::resetAMI().
|
protectedvirtual |
Recalculate the transformation tensors.
Definition at line 400 of file cyclicAMIPolyPatch.C.
References DebugInFunction, DebugPout, Foam::endl(), polyPatch::faceCentres(), forAll, Foam::name(), Foam::nl, and PrimitivePatch< FaceList, PointField >::points().
|
protectedvirtual |
Initialise the calculation of the patch geometry.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 436 of file cyclicAMIPolyPatch.C.
References DebugInFunction, Foam::endl(), and polyPatch::initGeometry().
Referenced by cyclicACMIPolyPatch::initGeometry().
|
protectedvirtual |
Calculate the patch geometry.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 453 of file cyclicAMIPolyPatch.C.
References DebugInFunction, and Foam::endl().
Referenced by cyclicACMIPolyPatch::calcGeometry().
|
protectedvirtual |
Initialise the patches for moving points.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 460 of file cyclicAMIPolyPatch.C.
References DebugInFunction, Foam::endl(), PrimitivePatch< FaceList, PointField >::movePoints(), and p.
Referenced by cyclicACMIPolyPatch::initMovePoints().
|
protectedvirtual |
Correct patches after moving points.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 496 of file cyclicAMIPolyPatch.C.
References DebugInFunction, and Foam::endl().
Referenced by cyclicACMIPolyPatch::movePoints().
|
protectedvirtual |
Initialise the update of the patch topology.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 519 of file cyclicAMIPolyPatch.C.
References DebugInFunction, Foam::endl(), polyPatch::initUpdateMesh(), and mesh.
Referenced by cyclicACMIPolyPatch::initUpdateMesh().
|
protectedvirtual |
Update of the patch topology.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 532 of file cyclicAMIPolyPatch.C.
References DebugInFunction, Foam::endl(), and polyPatch::updateMesh().
Referenced by cyclicACMIPolyPatch::updateMesh().
|
protectedvirtual |
Clear geometry.
Reimplemented from polyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 541 of file cyclicAMIPolyPatch.C.
References polyPatch::clearGeom(), DebugInFunction, and Foam::endl().
Referenced by cyclicACMIPolyPatch::clearGeom().
TypeName | ( | "cyclicAMI" | ) |
Runtime type information.
|
inlinevirtual |
Construct and return a clone, resetting the boundary mesh.
Reimplemented from polyPatch.
Reimplemented in cyclicACMIPolyPatch, and cyclicPeriodicAMIPolyPatch.
Definition at line 266 of file cyclicAMIPolyPatch.H.
|
inlinevirtual |
Construct and return a clone, resetting the face list.
and boundary mesh
Reimplemented from polyPatch.
Reimplemented in cyclicACMIPolyPatch, and cyclicPeriodicAMIPolyPatch.
Definition at line 274 of file cyclicAMIPolyPatch.H.
References patchIdentifier::index(), and cyclicAMIPolyPatch::nbrPatchName_.
|
inlinevirtual |
Construct and return a clone, resetting the face list.
and boundary mesh
Reimplemented from polyPatch.
Reimplemented in cyclicACMIPolyPatch, and cyclicPeriodicAMIPolyPatch.
Definition at line 298 of file cyclicAMIPolyPatch.H.
References patchIdentifier::index().
|
inline |
Flag to indicate whether the AMI can be reset.
Definition at line 31 of file cyclicAMIPolyPatchI.H.
References polyPatch::boundaryMesh(), polyBoundaryMesh::mesh(), UPstream::parRun(), TimePaths::processorCase(), and objectRegistry::time().
|
inline |
Return access to the createAMIFaces flag.
Definition at line 37 of file cyclicAMIPolyPatchI.H.
|
inline |
Return access to the updated flag.
Definition at line 43 of file cyclicAMIPolyPatchI.H.
|
virtual |
Return true if this patch changes the mesh topology.
True when createAMIFaces is true
Reimplemented from polyPatch.
Definition at line 647 of file cyclicAMIPolyPatchTopologyChange.C.
References DebugInFunction, and Foam::endl().
|
virtual |
Set topology changes in the polyTopoChange object.
Reimplemented from polyPatch.
Definition at line 657 of file cyclicAMIPolyPatchTopologyChange.C.
References DebugInFunction, Foam::endl(), and polyTopoChange::points().
|
inlinevirtual |
Is patch 'coupled'. Note that on AMI the geometry is not coupled but the fields are!
Reimplemented from coupledPolyPatch.
Definition at line 348 of file cyclicAMIPolyPatch.H.
|
inline |
Neighbour patch name.
Definition at line 49 of file cyclicAMIPolyPatchI.H.
References patchID.
Referenced by cyclicACMIPolyPatch::clone(), cyclicAMIPolyPatch::neighbPatchID(), and AMIWeights::reportPatch().
|
virtual |
Neighbour patch ID.
Definition at line 807 of file cyclicAMIPolyPatch.C.
References Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, Foam::name(), cyclicAMIPolyPatch::neighbPatchName(), Foam::nl, and WarningInFunction.
Referenced by cyclicACMIFvPatch::neighbFvPatch(), cyclicAMIFvPatch::neighbFvPatch(), cyclicACMIFvPatch::neighbPatch(), cyclicAMIFvPatch::neighbPatch(), cyclicAMIPointPatch::neighbPatch(), cyclicACMIPointPatch::neighbPatch(), cyclicACMIFvPatch::neighbPatchID(), and cyclicAMIFvPatch::neighbPatchID().
|
virtual |
Does this side own the patch?
Implements coupledPolyPatch.
Definition at line 843 of file cyclicAMIPolyPatch.C.
Referenced by combine< Type, TrackingData >::operator()(), cyclicACMIFvPatch::owner(), cyclicAMIFvPatch::owner(), and AMIWeights::writeWeightFields().
|
virtual |
Return a reference to the neighbour patch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 849 of file cyclicAMIPolyPatch.C.
Referenced by FaceCellWave< Type, TrackingData >::handleAMICyclicPatches(), particle< Type >::hitCyclicAMIPatch(), combine< Type, TrackingData >::operator()(), cyclicACMIPointPatchField< Type >::swapAddSeparated(), and AMIWeights::writeWeightFields().
const Foam::AMIPatchToPatchInterpolation & AMI | ( | ) | const |
Return a reference to the AMI interpolator.
Definition at line 856 of file cyclicAMIPolyPatch.C.
References Foam::abort(), Foam::FatalError, and FatalErrorInFunction.
Referenced by cyclicAMIFvPatch::AMI(), cyclicACMIFvPatch::AMI(), AMIWeights::reportPatch(), and AMIWeights::writeWeightFields().
|
inline |
Helper function to return the weights.
Definition at line 61 of file cyclicAMIPolyPatchI.H.
Referenced by cyclicACMIPolyPatch::scalePatchFaceAreas().
|
inline |
Helper function to return the weights sum.
Definition at line 72 of file cyclicAMIPolyPatchI.H.
Referenced by cyclicACMIPolyPatch::scalePatchFaceAreas().
bool applyLowWeightCorrection | ( | ) | const |
Return true if applying the low weight correction.
Definition at line 874 of file cyclicAMIPolyPatch.C.
Referenced by cyclicAMIFvPatch::applyLowWeightCorrection(), and FaceCellWave< Type, TrackingData >::handleAMICyclicPatches().
|
inline |
Return access to the initial face areas.
Used for topology change
Definition at line 83 of file cyclicAMIPolyPatchI.H.
Referenced by cyclicAMIPolyPatch::setAMIFaces().
|
inline |
Return access to the initial face centres.
Used for topology change
Definition at line 89 of file cyclicAMIPolyPatchI.H.
Referenced by cyclicAMIPolyPatch::setAMIFaces().
|
inline |
Axis of rotation for rotational cyclic AMI.
Definition at line 94 of file cyclicAMIPolyPatchI.H.
|
inline |
Point on axis of rotation for rotational cyclic AMI.
Definition at line 100 of file cyclicAMIPolyPatchI.H.
|
inline |
Translation vector for translational cyclic AMI.
Definition at line 106 of file cyclicAMIPolyPatchI.H.
|
virtual |
Transform patch-based positions from nbr side to this side.
Implements coupledPolyPatch.
Definition at line 887 of file cyclicAMIPolyPatch.C.
References forAll, s, and Foam::transform().
|
virtual |
Transform a patch-based position from nbr side to this side.
Implements coupledPolyPatch.
Definition at line 923 of file cyclicAMIPolyPatch.C.
References s, Foam::T(), and Foam::transform().
|
virtual |
Transform a patch-based position from this side to nbr side.
Definition at line 961 of file cyclicAMIPolyPatch.C.
References s, Foam::T(), and Foam::transform().
|
virtual |
Transform a patch-based direction from this side to nbr side.
Definition at line 999 of file cyclicAMIPolyPatch.C.
References Foam::T(), and Foam::transform().
Referenced by particle< Type >::hitCyclicAMIPatch().
tmp<Field<Type> > interpolate | ( | const Field< Type > & | fld, |
const UList< Type > & | defaultValues = UList< Type >() |
||
) | const |
Interpolate field.
Referenced by FaceCellWave< Type, TrackingData >::handleAMICyclicPatches(), cyclicAMIFvPatch::interpolate(), and cyclicACMIPointPatchField< Type >::swapAddSeparated().
tmp<Field<Type> > interpolate | ( | const tmp< Field< Type >> & | tFld, |
const UList< Type > & | defaultValues = UList< Type >() |
||
) | const |
Interpolate tmp field.
void interpolate | ( | const UList< Type > & | fld, |
const CombineOp & | cop, | ||
List< Type > & | result, | ||
const UList< Type > & | defaultValues = UList<Type>() |
||
) | const |
Low-level interpolate List.
Definition at line 61 of file cyclicAMIPolyPatchTemplates.C.
References fld.
|
virtual |
Calculate the patch geometry.
Implements coupledPolyPatch.
Definition at line 1019 of file cyclicAMIPolyPatch.C.
|
virtual |
Initialize ordering for primitivePatch. Does not refer to *this (except for name() and type() etc.)
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 1032 of file cyclicAMIPolyPatch.C.
Referenced by cyclicACMIPolyPatch::initOrder().
|
virtual |
Return new ordering for primitivePatch.
Ordering is -faceMap: for every face index of the new face -rotation:for every new face the clockwise shift of the original face. Return false if nothing changes (faceMap is identity, rotation is 0), true otherwise.
Implements coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch.
Definition at line 1040 of file cyclicAMIPolyPatch.C.
References Foam::faceMap(), and List< T >::setSize().
Referenced by cyclicACMIPolyPatch::order().
Return face index on neighbour patch which shares point p following trajectory vector n
Definition at line 1058 of file cyclicAMIPolyPatch.C.
Referenced by particle< Type >::hitCyclicACMIPatch(), and particle< Type >::hitCyclicAMIPatch().
|
virtual |
Write the polyPatch data as a dictionary.
Reimplemented from coupledPolyPatch.
Reimplemented in cyclicACMIPolyPatch, and cyclicPeriodicAMIPolyPatch.
Definition at line 1104 of file cyclicAMIPolyPatch.C.
References Foam::radToDeg(), Foam::transform(), Ostream::write(), coupledPolyPatch::write(), and Ostream::writeEntry().
Referenced by cyclicPeriodicAMIPolyPatch::write(), and cyclicACMIPolyPatch::write().
Foam::tmp<Foam::Field<Type> > interpolate | ( | const Field< Type > & | fld, |
const UList< Type > & | defaultValues | ||
) | const |
Definition at line 32 of file cyclicAMIPolyPatchTemplates.C.
References fld.
Foam::tmp<Foam::Field<Type> > interpolate | ( | const tmp< Field< Type >> & | tFld, |
const UList< Type > & | defaultValues | ||
) | const |
Definition at line 50 of file cyclicAMIPolyPatchTemplates.C.
References Foam::fac::interpolate().
|
mutableprotected |
Name of other half.
Definition at line 91 of file cyclicAMIPolyPatch.H.
Referenced by cyclicPeriodicAMIPolyPatch::clone(), and cyclicAMIPolyPatch::clone().
|
protected |
Optional patchGroup to find neighbPatch.
Definition at line 94 of file cyclicAMIPolyPatch.H.
|
mutableprotected |
Index of other half.
Definition at line 97 of file cyclicAMIPolyPatch.H.
|
protected |
Axis of rotation for rotational cyclics.
Definition at line 105 of file cyclicAMIPolyPatch.H.
|
protected |
Point on axis of rotation for rotational cyclics.
Definition at line 108 of file cyclicAMIPolyPatch.H.
|
protected |
Flag to show whether the rotation angle is defined.
Definition at line 111 of file cyclicAMIPolyPatch.H.
|
protected |
Rotation angle.
Definition at line 114 of file cyclicAMIPolyPatch.H.
|
protected |
Translation vector.
Definition at line 120 of file cyclicAMIPolyPatch.H.
|
mutableprotected |
AMI interpolation class.
Definition at line 124 of file cyclicAMIPolyPatch.H.
|
protected |
Dictionary used during projection surface construction.
Definition at line 127 of file cyclicAMIPolyPatch.H.
|
mutableprotected |
Projection surface.
Definition at line 130 of file cyclicAMIPolyPatch.H.
|
mutableprotected |
Flag to indicate that new AMI faces will created.
Set by the call to changeTopology
Definition at line 137 of file cyclicAMIPolyPatch.H.
Referenced by cyclicAMIPolyPatch::restoreScaledGeometry().
|
protected |
Move face centres (default = no)
Definition at line 140 of file cyclicAMIPolyPatch.H.
Referenced by cyclicAMIPolyPatch::restoreScaledGeometry().
|
mutableprotected |
Definition at line 142 of file cyclicAMIPolyPatch.H.
|
protected |
Definition at line 144 of file cyclicAMIPolyPatch.H.
|
protected |
Definition at line 146 of file cyclicAMIPolyPatch.H.
|
mutableprotected |
Temporary storage for AMI face areas.
Definition at line 149 of file cyclicAMIPolyPatch.H.
Referenced by cyclicAMIPolyPatch::restoreScaledGeometry().
|
mutableprotected |
Temporary storage for AMI face centres.
Definition at line 152 of file cyclicAMIPolyPatch.H.
Referenced by cyclicAMIPolyPatch::restoreScaledGeometry().
|
static |
Tolerance used e.g. for area calculations/limits.
Definition at line 328 of file cyclicAMIPolyPatch.H.