Changed way of populating database for dsmcFieldCalc. Added correctBoundaryConditions() to sigmaTcRMax on initialisation

This commit is contained in:
graham
2009-03-10 14:25:15 +00:00
parent e49d70a85a
commit 542e05ce7f
2 changed files with 98 additions and 101 deletions

View File

@ -35,110 +35,106 @@ Description
#include "fvc.H" #include "fvc.H"
#include "dsmcCloud.H" #include "dsmcCloud.H"
#include "dsmcFields.H" #include "dsmcFields.H"
#include "IOobjectList.H"
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
namespace Foam
{
template<class Type>
bool addFieldsToList
(
const fvMesh& mesh,
PtrList<GeometricField<Type, fvPatchField, volMesh> >& list,
const wordList& fieldNames
)
{
typedef GeometricField<Type, fvPatchField, volMesh> fieldType;
label index = 0;
forAll(fieldNames, i)
{
IOobject obj
(
fieldNames[i],
mesh.time().timeName(),
mesh,
IOobject::MUST_READ
);
if (obj.headerOk() && obj.headerClassName() == fieldType::typeName)
{
list.set(index++, new fieldType(obj, mesh));
}
else
{
Info<< "Could not find " << fieldNames[i] << endl;
return false;
}
}
return true;
}
}
void Foam::calc(const argList& args, const Time& runTime, const fvMesh& mesh) void Foam::calc(const argList& args, const Time& runTime, const fvMesh& mesh)
{ {
bool writeResults = !args.options().found("noWrite"); bool writeResults = !args.options().found("noWrite");
IOobject rhoNMeanheader wordList extensiveVSFNames
( (
"rhoNMean", IStringStream
runTime.timeName(), (
mesh, "( \
IOobject::MUST_READ rhoNMean \
rhoMMean \
linearKEMean \
internalEMean \
iDofMean \
)"
)()
); );
IOobject rhoMMeanheader PtrList<volScalarField> extensiveVSFs(extensiveVSFNames.size());
if
( (
"rhoMMean", !addFieldsToList
runTime.timeName(),
mesh,
IOobject::MUST_READ
);
IOobject momentumMeanheader
( (
"momentumMean",
runTime.timeName(),
mesh, mesh,
IOobject::MUST_READ extensiveVSFs,
); extensiveVSFNames
)
)
{
return;
}
IOobject linearKEMeanheader wordList extensiveVVFNames(IStringStream ("(momentumMean)")());
PtrList<volVectorField> extensiveVVFs(extensiveVVFNames.size());
if
( (
"linearKEMean", !addFieldsToList
runTime.timeName(),
mesh,
IOobject::MUST_READ
);
IOobject internalEMeanheader
( (
"internalEMean",
runTime.timeName(),
mesh, mesh,
IOobject::MUST_READ extensiveVVFs,
); extensiveVVFNames
)
IOobject iDofMeanheader )
(
"iDofMean",
runTime.timeName(),
mesh,
IOobject::MUST_READ
);
if (!rhoNMeanheader.headerOk())
{ {
Info<< " No rhoNMean" << endl; return;
} }
else if (!rhoMMeanheader.headerOk())
{
Info<< " No rhoMMean" << endl;
}
else if (!momentumMeanheader.headerOk())
{
Info<< " No momentumMean" << endl;
}
else if (!linearKEMeanheader.headerOk())
{
Info<< " No linearKEMean" << endl;
}
else if (!internalEMeanheader.headerOk())
{
Info<< " No internalEMean" << endl;
}
else if (!iDofMeanheader.headerOk())
{
Info<< " No iDofMean" << endl;
}
else
{
Info<< "Reading field rhoNMean" << endl;
volScalarField rhoNMean(rhoNMeanheader, mesh);
Info<< "Reading field rhoMMean" << endl;
volScalarField rhoMMean(rhoMMeanheader, mesh);
Info<< "Reading field momentumMean" << endl;
volVectorField momentumMean(momentumMeanheader, mesh);
Info<< "Reading field linearKEMean" << endl;
volScalarField linearKEMean(linearKEMeanheader, mesh);
Info<< "Reading field internalEMean" << endl;
volScalarField internalEMean(internalEMeanheader, mesh);
Info<< "Reading field iDofMean" << endl;
volScalarField iDofMean(iDofMeanheader, mesh);
dsmcFields dF dsmcFields dF
( (
"dsmcFieldsUtility", "dsmcFieldsUtility",
mesh, mesh,
dictionary(), dictionary::null,
false false
); );
@ -146,7 +142,6 @@ void Foam::calc(const argList& args, const Time& runTime, const fvMesh& mesh)
{ {
dF.write(); dF.write();
} }
}
} }
// ************************************************************************* // // ************************************************************************* //

View File

@ -214,6 +214,8 @@ void Foam::DsmcCloud<ParcelType>::initialise
temperature, temperature,
cP.mass() cP.mass()
); );
sigmaTcRMax_.correctBoundaryConditions();
} }