64 <<
"patch " << this->
patch().
index() <<
" not cyclicAMI type. "
65 <<
"Patch type = " << p.type()
74 const cyclicAMIPointPatchField<Type>& ptf,
76 const DimensionedField<Type, pointMesh>& iF,
77 const pointPatchFieldMapper& mapper
80 coupledPointPatchField<Type>(ptf,
p, iF, mapper),
81 cyclicAMIPatch_(
refCast<const cyclicAMIPointPatch>(
p)),
88 <<
"Field type does not correspond to patch type for patch "
91 <<
"Patch type: " << this->
patch().type()
100 const cyclicAMIPointPatchField<Type>& ptf,
101 const DimensionedField<Type, pointMesh>& iF
104 coupledPointPatchField<Type>(ptf, iF),
105 cyclicAMIPatch_(ptf.cyclicAMIPatch_),
116 return cyclicAMIPatch_.coupled();
127 if (cyclicAMIPatch_.cyclicAMIPatch().owner())
140 this->internalField()
146 fld.boundaryField()[nbrPatch.
index()]
150 Field<Type> ptFld(this->patchInternalField(pField));
151 Field<Type> nbrPtFld(nbr.patchInternalField(pField));
156 const tensor& forwardT = this->forwardT()[0];
157 const tensor& reverseT = this->reverseT()[0];
167 Field<Type> nbrFcFld(nbrPpi().pointToFaceInterpolate(nbrPtFld));
170 if (cyclicAMIPatch_.cyclicAMIPatch().applyLowWeightCorrection())
172 Field<Type> fcFld(ppi().pointToFaceInterpolate(ptFld));
175 cyclicAMIPatch_.cyclicAMIPatch().interpolate
184 cyclicAMIPatch_.cyclicAMIPatch().interpolate(nbrFcFld);
188 this->addToInternalField
191 ppi().faceToPointInterpolate(nbrFcFld)()
197 Field<Type> fcFld(ppi().pointToFaceInterpolate(ptFld));
200 if (cyclicAMIPatch_.cyclicAMIPatch().applyLowWeightCorrection())
202 Field<Type> nbrFcFld(nbrPpi().pointToFaceInterpolate(nbrPtFld));
205 cyclicAMIPatch_.cyclicAMIPatch().neighbPatch().interpolate
214 cyclicAMIPatch_.cyclicAMIPatch().neighbPatch().interpolate
221 nbr.addToInternalField
224 nbrPpi().faceToPointInterpolate(fcFld)()
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 AMI front and back plane patch field.
virtual bool doTransform() const
Does the patch field perform the transformation.
virtual void swapAddSeparated(const Pstream::commsTypes commsType, Field< Type > &) const
Complete swap of patch point values and add to local values.
cyclicAMIPointPatchField(const pointPatch &, const DimensionedField< Type, pointMesh > &)
Construct from patch and internal field.
virtual const tensorField & reverseT() const
Return neighbour-cell transformation tensor.
virtual bool coupled() const
Return true if coupled. Note that the underlying patch is not coupled() - the points don't align.
virtual const tensorField & forwardT() const
Return face transformation tensor.
Cyclic AMI point patch - place holder only.
const cyclicAMIPointPatch & 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.
#define FatalIOErrorInFunction(ios)
Report an error message using Foam::FatalIOError.
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
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")
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)