mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
Merge branch 'master' of /home/dm4/OpenFOAM/OpenFOAM-dev
This commit is contained in:
@ -255,6 +255,8 @@ addLayersControls
|
|||||||
relativeSizes true;
|
relativeSizes true;
|
||||||
|
|
||||||
// Per final patch (so not geometry!) the layer information
|
// Per final patch (so not geometry!) the layer information
|
||||||
|
// Note: This behaviour changed after 21x. Any non-mentioned patches
|
||||||
|
// now slide unless nSurfaceLayers is explicitly mentioned to be 0.
|
||||||
layers
|
layers
|
||||||
{
|
{
|
||||||
sphere.stl_firstSolid
|
sphere.stl_firstSolid
|
||||||
@ -265,6 +267,17 @@ addLayersControls
|
|||||||
maxY
|
maxY
|
||||||
{
|
{
|
||||||
nSurfaceLayers 1;
|
nSurfaceLayers 1;
|
||||||
|
// Per patch layer data
|
||||||
|
expansionRatio 1.3;
|
||||||
|
finalLayerThickness 0.3;
|
||||||
|
minThickness 0.1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disable any mesh shrinking and layer addition on any point of
|
||||||
|
// a patch by setting nSurfaceLayers to 0
|
||||||
|
frozenPatches
|
||||||
|
{
|
||||||
|
nSurfaceLayers 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -281,6 +294,7 @@ addLayersControls
|
|||||||
|
|
||||||
//- Minimum thickness of cell layer. If for any reason layer
|
//- Minimum thickness of cell layer. If for any reason layer
|
||||||
// cannot be above minThickness do not add layer.
|
// cannot be above minThickness do not add layer.
|
||||||
|
// Relative to undistorted size of cell outside layer.
|
||||||
// See relativeSizes parameter.
|
// See relativeSizes parameter.
|
||||||
minThickness 0.25;
|
minThickness 0.25;
|
||||||
|
|
||||||
@ -417,7 +431,7 @@ meshQualityControls
|
|||||||
// Flags for optional output
|
// Flags for optional output
|
||||||
// 0 : only write final meshes
|
// 0 : only write final meshes
|
||||||
// 1 : write intermediate meshes
|
// 1 : write intermediate meshes
|
||||||
// 2 : write volScalarFields with cellLevel and cell centres for postprocessing
|
// 2 : write volScalarField with cellLevel for postprocessing
|
||||||
// 4 : write current intersections as .obj files
|
// 4 : write current intersections as .obj files
|
||||||
debug 0;
|
debug 0;
|
||||||
|
|
||||||
|
|||||||
@ -38,7 +38,11 @@ Description
|
|||||||
myPatch
|
myPatch
|
||||||
{
|
{
|
||||||
type codedMixed;
|
type codedMixed;
|
||||||
value uniform 0;
|
|
||||||
|
refValue uniform (0 0 0);
|
||||||
|
refGradient uniform (0 0 0);
|
||||||
|
valueFraction uniform 1;
|
||||||
|
|
||||||
redirectType rampedMixed; // name of generated BC
|
redirectType rampedMixed; // name of generated BC
|
||||||
|
|
||||||
code
|
code
|
||||||
|
|||||||
@ -5,6 +5,7 @@ EXE_INC = \
|
|||||||
-I$(LIB_SRC)/lagrangian/basic/lnInclude \
|
-I$(LIB_SRC)/lagrangian/basic/lnInclude \
|
||||||
-I$(LIB_SRC)/meshTools/lnInclude \
|
-I$(LIB_SRC)/meshTools/lnInclude \
|
||||||
-I$(LIB_SRC)/edgeMesh/lnInclude \
|
-I$(LIB_SRC)/edgeMesh/lnInclude \
|
||||||
|
-I$(LIB_SRC)/surfMesh/lnInclude \
|
||||||
-I$(LIB_SRC)/triSurface/lnInclude
|
-I$(LIB_SRC)/triSurface/lnInclude
|
||||||
|
|
||||||
LIB_LIBS = \
|
LIB_LIBS = \
|
||||||
@ -13,5 +14,6 @@ LIB_LIBS = \
|
|||||||
-llagrangian \
|
-llagrangian \
|
||||||
-lmeshTools \
|
-lmeshTools \
|
||||||
-ledgeMesh \
|
-ledgeMesh \
|
||||||
|
-lsurfMesh \
|
||||||
-ltriSurface \
|
-ltriSurface \
|
||||||
-ldistributed
|
-ldistributed
|
||||||
|
|||||||
@ -26,6 +26,7 @@ $(surfaceFormats)/ftr/FTRsurfaceFormatRunTime.C
|
|||||||
$(surfaceFormats)/gts/GTSsurfaceFormatRunTime.C
|
$(surfaceFormats)/gts/GTSsurfaceFormatRunTime.C
|
||||||
$(surfaceFormats)/nas/NASsurfaceFormatRunTime.C
|
$(surfaceFormats)/nas/NASsurfaceFormatRunTime.C
|
||||||
$(surfaceFormats)/obj/OBJsurfaceFormatRunTime.C
|
$(surfaceFormats)/obj/OBJsurfaceFormatRunTime.C
|
||||||
|
$(surfaceFormats)/obj/OBJstream.C
|
||||||
$(surfaceFormats)/off/OFFsurfaceFormatRunTime.C
|
$(surfaceFormats)/off/OFFsurfaceFormatRunTime.C
|
||||||
$(surfaceFormats)/ofs/OFSsurfaceFormatCore.C
|
$(surfaceFormats)/ofs/OFSsurfaceFormatCore.C
|
||||||
$(surfaceFormats)/ofs/OFSsurfaceFormatRunTime.C
|
$(surfaceFormats)/ofs/OFSsurfaceFormatRunTime.C
|
||||||
|
|||||||
323
src/surfMesh/surfaceFormats/obj/OBJstream.C
Normal file
323
src/surfMesh/surfaceFormats/obj/OBJstream.C
Normal file
@ -0,0 +1,323 @@
|
|||||||
|
/*---------------------------------------------------------------------------*\
|
||||||
|
========= |
|
||||||
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
|
\\ / O peration |
|
||||||
|
\\ / A nd | Copyright (C) 2012 OpenFOAM Foundation
|
||||||
|
\\/ M anipulation |
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
License
|
||||||
|
This file is part of OpenFOAM.
|
||||||
|
|
||||||
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
#include "OBJstream.H"
|
||||||
|
//#include "token.H"
|
||||||
|
#include "primitivePatch.H"
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
defineTypeNameAndDebug(Foam::OBJstream, 0);
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
|
||||||
|
|
||||||
|
void Foam::OBJstream::writeAndCheck(const char c)
|
||||||
|
{
|
||||||
|
if (c == '\n')
|
||||||
|
{
|
||||||
|
startOfLine_ = true;
|
||||||
|
}
|
||||||
|
else if (startOfLine_)
|
||||||
|
{
|
||||||
|
startOfLine_ = false;
|
||||||
|
if (c == 'v')
|
||||||
|
{
|
||||||
|
nVertices_++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
OFstream::write(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
Foam::OBJstream::OBJstream
|
||||||
|
(
|
||||||
|
const fileName& pathname,
|
||||||
|
streamFormat format,
|
||||||
|
versionNumber version,
|
||||||
|
compressionType compression
|
||||||
|
)
|
||||||
|
:
|
||||||
|
OFstream(pathname, format, version, compression),
|
||||||
|
startOfLine_(true),
|
||||||
|
nVertices_(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
Foam::OBJstream::~OBJstream()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const char c)
|
||||||
|
{
|
||||||
|
writeAndCheck(c);
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const char* str)
|
||||||
|
{
|
||||||
|
for (const char* p = str; *p != '\0'; ++p)
|
||||||
|
{
|
||||||
|
writeAndCheck(*p);
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const word& str)
|
||||||
|
{
|
||||||
|
write(str.c_str());
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const string& str)
|
||||||
|
{
|
||||||
|
OFstream::write(token::BEGIN_STRING);
|
||||||
|
|
||||||
|
register int backslash = 0;
|
||||||
|
for (string::const_iterator iter = str.begin(); iter != str.end(); ++iter)
|
||||||
|
{
|
||||||
|
register char c = *iter;
|
||||||
|
|
||||||
|
if (c == '\\')
|
||||||
|
{
|
||||||
|
backslash++;
|
||||||
|
// suppress output until we know if other characters follow
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else if (c == token::NL)
|
||||||
|
{
|
||||||
|
lineNumber_++;
|
||||||
|
backslash++; // backslash escape for newline
|
||||||
|
}
|
||||||
|
else if (c == token::END_STRING)
|
||||||
|
{
|
||||||
|
backslash++; // backslash escape for quote
|
||||||
|
}
|
||||||
|
|
||||||
|
// output pending backslashes
|
||||||
|
while (backslash)
|
||||||
|
{
|
||||||
|
OFstream::write('\\');
|
||||||
|
backslash--;
|
||||||
|
}
|
||||||
|
|
||||||
|
writeAndCheck(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
// silently drop any trailing backslashes
|
||||||
|
// they would otherwise appear like an escaped end-quote
|
||||||
|
|
||||||
|
OFstream::write(token::END_STRING);
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::writeQuoted
|
||||||
|
(
|
||||||
|
const std::string& str,
|
||||||
|
const bool quoted
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (quoted)
|
||||||
|
{
|
||||||
|
OFstream::write(token::BEGIN_STRING);
|
||||||
|
|
||||||
|
register int backslash = 0;
|
||||||
|
for
|
||||||
|
(
|
||||||
|
string::const_iterator iter = str.begin();
|
||||||
|
iter != str.end();
|
||||||
|
++iter
|
||||||
|
)
|
||||||
|
{
|
||||||
|
register char c = *iter;
|
||||||
|
|
||||||
|
if (c == '\\')
|
||||||
|
{
|
||||||
|
backslash++;
|
||||||
|
// suppress output until we know if other characters follow
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else if (c == token::NL)
|
||||||
|
{
|
||||||
|
lineNumber_++;
|
||||||
|
backslash++; // backslash escape for newline
|
||||||
|
}
|
||||||
|
else if (c == token::END_STRING)
|
||||||
|
{
|
||||||
|
backslash++; // backslash escape for quote
|
||||||
|
}
|
||||||
|
|
||||||
|
// output pending backslashes
|
||||||
|
while (backslash)
|
||||||
|
{
|
||||||
|
OFstream::write('\\');
|
||||||
|
backslash--;
|
||||||
|
}
|
||||||
|
|
||||||
|
writeAndCheck(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
// silently drop any trailing backslashes
|
||||||
|
// they would otherwise appear like an escaped end-quote
|
||||||
|
OFstream::write(token::END_STRING);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// output unquoted string, only advance line number on newline
|
||||||
|
write(str.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const point& pt)
|
||||||
|
{
|
||||||
|
write("v ") << pt.x() << ' ' << pt.y() << ' ' << pt.z()
|
||||||
|
<< nl;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const point& pt, const vector& n)
|
||||||
|
{
|
||||||
|
write(pt);
|
||||||
|
OFstream::write("vn ") << n.x() << ' ' << n.y()
|
||||||
|
<< ' ' << n.z() << nl;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const edge& e, const pointField& points)
|
||||||
|
{
|
||||||
|
write(points[e[0]]);
|
||||||
|
write(points[e[1]]);
|
||||||
|
write("l ") << nVertices_-1 << ' ' << nVertices_ << nl;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write(const linePointRef& ln)
|
||||||
|
{
|
||||||
|
write(ln.start());
|
||||||
|
write(ln.end());
|
||||||
|
write("l ") << nVertices_-1 << ' ' << nVertices_ << nl;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write
|
||||||
|
(
|
||||||
|
const face& f,
|
||||||
|
const pointField& points,
|
||||||
|
const bool lines
|
||||||
|
)
|
||||||
|
{
|
||||||
|
label start = nVertices_;
|
||||||
|
forAll(f, i)
|
||||||
|
{
|
||||||
|
write(points[f[i]]);
|
||||||
|
}
|
||||||
|
if (lines)
|
||||||
|
{
|
||||||
|
write('l');
|
||||||
|
forAll(f, i)
|
||||||
|
{
|
||||||
|
write(' ') << start+1+i;
|
||||||
|
}
|
||||||
|
write(' ') << start+1 << '\n';
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
write('f');
|
||||||
|
forAll(f, i)
|
||||||
|
{
|
||||||
|
write(' ') << start+1+i;
|
||||||
|
}
|
||||||
|
write('\n');
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Foam::Ostream& Foam::OBJstream::write
|
||||||
|
(
|
||||||
|
const faceList& fcs,
|
||||||
|
const pointField& points,
|
||||||
|
const bool lines
|
||||||
|
)
|
||||||
|
{
|
||||||
|
SubList<face> allFcs(fcs, fcs.size());
|
||||||
|
|
||||||
|
primitivePatch pp(allFcs, points);
|
||||||
|
|
||||||
|
const pointField& localPoints = pp.localPoints();
|
||||||
|
const faceList& localFaces = pp.localFaces();
|
||||||
|
|
||||||
|
label start = nVertices_;
|
||||||
|
|
||||||
|
forAll(localPoints, i)
|
||||||
|
{
|
||||||
|
write(localPoints[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (lines)
|
||||||
|
{
|
||||||
|
const edgeList& edges = pp.edges();
|
||||||
|
forAll(edges, edgeI)
|
||||||
|
{
|
||||||
|
const edge& e = edges[edgeI];
|
||||||
|
|
||||||
|
write("l ") << start+e[0]+1 << ' ' << start+e[1]+1 << nl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
forAll(localFaces, faceI)
|
||||||
|
{
|
||||||
|
const face& f = localFaces[faceI];
|
||||||
|
write('f');
|
||||||
|
forAll(f, i)
|
||||||
|
{
|
||||||
|
write(' ') << start+f[i]+1;
|
||||||
|
}
|
||||||
|
write('\n');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ************************************************************************* //
|
||||||
164
src/surfMesh/surfaceFormats/obj/OBJstream.H
Normal file
164
src/surfMesh/surfaceFormats/obj/OBJstream.H
Normal file
@ -0,0 +1,164 @@
|
|||||||
|
/*---------------------------------------------------------------------------*\
|
||||||
|
========= |
|
||||||
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
|
\\ / O peration |
|
||||||
|
\\ / A nd | Copyright (C) 2012 OpenFOAM Foundation
|
||||||
|
\\/ M anipulation |
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
License
|
||||||
|
This file is part of OpenFOAM.
|
||||||
|
|
||||||
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Class
|
||||||
|
Foam::OBJstream
|
||||||
|
|
||||||
|
Description
|
||||||
|
OFstream which keeps track of vertices
|
||||||
|
|
||||||
|
SourceFiles
|
||||||
|
OBJstream.C
|
||||||
|
|
||||||
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
#ifndef OBJstream_H
|
||||||
|
#define OBJstream_H
|
||||||
|
|
||||||
|
#include "OFstream.H"
|
||||||
|
#include "point.H"
|
||||||
|
#include "edge.H"
|
||||||
|
#include "face.H"
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
namespace Foam
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*\
|
||||||
|
Class OBJstream Declaration
|
||||||
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
class OBJstream
|
||||||
|
:
|
||||||
|
public OFstream
|
||||||
|
{
|
||||||
|
// Private data
|
||||||
|
|
||||||
|
bool startOfLine_;
|
||||||
|
|
||||||
|
label nVertices_;
|
||||||
|
|
||||||
|
|
||||||
|
// Private Member Functions
|
||||||
|
|
||||||
|
void writeAndCheck(const char);
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
// Declare name of the class and its debug switch
|
||||||
|
ClassName("OBJstream");
|
||||||
|
|
||||||
|
|
||||||
|
// Constructors
|
||||||
|
|
||||||
|
//- Construct from pathname
|
||||||
|
OBJstream
|
||||||
|
(
|
||||||
|
const fileName& pathname,
|
||||||
|
streamFormat format=ASCII,
|
||||||
|
versionNumber version=currentVersion,
|
||||||
|
compressionType compression=UNCOMPRESSED
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
//- Destructor
|
||||||
|
~OBJstream();
|
||||||
|
|
||||||
|
|
||||||
|
// Member functions
|
||||||
|
|
||||||
|
// Access
|
||||||
|
|
||||||
|
//- Return the name of the stream
|
||||||
|
label nVertices() const
|
||||||
|
{
|
||||||
|
return nVertices_;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Ostream implementation
|
||||||
|
|
||||||
|
//- Write character
|
||||||
|
virtual Ostream& write(const char);
|
||||||
|
|
||||||
|
//- Write character string
|
||||||
|
virtual Ostream& write(const char*);
|
||||||
|
|
||||||
|
//- Write word
|
||||||
|
virtual Ostream& write(const word&);
|
||||||
|
|
||||||
|
virtual Ostream& write(const string&);
|
||||||
|
|
||||||
|
//- Write std::string surrounded by quotes.
|
||||||
|
// Optional write without quotes.
|
||||||
|
virtual Ostream& writeQuoted
|
||||||
|
(
|
||||||
|
const std::string&,
|
||||||
|
const bool quoted=true
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
// Direct write functionality
|
||||||
|
|
||||||
|
//- Write point
|
||||||
|
Ostream& write(const point&);
|
||||||
|
|
||||||
|
//- Write point and vector normal ('vn')
|
||||||
|
Ostream& write(const point&, const vector&);
|
||||||
|
|
||||||
|
//- Write edge as points with line
|
||||||
|
Ostream& write(const edge&, const pointField&);
|
||||||
|
|
||||||
|
//- Write line
|
||||||
|
Ostream& write(const linePointRef&);
|
||||||
|
|
||||||
|
//- Write face as points with lines or filled polygon
|
||||||
|
Ostream& write
|
||||||
|
(
|
||||||
|
const face&,
|
||||||
|
const pointField&,
|
||||||
|
const bool lines = true
|
||||||
|
);
|
||||||
|
|
||||||
|
//- Write patch as points and faces with lines or filled polygons
|
||||||
|
Ostream& write
|
||||||
|
(
|
||||||
|
const faceList&,
|
||||||
|
const pointField&,
|
||||||
|
const bool lines = true
|
||||||
|
);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
} // End namespace Foam
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// ************************************************************************* //
|
||||||
@ -156,12 +156,14 @@ Foam::basicThermo::basicThermo
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::autoPtr<Foam::basicThermo> Foam::basicThermo::New
|
Foam::autoPtr<Foam::basicThermo> Foam::basicThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh
|
const fvMesh& mesh
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return NewThermo<basicThermo>(mesh);
|
return New<basicThermo>(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -29,7 +29,6 @@ Description
|
|||||||
|
|
||||||
SourceFiles
|
SourceFiles
|
||||||
basicThermo.C
|
basicThermo.C
|
||||||
basicThermoNew.C
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
@ -104,8 +103,14 @@ public:
|
|||||||
basicThermo(const fvMesh&, const dictionary&);
|
basicThermo(const fvMesh&, const dictionary&);
|
||||||
|
|
||||||
|
|
||||||
//- Selector
|
// Selectors
|
||||||
static autoPtr<basicThermo> New(const fvMesh&);
|
|
||||||
|
//- Generic New for each of the related thermodynamics packages
|
||||||
|
template<class Thermo>
|
||||||
|
static autoPtr<Thermo> New(const fvMesh&);
|
||||||
|
|
||||||
|
//- Specialisation of the Generic New for basicThermo
|
||||||
|
static autoPtr<basicThermo> New(const fvMesh&);
|
||||||
|
|
||||||
|
|
||||||
//- Destructor
|
//- Destructor
|
||||||
@ -344,132 +349,18 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
template<class Thermo>
|
|
||||||
autoPtr<Thermo> NewThermo
|
|
||||||
(
|
|
||||||
const fvMesh& mesh
|
|
||||||
)
|
|
||||||
{
|
|
||||||
IOdictionary thermoDict
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"thermophysicalProperties",
|
|
||||||
mesh.time().constant(),
|
|
||||||
mesh,
|
|
||||||
IOobject::MUST_READ_IF_MODIFIED,
|
|
||||||
IOobject::NO_WRITE,
|
|
||||||
false
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
word thermoTypeName;
|
|
||||||
|
|
||||||
if (thermoDict.isDict("thermoType"))
|
|
||||||
{
|
|
||||||
const dictionary& thermoTypeDict(thermoDict.subDict("thermoType"));
|
|
||||||
|
|
||||||
Info<< "Selecting thermodynamics package " << thermoTypeDict << endl;
|
|
||||||
|
|
||||||
const int nCmpt = 7;
|
|
||||||
const char* cmptNames[nCmpt] =
|
|
||||||
{
|
|
||||||
"type",
|
|
||||||
"mixture",
|
|
||||||
"transport",
|
|
||||||
"thermo",
|
|
||||||
"equationOfState",
|
|
||||||
"specie",
|
|
||||||
"energy"
|
|
||||||
};
|
|
||||||
|
|
||||||
// Construct the name of the thermo package from the components
|
|
||||||
thermoTypeName =
|
|
||||||
word(thermoTypeDict.lookup("type")) + '<'
|
|
||||||
+ word(thermoTypeDict.lookup("mixture")) + '<'
|
|
||||||
+ word(thermoTypeDict.lookup("transport")) + '<'
|
|
||||||
+ word(thermoTypeDict.lookup("thermo")) + '<'
|
|
||||||
+ word(thermoTypeDict.lookup("equationOfState")) + '<'
|
|
||||||
+ word(thermoTypeDict.lookup("specie")) + ">>,"
|
|
||||||
+ word(thermoTypeDict.lookup("energy")) + ">>>";
|
|
||||||
|
|
||||||
// Lookup the thermo package
|
|
||||||
typename Thermo::fvMeshConstructorTable::iterator cstrIter =
|
|
||||||
Thermo::fvMeshConstructorTablePtr_->find(thermoTypeName);
|
|
||||||
|
|
||||||
// Print error message if package not found in the table
|
|
||||||
if (cstrIter == Thermo::fvMeshConstructorTablePtr_->end())
|
|
||||||
{
|
|
||||||
FatalErrorIn(Thermo::typeName + "::New(const fvMesh&)")
|
|
||||||
<< "Unknown " << Thermo::typeName << " type " << nl
|
|
||||||
<< "thermoType" << thermoTypeDict << nl << nl
|
|
||||||
<< "Valid " << Thermo::typeName << " types are:" << nl << nl;
|
|
||||||
|
|
||||||
// Get the list of all the suitable thermo packages available
|
|
||||||
wordList validThermoTypeNames
|
|
||||||
(
|
|
||||||
Thermo::fvMeshConstructorTablePtr_->sortedToc()
|
|
||||||
);
|
|
||||||
|
|
||||||
// Build a table of the thermo packages constituent parts
|
|
||||||
// Note: row-0 contains the names of constituent parts
|
|
||||||
List<wordList> validThermoTypeNameCmpts
|
|
||||||
(
|
|
||||||
validThermoTypeNames.size() + 1
|
|
||||||
);
|
|
||||||
|
|
||||||
validThermoTypeNameCmpts[0].setSize(nCmpt);
|
|
||||||
forAll(validThermoTypeNameCmpts[0], j)
|
|
||||||
{
|
|
||||||
validThermoTypeNameCmpts[0][j] = cmptNames[j];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Split the thermo package names into their constituent parts
|
|
||||||
forAll(validThermoTypeNames, i)
|
|
||||||
{
|
|
||||||
validThermoTypeNameCmpts[i+1] =
|
|
||||||
Thermo::splitThermoName(validThermoTypeNames[i], nCmpt);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Print the table of available packages
|
|
||||||
// in terms of their constituent parts
|
|
||||||
printTable(validThermoTypeNameCmpts, FatalError);
|
|
||||||
|
|
||||||
FatalError<< exit(FatalError);
|
|
||||||
}
|
|
||||||
|
|
||||||
return autoPtr<Thermo>(cstrIter()(mesh));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
thermoTypeName = word(thermoDict.lookup("thermoType"));
|
|
||||||
|
|
||||||
Info<< "Selecting thermodynamics package " << thermoTypeName << endl;
|
|
||||||
|
|
||||||
typename Thermo::fvMeshConstructorTable::iterator cstrIter =
|
|
||||||
Thermo::fvMeshConstructorTablePtr_->find(thermoTypeName);
|
|
||||||
|
|
||||||
if (cstrIter == Thermo::fvMeshConstructorTablePtr_->end())
|
|
||||||
{
|
|
||||||
FatalErrorIn(Thermo::typeName + "::New(const fvMesh&)")
|
|
||||||
<< "Unknown " << Thermo::typeName << " type "
|
|
||||||
<< thermoTypeName << nl << nl
|
|
||||||
<< "Valid " << Thermo::typeName << " types are:" << nl
|
|
||||||
<< Thermo::fvMeshConstructorTablePtr_->sortedToc() << nl
|
|
||||||
<< exit(FatalError);
|
|
||||||
}
|
|
||||||
|
|
||||||
return autoPtr<Thermo>(cstrIter()(mesh));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
} // End namespace Foam
|
} // End namespace Foam
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
#ifdef NoRepository
|
||||||
|
# include "basicThermoTemplates.C"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// ************************************************************************* //
|
// ************************************************************************* //
|
||||||
|
|||||||
@ -0,0 +1,150 @@
|
|||||||
|
/*---------------------------------------------------------------------------*\
|
||||||
|
========= |
|
||||||
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
|
\\ / O peration |
|
||||||
|
\\ / A nd | Copyright (C) 2012 OpenFOAM Foundation
|
||||||
|
\\/ M anipulation |
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
License
|
||||||
|
This file is part of OpenFOAM.
|
||||||
|
|
||||||
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
#include "basicThermo.H"
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
template<class Thermo>
|
||||||
|
Foam::autoPtr<Thermo> Foam::basicThermo::New
|
||||||
|
(
|
||||||
|
const fvMesh& mesh
|
||||||
|
)
|
||||||
|
{
|
||||||
|
IOdictionary thermoDict
|
||||||
|
(
|
||||||
|
IOobject
|
||||||
|
(
|
||||||
|
"thermophysicalProperties",
|
||||||
|
mesh.time().constant(),
|
||||||
|
mesh,
|
||||||
|
IOobject::MUST_READ_IF_MODIFIED,
|
||||||
|
IOobject::NO_WRITE,
|
||||||
|
false
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
word thermoTypeName;
|
||||||
|
|
||||||
|
if (thermoDict.isDict("thermoType"))
|
||||||
|
{
|
||||||
|
const dictionary& thermoTypeDict(thermoDict.subDict("thermoType"));
|
||||||
|
|
||||||
|
Info<< "Selecting thermodynamics package " << thermoTypeDict << endl;
|
||||||
|
|
||||||
|
const int nCmpt = 7;
|
||||||
|
const char* cmptNames[nCmpt] =
|
||||||
|
{
|
||||||
|
"type",
|
||||||
|
"mixture",
|
||||||
|
"transport",
|
||||||
|
"thermo",
|
||||||
|
"equationOfState",
|
||||||
|
"specie",
|
||||||
|
"energy"
|
||||||
|
};
|
||||||
|
|
||||||
|
// Construct the name of the thermo package from the components
|
||||||
|
thermoTypeName =
|
||||||
|
word(thermoTypeDict.lookup("type")) + '<'
|
||||||
|
+ word(thermoTypeDict.lookup("mixture")) + '<'
|
||||||
|
+ word(thermoTypeDict.lookup("transport")) + '<'
|
||||||
|
+ word(thermoTypeDict.lookup("thermo")) + '<'
|
||||||
|
+ word(thermoTypeDict.lookup("equationOfState")) + '<'
|
||||||
|
+ word(thermoTypeDict.lookup("specie")) + ">>,"
|
||||||
|
+ word(thermoTypeDict.lookup("energy")) + ">>>";
|
||||||
|
|
||||||
|
// Lookup the thermo package
|
||||||
|
typename Thermo::fvMeshConstructorTable::iterator cstrIter =
|
||||||
|
Thermo::fvMeshConstructorTablePtr_->find(thermoTypeName);
|
||||||
|
|
||||||
|
// Print error message if package not found in the table
|
||||||
|
if (cstrIter == Thermo::fvMeshConstructorTablePtr_->end())
|
||||||
|
{
|
||||||
|
FatalErrorIn(Thermo::typeName + "::New(const fvMesh&)")
|
||||||
|
<< "Unknown " << Thermo::typeName << " type " << nl
|
||||||
|
<< "thermoType" << thermoTypeDict << nl << nl
|
||||||
|
<< "Valid " << Thermo::typeName << " types are:" << nl << nl;
|
||||||
|
|
||||||
|
// Get the list of all the suitable thermo packages available
|
||||||
|
wordList validThermoTypeNames
|
||||||
|
(
|
||||||
|
Thermo::fvMeshConstructorTablePtr_->sortedToc()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Build a table of the thermo packages constituent parts
|
||||||
|
// Note: row-0 contains the names of constituent parts
|
||||||
|
List<wordList> validThermoTypeNameCmpts
|
||||||
|
(
|
||||||
|
validThermoTypeNames.size() + 1
|
||||||
|
);
|
||||||
|
|
||||||
|
validThermoTypeNameCmpts[0].setSize(nCmpt);
|
||||||
|
forAll(validThermoTypeNameCmpts[0], j)
|
||||||
|
{
|
||||||
|
validThermoTypeNameCmpts[0][j] = cmptNames[j];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Split the thermo package names into their constituent parts
|
||||||
|
forAll(validThermoTypeNames, i)
|
||||||
|
{
|
||||||
|
validThermoTypeNameCmpts[i+1] =
|
||||||
|
Thermo::splitThermoName(validThermoTypeNames[i], nCmpt);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Print the table of available packages
|
||||||
|
// in terms of their constituent parts
|
||||||
|
printTable(validThermoTypeNameCmpts, FatalError);
|
||||||
|
|
||||||
|
FatalError<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
return autoPtr<Thermo>(cstrIter()(mesh));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
thermoTypeName = word(thermoDict.lookup("thermoType"));
|
||||||
|
|
||||||
|
Info<< "Selecting thermodynamics package " << thermoTypeName << endl;
|
||||||
|
|
||||||
|
typename Thermo::fvMeshConstructorTable::iterator cstrIter =
|
||||||
|
Thermo::fvMeshConstructorTablePtr_->find(thermoTypeName);
|
||||||
|
|
||||||
|
if (cstrIter == Thermo::fvMeshConstructorTablePtr_->end())
|
||||||
|
{
|
||||||
|
FatalErrorIn(Thermo::typeName + "::New(const fvMesh&)")
|
||||||
|
<< "Unknown " << Thermo::typeName << " type "
|
||||||
|
<< thermoTypeName << nl << nl
|
||||||
|
<< "Valid " << Thermo::typeName << " types are:" << nl
|
||||||
|
<< Thermo::fvMeshConstructorTablePtr_->sortedToc() << nl
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
return autoPtr<Thermo>(cstrIter()(mesh));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ************************************************************************* //
|
||||||
@ -49,12 +49,14 @@ Foam::fluidThermo::fluidThermo(const fvMesh& mesh, const dictionary& dict)
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::autoPtr<Foam::fluidThermo> Foam::fluidThermo::New
|
Foam::autoPtr<Foam::fluidThermo> Foam::fluidThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh
|
const fvMesh& mesh
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return NewThermo<fluidThermo>(mesh);
|
return basicThermo::New<fluidThermo>(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -29,7 +29,6 @@ Description
|
|||||||
|
|
||||||
SourceFiles
|
SourceFiles
|
||||||
fluidThermo.C
|
fluidThermo.C
|
||||||
fluidThermoNew.C
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
|||||||
@ -70,12 +70,14 @@ Foam::psiThermo::psiThermo(const fvMesh& mesh)
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::autoPtr<Foam::psiThermo> Foam::psiThermo::New
|
Foam::autoPtr<Foam::psiThermo> Foam::psiThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh
|
const fvMesh& mesh
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return NewThermo<psiThermo>(mesh);
|
return basicThermo::New<psiThermo>(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -29,7 +29,6 @@ Description
|
|||||||
|
|
||||||
SourceFiles
|
SourceFiles
|
||||||
psiThermo.C
|
psiThermo.C
|
||||||
psiThermoNew.C
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
|||||||
@ -130,12 +130,14 @@ Foam::rhoThermo::rhoThermo(const fvMesh& mesh, const dictionary& dict)
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::autoPtr<Foam::rhoThermo> Foam::rhoThermo::New
|
Foam::autoPtr<Foam::rhoThermo> Foam::rhoThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh
|
const fvMesh& mesh
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return NewThermo<rhoThermo>(mesh);
|
return basicThermo::New<rhoThermo>(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -29,7 +29,6 @@ Description
|
|||||||
|
|
||||||
SourceFiles
|
SourceFiles
|
||||||
rhoThermo.C
|
rhoThermo.C
|
||||||
rhoThermoNew.C
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
|||||||
@ -9,7 +9,6 @@ psiReactionThermo/psiReactionThermo/psiReactionThermoNew.C
|
|||||||
psiReactionThermo/hePsiReactionThermo/hePsiReactionThermos.C
|
psiReactionThermo/hePsiReactionThermo/hePsiReactionThermos.C
|
||||||
|
|
||||||
psiReactionThermo/psiuReactionThermo/psiuReactionThermo.C
|
psiReactionThermo/psiuReactionThermo/psiuReactionThermo.C
|
||||||
psiReactionThermo/psiuReactionThermo/psiuReactionThermoNew.C
|
|
||||||
psiReactionThermo/heheuReactionThermo/heheuReactionThermos.C
|
psiReactionThermo/heheuReactionThermo/heheuReactionThermos.C
|
||||||
|
|
||||||
rhoReactionThermo/rhoReactionThermo/rhoReactionThermo.C
|
rhoReactionThermo/rhoReactionThermo/rhoReactionThermo.C
|
||||||
|
|||||||
@ -42,6 +42,17 @@ Foam::psiReactionThermo::psiReactionThermo(const fvMesh& mesh)
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
Foam::autoPtr<Foam::psiReactionThermo> Foam::psiReactionThermo::New
|
||||||
|
(
|
||||||
|
const fvMesh& mesh
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return basicThermo::New<psiReactionThermo>(mesh);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::psiReactionThermo::~psiReactionThermo()
|
Foam::psiReactionThermo::~psiReactionThermo()
|
||||||
|
|||||||
@ -26,8 +26,7 @@ License
|
|||||||
#include "psiReactionThermo.H"
|
#include "psiReactionThermo.H"
|
||||||
#include "fvMesh.H"
|
#include "fvMesh.H"
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
/*
|
||||||
|
|
||||||
Foam::autoPtr<Foam::psiReactionThermo> Foam::psiReactionThermo::New
|
Foam::autoPtr<Foam::psiReactionThermo> Foam::psiReactionThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh
|
const fvMesh& mesh
|
||||||
@ -68,7 +67,7 @@ Foam::autoPtr<Foam::psiReactionThermo> Foam::psiReactionThermo::New
|
|||||||
|
|
||||||
return autoPtr<psiReactionThermo>(cstrIter()(mesh));
|
return autoPtr<psiReactionThermo>(cstrIter()(mesh));
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
Foam::autoPtr<Foam::psiReactionThermo> Foam::psiReactionThermo::NewType
|
Foam::autoPtr<Foam::psiReactionThermo> Foam::psiReactionThermo::NewType
|
||||||
(
|
(
|
||||||
|
|||||||
@ -106,6 +106,17 @@ psiuReactionThermo::psiuReactionThermo(const fvMesh& mesh)
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
Foam::autoPtr<Foam::psiuReactionThermo> Foam::psiuReactionThermo::New
|
||||||
|
(
|
||||||
|
const fvMesh& mesh
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return basicThermo::New<psiuReactionThermo>(mesh);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
psiuReactionThermo::~psiuReactionThermo()
|
psiuReactionThermo::~psiuReactionThermo()
|
||||||
|
|||||||
@ -1,73 +0,0 @@
|
|||||||
/*---------------------------------------------------------------------------*\
|
|
||||||
========= |
|
|
||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
||||||
\\ / O peration |
|
|
||||||
\\ / A nd | Copyright (C) 2011-2012 OpenFOAM Foundation
|
|
||||||
\\/ M anipulation |
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
License
|
|
||||||
This file is part of OpenFOAM.
|
|
||||||
|
|
||||||
OpenFOAM is free software: you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation, either version 3 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
|
||||||
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#include "psiuReactionThermo.H"
|
|
||||||
#include "fvMesh.H"
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
||||||
|
|
||||||
Foam::autoPtr<Foam::psiuReactionThermo> Foam::psiuReactionThermo::New
|
|
||||||
(
|
|
||||||
const fvMesh& mesh
|
|
||||||
)
|
|
||||||
{
|
|
||||||
// get model name, but do not register the dictionary
|
|
||||||
// otherwise it is registered in the database twice
|
|
||||||
const word modelType
|
|
||||||
(
|
|
||||||
IOdictionary
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"thermophysicalProperties",
|
|
||||||
mesh.time().constant(),
|
|
||||||
mesh,
|
|
||||||
IOobject::MUST_READ_IF_MODIFIED,
|
|
||||||
IOobject::NO_WRITE,
|
|
||||||
false
|
|
||||||
)
|
|
||||||
).lookup("thermoType")
|
|
||||||
);
|
|
||||||
|
|
||||||
Info<< "Selecting thermodynamics package " << modelType << endl;
|
|
||||||
|
|
||||||
fvMeshConstructorTable::iterator cstrIter =
|
|
||||||
fvMeshConstructorTablePtr_->find(modelType);
|
|
||||||
|
|
||||||
if (cstrIter == fvMeshConstructorTablePtr_->end())
|
|
||||||
{
|
|
||||||
FatalErrorIn("psiuReactionThermo::New(const fvMesh&)")
|
|
||||||
<< "Unknown psiuReactionThermo type "
|
|
||||||
<< modelType << nl << nl
|
|
||||||
<< "Valid psiuReactionThermo types are :" << endl
|
|
||||||
<< fvMeshConstructorTablePtr_->sortedToc()
|
|
||||||
<< exit(FatalError);
|
|
||||||
}
|
|
||||||
|
|
||||||
return autoPtr<psiuReactionThermo>(cstrIter()(mesh));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ************************************************************************* //
|
|
||||||
@ -42,6 +42,17 @@ Foam::rhoReactionThermo::rhoReactionThermo(const fvMesh& mesh)
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Selectors * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
Foam::autoPtr<Foam::rhoReactionThermo> Foam::rhoReactionThermo::New
|
||||||
|
(
|
||||||
|
const fvMesh& mesh
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return basicThermo::New<rhoReactionThermo>(mesh);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::rhoReactionThermo::~rhoReactionThermo()
|
Foam::rhoReactionThermo::~rhoReactionThermo()
|
||||||
|
|||||||
@ -26,8 +26,7 @@ License
|
|||||||
#include "rhoReactionThermo.H"
|
#include "rhoReactionThermo.H"
|
||||||
#include "fvMesh.H"
|
#include "fvMesh.H"
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
/*
|
||||||
|
|
||||||
Foam::autoPtr<Foam::rhoReactionThermo> Foam::rhoReactionThermo::New
|
Foam::autoPtr<Foam::rhoReactionThermo> Foam::rhoReactionThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh
|
const fvMesh& mesh
|
||||||
@ -68,6 +67,7 @@ Foam::autoPtr<Foam::rhoReactionThermo> Foam::rhoReactionThermo::New
|
|||||||
|
|
||||||
return autoPtr<rhoReactionThermo>(cstrIter()(mesh));
|
return autoPtr<rhoReactionThermo>(cstrIter()(mesh));
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
Foam::autoPtr<Foam::rhoReactionThermo> Foam::rhoReactionThermo::NewType
|
Foam::autoPtr<Foam::rhoReactionThermo> Foam::rhoReactionThermo::NewType
|
||||||
|
|||||||
@ -76,7 +76,8 @@ Foam::autoPtr<Foam::solidThermo> Foam::solidThermo::New
|
|||||||
|
|
||||||
Foam::autoPtr<Foam::solidThermo> Foam::solidThermo::New
|
Foam::autoPtr<Foam::solidThermo> Foam::solidThermo::New
|
||||||
(
|
(
|
||||||
const fvMesh& mesh, const dictionary& dict
|
const fvMesh& mesh,
|
||||||
|
const dictionary& dict
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
if (debug)
|
if (debug)
|
||||||
@ -106,4 +107,5 @@ Foam::autoPtr<Foam::solidThermo> Foam::solidThermo::New
|
|||||||
return autoPtr<solidThermo>(cstrIter()(mesh, dict));
|
return autoPtr<solidThermo>(cstrIter()(mesh, dict));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heheuReactionThermo<inhomogeneousMixture<sutherlandTransport<janafThermo<perfectGas<specie>>,absoluteEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heheuReactionThermo;
|
||||||
|
mixture inhomogeneousMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo janafThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy absoluteEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
stoichiometricAirFuelMassRatio stoichiometricAirFuelMassRatio [0 0 0 0 0 0 0] 15.5776;
|
stoichiometricAirFuelMassRatio stoichiometricAirFuelMassRatio [0 0 0 0 0 0 0] 15.5776;
|
||||||
|
|
||||||
|
|||||||
@ -20,30 +20,35 @@ FoamFile
|
|||||||
left
|
left
|
||||||
{
|
{
|
||||||
type symmetryPlane;
|
type symmetryPlane;
|
||||||
|
inGroups 1(symmetryPlane);
|
||||||
nFaces 35;
|
nFaces 35;
|
||||||
startFace 4795;
|
startFace 4795;
|
||||||
}
|
}
|
||||||
right
|
right
|
||||||
{
|
{
|
||||||
type symmetryPlane;
|
type symmetryPlane;
|
||||||
|
inGroups 1(symmetryPlane);
|
||||||
nFaces 35;
|
nFaces 35;
|
||||||
startFace 4830;
|
startFace 4830;
|
||||||
}
|
}
|
||||||
top
|
top
|
||||||
{
|
{
|
||||||
type symmetryPlane;
|
type symmetryPlane;
|
||||||
|
inGroups 1(symmetryPlane);
|
||||||
nFaces 70;
|
nFaces 70;
|
||||||
startFace 4865;
|
startFace 4865;
|
||||||
}
|
}
|
||||||
bottom
|
bottom
|
||||||
{
|
{
|
||||||
type symmetryPlane;
|
type symmetryPlane;
|
||||||
|
inGroups 1(symmetryPlane);
|
||||||
nFaces 70;
|
nFaces 70;
|
||||||
startFace 4935;
|
startFace 4935;
|
||||||
}
|
}
|
||||||
frontAndBack
|
frontAndBack
|
||||||
{
|
{
|
||||||
type empty;
|
type empty;
|
||||||
|
inGroups 1(empty);
|
||||||
nFaces 4900;
|
nFaces 4900;
|
||||||
startFace 5005;
|
startFace 5005;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heheuReactionThermo<homogeneousMixture<sutherlandTransport<janafThermo<perfectGas<specie>>,absoluteEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heheuReactionThermo;
|
||||||
|
mixture homogeneousMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo janafThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy absoluteEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
stoichiometricAirFuelMassRatio stoichiometricAirFuelMassRatio [ 0 0 0 0 0 0 0 ] 15.675;
|
stoichiometricAirFuelMassRatio stoichiometricAirFuelMassRatio [ 0 0 0 0 0 0 0 ] 15.675;
|
||||||
|
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heheuReactionThermo<inhomogeneousMixture<sutherlandTransport<janafThermo<perfectGas<specie>>,absoluteEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heheuReactionThermo;
|
||||||
|
mixture inhomogeneousMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo janafThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy absoluteEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
stoichiometricAirFuelMassRatio stoichiometricAirFuelMassRatio [ 0 0 0 0 0 0 0 ] 15.0336;
|
stoichiometricAirFuelMassRatio stoichiometricAirFuelMassRatio [ 0 0 0 0 0 0 0 ] 15.0336;
|
||||||
|
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<janafThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo janafThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
// Note: these are the properties for a "normalised" inviscid gas
|
// Note: these are the properties for a "normalised" inviscid gas
|
||||||
// for which the speed of sound is 1 m/s at a temperature of 1K
|
// for which the speed of sound is 1 m/s at a temperature of 1K
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<sutherlandTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport sutherlandTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
// Note: these are the properties for a "normalised" inviscid gas
|
// Note: these are the properties for a "normalised" inviscid gas
|
||||||
// for which the speed of sound is 1 m/s at a temperature of 1K
|
// for which the speed of sound is 1 m/s at a temperature of 1K
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleInternalEnergy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,8 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
//thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleInternalEnergy>>>;
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
pRef 100000;
|
pRef 100000;
|
||||||
|
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
pRef 100000;
|
pRef 100000;
|
||||||
|
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType hePsiThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type hePsiThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
pRef 100000;
|
pRef 100000;
|
||||||
|
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -14,7 +14,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<rhoConst<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState rhoConst;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
@ -15,7 +15,16 @@ FoamFile
|
|||||||
}
|
}
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
thermoType heRhoThermo<pureMixture<constTransport<hConstThermo<perfectGas<specie>>,sensibleEnthalpy>>>;
|
thermoType
|
||||||
|
{
|
||||||
|
type heRhoThermo;
|
||||||
|
mixture pureMixture;
|
||||||
|
transport constTransport;
|
||||||
|
thermo hConstThermo;
|
||||||
|
equationOfState perfectGas;
|
||||||
|
specie specie;
|
||||||
|
energy sensibleEnthalpy;
|
||||||
|
}
|
||||||
|
|
||||||
mixture
|
mixture
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user