diff --git a/src/sampling/sampledSurface/distanceSurface/distanceSurface.C b/src/sampling/sampledSurface/distanceSurface/distanceSurface.C index 450384506a..3a6562b897 100644 --- a/src/sampling/sampledSurface/distanceSurface/distanceSurface.C +++ b/src/sampling/sampledSurface/distanceSurface/distanceSurface.C @@ -50,6 +50,9 @@ void Foam::distanceSurface::createGeometry() // Clear any stored topologies facesPtr_.clear(); + // Clear derived data + clearGeom(); + const fvMesh& fvm = static_cast(mesh()); // Distance to cell centres @@ -361,6 +364,9 @@ bool Foam::distanceSurface::expire() // Clear any stored topologies facesPtr_.clear(); + // Clear derived data + clearGeom(); + // already marked as expired if (needsUpdate_) { diff --git a/src/sampling/sampledSurface/isoSurface/sampledIsoSurface.C b/src/sampling/sampledSurface/isoSurface/sampledIsoSurface.C index b70461cef3..46d6f108cc 100644 --- a/src/sampling/sampledSurface/isoSurface/sampledIsoSurface.C +++ b/src/sampling/sampledSurface/isoSurface/sampledIsoSurface.C @@ -333,6 +333,9 @@ bool Foam::sampledIsoSurface::updateGeometry() const surfPtr_.clear(); facesPtr_.clear(); + // Clear derived data + clearGeom(); + if (subMeshPtr_.valid()) { surfPtr_.reset @@ -471,6 +474,9 @@ bool Foam::sampledIsoSurface::expire() facesPtr_.clear(); subMeshPtr_.clear(); + // Clear derived data + clearGeom(); + // already marked as expired if (prevTimeIndex_ == -1) { diff --git a/src/sampling/sampledSurface/isoSurface/sampledIsoSurfaceCell.C b/src/sampling/sampledSurface/isoSurface/sampledIsoSurfaceCell.C index 155e12bbd2..7d1b138f5e 100644 --- a/src/sampling/sampledSurface/isoSurface/sampledIsoSurfaceCell.C +++ b/src/sampling/sampledSurface/isoSurface/sampledIsoSurfaceCell.C @@ -62,6 +62,9 @@ bool Foam::sampledIsoSurfaceCell::updateGeometry() const // Clear any stored topo facesPtr_.clear(); + // Clear derived data + sampledSurface::clearGeom(); + // Optionally read volScalarField autoPtr readFieldPtr_; @@ -240,6 +243,9 @@ bool Foam::sampledIsoSurfaceCell::expire() { facesPtr_.clear(); + // Clear derived data + sampledSurface::clearGeom(); + // already marked as expired if (prevTimeIndex_ == -1) { diff --git a/src/sampling/sampledSurface/sampledCuttingPlane/sampledCuttingPlane.C b/src/sampling/sampledSurface/sampledCuttingPlane/sampledCuttingPlane.C index bfbb5293f7..3c88d38d6f 100644 --- a/src/sampling/sampledSurface/sampledCuttingPlane/sampledCuttingPlane.C +++ b/src/sampling/sampledSurface/sampledCuttingPlane/sampledCuttingPlane.C @@ -60,6 +60,8 @@ void Foam::sampledCuttingPlane::createGeometry() pointDistance_.clear(); cellDistancePtr_.clear(); + // Clear derived data + clearGeom(); // Get any subMesh if (zoneID_.index() != -1 && !subMeshPtr_.valid()) @@ -321,6 +323,9 @@ bool Foam::sampledCuttingPlane::expire() // Clear any stored topologies facesPtr_.clear(); + // Clear derived data + clearGeom(); + // already marked as expired if (needsUpdate_) { diff --git a/src/sampling/sampledSurface/thresholdCellFaces/sampledThresholdCellFaces.C b/src/sampling/sampledSurface/thresholdCellFaces/sampledThresholdCellFaces.C index 0d9e1312ab..c8a3291ede 100644 --- a/src/sampling/sampledSurface/thresholdCellFaces/sampledThresholdCellFaces.C +++ b/src/sampling/sampledSurface/thresholdCellFaces/sampledThresholdCellFaces.C @@ -124,6 +124,8 @@ bool Foam::sampledThresholdCellFaces::updateGeometry() const ).MeshedSurface::transfer(surf); meshCells_.transfer(surf.meshCells()); + // clear derived data + sampledSurface::clearGeom(); if (debug) {