111 #ifndef functionObjects_forces_H 112 #define functionObjects_forces_H 124 namespace functionObjects
133 public fvMeshFunctionObject,
149 List<Field<vector>>
force_;
310 virtual bool write();
virtual vector momentEff() const
Return the total moment.
virtual void writeFileHeader(const label i)
Output file header information.
List< Field< vector > > moment_
Pressure, viscous and porous moment per bin.
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
labelHashSet patchSet_
Patches to integrate forces over.
const word & name() const
Return the name of this functionObject.
word UName_
Name of velocity field.
vector binDir_
Direction used to determine bin orientation.
A list of keyword definitions, which are a keyword followed by any number of values (e...
A 1D array of objects of type <T>, where the size of the vector is known and used for subscript bound...
coordinateSystem coordSys_
Coordinate system used when evaluating forces/moments.
virtual vector forceEff() const
Return the total force.
bool localSystem_
Flag to indicate whether we are using a local co-ordinate sys.
word pName_
Name of pressure field.
TypeName("forces")
Runtime type information.
word rhoName_
Name of density field (optional)
virtual bool read(const dictionary &)
Read the forces data.
Class to control time during OpenFOAM simulations that is also the top-level objectRegistry.
void writeBins()
Helper function to write bin data.
bool binCumulative_
Should bin data be cumulative?
HashSet< label, Hash< label > > labelHashSet
A HashSet with label keys.
virtual bool execute()
Execute, currently does nothing.
A class for handling words, derived from string.
tmp< volScalarField > mu() const
Dynamic viscosity field.
scalar rhoRef_
Reference density needed for incompressible calculations.
bool initialised_
Initialised flag.
List< point > binPoints_
Bin positions along binDir.
virtual void calcForcesMoment()
Calculate the forces and moments.
tmp< volScalarField > rho() const
Return rho if specified otherwise rhoRef.
void applyBins(const vectorField &Md, const vectorField &fN, const vectorField &fT, const vectorField &fP, const vectorField &d)
Accumulate bin data.
forces(const forces &)
Disallow default bitwise copy construct.
tmp< volSymmTensorField > devRhoReff() const
Return the effective viscous stress (laminar + turbulent).
void initialise()
Initialise the fields.
bool porosity_
Flag to include porosity effects.
scalar binMin_
Minimum bin bounds.
void writeForces()
Helper function to write force data.
scalar pRef_
Reference pressure.
void operator=(const forces &)
Disallow default bitwise assignment.
List< Field< vector > > force_
Pressure, viscous and porous force per bin.
scalar binDx_
Distance between bin divisions.
Switch directForceDensity_
Is the force density being supplied directly?
Calculates the forces and moments by integrating the pressure and skin-friction forces over a given l...
word fDName_
The name of the force density (fD) field.
A class for managing temporary objects.
Registry of regIOobjects.
virtual ~forces()
Destructor.
fileID
Enumeration for ensuring the right file is accessed.
label nBin_
Number of bins.
virtual bool write()
Write the forces.
wordList createFileNames(const dictionary &dict) const
Create file names for forces and bins.