60 <<
"patch " << this->
patch().
index() <<
" not cyclic type. "
61 <<
"Patch type = " << p.type()
70 const cyclicPointPatchField<Type>& ptf,
72 const DimensionedField<Type, pointMesh>& iF,
73 const pointPatchFieldMapper& mapper
76 coupledPointPatchField<Type>(ptf,
p, iF, mapper),
77 cyclicPatch_(
refCast<const cyclicPointPatch>(
p))
82 <<
"Field type does not correspond to patch type for patch "
85 <<
"Patch type: " << this->
patch().type()
94 const cyclicPointPatchField<Type>& ptf,
95 const DimensionedField<Type, pointMesh>& iF
98 coupledPointPatchField<Type>(ptf, iF),
99 cyclicPatch_(ptf.cyclicPatch_)
115 if (cyclicPatch_.cyclicPatch().owner())
125 this->internalField()
131 fld.boundaryField()[nbrPatch.
index()]
138 const edgeList& pairs = cyclicPatch_.transformPairs();
145 label pointi = pairs[pairi][0];
146 label nbrPointi = pairs[pairi][1];
148 Type
tmp = pf[pointi];
149 pf[pointi] =
transform(forwardT()[0], nbrPf[nbrPointi]);
157 Foam::Swap(pf[pairs[pairi][0]], nbrPf[pairs[pairi][1]]);
160 this->addToInternalField(pField, pf);
161 nbr.addToInternalField(pField, nbrPf);
Info<< nl;Info<< "Write faMesh in vtk format:"<< nl;{ vtk::uindirectPatchWriter writer(aMesh.patch(), fileName(aMesh.time().globalPath()/vtkBaseFileName));writer.writeGeometry();globalIndex procAddr(aMesh.nFaces());labelList cellIDs;if(UPstream::master()) { cellIDs.resize(procAddr.totalSize());for(const labelRange &range :procAddr.ranges()) { auto slice=cellIDs.slice(range);slice=identity(range);} } writer.beginCellData(4);writer.writeProcIDs();writer.write("cellID", cellIDs);writer.write("area", aMesh.S().field());writer.write("normal", aMesh.faceAreaNormals());writer.beginPointData(1);writer.write("normal", aMesh.pointAreaNormals());Info<< " "<< writer.output().name()<< nl;}{ vtk::lineWriter writer(aMesh.points(), aMesh.edges(), fileName(aMesh.time().globalPath()/(vtkBaseFileName+"-edges")));writer.writeGeometry();writer.beginCellData(4);writer.writeProcIDs();{ Field< scalar > fld(faMeshTools::flattenEdgeField(aMesh.magLe(), true))
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
Generic templated field type that is much like a Foam::List except that it is expected to hold numeri...
Generic GeometricField class.
commsTypes
Communications types.
A Coupled boundary condition for pointField.
coupledPointPatchField(const pointPatch &, const DimensionedField< Type, pointMesh > &)
Construct from patch and internal field.
Cyclic front and back plane patch field.
virtual bool doTransform() const
Does the patch field perform the transformation.
cyclicPointPatchField(const pointPatch &, const DimensionedField< Type, pointMesh > &)
Construct from patch and internal field.
virtual void swapAddSeparated(const Pstream::commsTypes commsType, Field< Type > &) const
Complete swap of patch point values and add to local values.
virtual const tensorField & reverseT() const
Return neighbour-cell transformation tensor.
virtual const tensorField & forwardT() const
Return face transformation tensor.
Cyclic patch for post-processing.
const cyclicPointPatch & neighbPatch() const
Return neighbour point patch.
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
virtual label index() const
Return the index of this patch in the pointBoundaryMesh.
label index() const noexcept
The index of this patch in the boundaryMesh.
const pointPatch & patch() const noexcept
Return the patch.
Foam::pointPatchFieldMapper.
void patchInternalField(const UList< Type1 > &internalData, const labelUList &addressing, UList< Type1 > &pfld) const
Extract field using specified addressing.
void addToInternalField(Field< Type1 > &iF, const Field< Type1 > &pF) const
Given the internal field and a patch field, add the patch field to the internal field.
const DimensionedField< Type, pointMesh > & internalField() const noexcept
Return const-reference to the dimensioned internal field.
Basic pointPatch represents a set of points from the mesh.
A class for managing temporary objects.
#define FatalIOErrorInFunction(ios)
Report an error message using Foam::FatalIOError.
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
List< edge > edgeList
List of edge.
Type & refCast(U &obj)
A dynamic_cast (for references) to Type reference.
refinementData transform(const tensor &, const refinementData val)
No-op rotational transform for base types.
const word GlobalIOList< Tuple2< scalar, vector > >::typeName("scalarVectorTable")
void Swap(DynamicList< T, SizeMinA > &a, DynamicList< T, SizeMinB > &b)
Exchange contents of lists - see DynamicList::swap().
Ostream & endl(Ostream &os)
Add newline and flush stream.
IOerror FatalIOError
Error stream (stdout output on all processes), with additional 'FOAM FATAL IO ERROR' header text and ...
bool isType(const U &obj)
Check if typeid of the object and Type are identical.
error FatalError
Error stream (stdout output on all processes), with additional 'FOAM FATAL ERROR' header text and sta...
errorManipArg< error, int > exit(error &err, const int errNo=1)
#define forAll(list, i)
Loop across all elements in list.