44#ifndef laplacianMotionSolver_H
45#define laplacianMotionSolver_H
61class motionInterpolation;
145 virtual void solve();
IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionalit...
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Base class for fvMesh based motionSolvers.
Similar to velocityLaplacian but iteratively solves the mesh displacement PDEs to account for non-ort...
volVectorField cellMotionU_
virtual tmp< pointField > curPoints() const
Return point location obtained from the current motion field.
scalar tolerance_
Residual threshold.
label nIters_
Number of laplacian iterations per solution step.
void setBoundaryConditions()
Set boundary conditions of cellMotionU based on pointMotionU.
volVectorField & cellMotionU()
Get const and non-const references to cellMotionU.
autoPtr< motionInterpolation > interpolationPtr_
Interpolation used to transfer cell displacement to the points.
pointVectorField pointMotionU_
virtual void movePoints(const pointField &)
Update local data for geometry changes.
virtual void updateMesh(const mapPolyMesh &)
Update the mesh corresponding to given map.
virtual ~laplacianMotionSolver()=default
Destructor.
TypeName("laplacianMotionSolver")
Runtime type information.
virtual void solve()
Solve for motion.
pointVectorField & pointMotionU()
Get const and non-const references to pointMotionU.
Class containing mesh-to-mesh mapping information after a change in polyMesh topology.
Virtual base class for mesh motion solver.
const polyMesh & mesh() const
Return reference to mesh.
Mesh consisting of general polyhedral cells.
A class for managing temporary objects.
#define TypeName(TypeNameString)
Declare a ClassName() with extra virtual type info.