functionObjects::age: Added caching of the age field

to allow post-processing, e.g. sampling, cutting planes, averaging etc.
This commit is contained in:
Henry Weller
2019-10-10 16:16:24 +01:00
parent a2a74cbb79
commit e62ded842f
5 changed files with 64 additions and 25 deletions

View File

@ -124,26 +124,25 @@ bool Foam::functionObjects::age::read(const dictionary& dict)
bool Foam::functionObjects::age::execute()
{
return true;
}
bool Foam::functionObjects::age::write()
{
volScalarField age
tmp<volScalarField> tage
(
IOobject
new volScalarField
(
typeName,
mesh_.time().timeName(),
IOobject
(
typeName,
mesh_.time().timeName(),
mesh_,
IOobject::READ_IF_PRESENT,
IOobject::AUTO_WRITE,
false
),
mesh_,
IOobject::READ_IF_PRESENT,
IOobject::AUTO_WRITE
),
mesh_,
dimensionedScalar(dimTime, 0),
patchTypes()
dimensionedScalar(dimTime, 0),
patchTypes()
)
);
volScalarField& age = tage.ref();
const word divScheme("div(phi," + schemesField_ + ")");
@ -244,10 +243,16 @@ bool Foam::functionObjects::age::write()
Info<< "Min/max age:" << min(age).value()
<< ' ' << max(age).value() << endl;
age.write();
store(tage);
return true;
}
bool Foam::functionObjects::age::write()
{
return writeObject(typeName);
}
// ************************************************************************* //

View File

@ -56,8 +56,8 @@ Usage
type age;
libs ("libsolverFunctionObjects.so");
executeControl writeTime;
writeControl writeTime;
writeInterval 1;
schemesField k;
}