buoyantWallHeatFlux utility
Variant of wallHeatFlux utility for incompressible flow with Boussinesq's buoyancy assumption (e.g. buoyantBoussinesqSimpleFoam). Reports total wall heat flux on each wall and also writes buoyantWallHeatFlux as volScalarField for easy visualisation.
This commit is contained in:
parent
3d6293352a
commit
b4a7a0e33f
6 changed files with 242 additions and 0 deletions
|
@ -0,0 +1,46 @@
|
|||
# --------------------------------------------------------------------------
|
||||
# ======== |
|
||||
# \ / F ield | foam-extend: Open Source CFD
|
||||
# \ / O peration | Version: 4.1
|
||||
# \ / A nd | Web: http://www.foam-extend.org
|
||||
# \/ M anipulation | For copyright notice see file Copyright
|
||||
# --------------------------------------------------------------------------
|
||||
# License
|
||||
# This file is part of foam-extend.
|
||||
#
|
||||
# foam-extend 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.
|
||||
#
|
||||
# foam-extend 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 foam-extend. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
# Description
|
||||
# CMakeLists.txt file for libraries and applications
|
||||
#
|
||||
# Author
|
||||
# Henrik Rusche, Wikki GmbH, 2017. All rights reserved
|
||||
#
|
||||
#
|
||||
# --------------------------------------------------------------------------
|
||||
|
||||
list(APPEND SOURCES
|
||||
buoyantWallHeatFlux.C
|
||||
)
|
||||
|
||||
# Set minimal environment for external compilation
|
||||
if(NOT FOAM_FOUND)
|
||||
cmake_minimum_required(VERSION 2.8)
|
||||
find_package(FOAM REQUIRED)
|
||||
endif()
|
||||
|
||||
add_foam_executable(buoyantWallHeatFlux
|
||||
DEPENDS incompressibleRASModels incompressibleTransportModels incompressibleLESModels
|
||||
SOURCES ${SOURCES}
|
||||
)
|
|
@ -0,0 +1,3 @@
|
|||
buoyantWallHeatFlux.C
|
||||
|
||||
EXE = $(FOAM_APPBIN)/buoyantWallHeatFlux
|
|
@ -0,0 +1,20 @@
|
|||
EXE_INC = \
|
||||
-I$(LIB_SRC)/finiteVolume/lnInclude \
|
||||
-I$(LIB_SRC)/turbulenceModels \
|
||||
-I$(LIB_SRC)/turbulenceModels/LES/LESdeltas/lnInclude \
|
||||
-I$(LIB_SRC)/turbulenceModels/LES/LESfilters/lnInclude \
|
||||
-I$(LIB_SRC)/turbulenceModels/incompressible/RAS/lnInclude \
|
||||
-I$(LIB_SRC)/turbulenceModels/incompressible/LES/lnInclude \
|
||||
-I$(LIB_SRC)/transportModels \
|
||||
-I$(LIB_SRC)/transportModels/incompressible/singlePhaseTransportModel
|
||||
|
||||
EXE_LIBS = \
|
||||
-lfiniteVolume \
|
||||
-lmeshTools \
|
||||
-lincompressibleTurbulenceModel \
|
||||
-lincompressibleRASModels \
|
||||
-lincompressibleLESModels \
|
||||
-lincompressibleTransportModels \
|
||||
-lLESdeltas \
|
||||
-lLESfilters \
|
||||
-llduSolvers
|
|
@ -0,0 +1,116 @@
|
|||
/*---------------------------------------------------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | foam-extend: Open Source CFD
|
||||
\\ / O peration | Version: 4.1
|
||||
\\ / A nd | Web: http://www.foam-extend.org
|
||||
\\/ M anipulation | For copyright notice see file Copyright
|
||||
-------------------------------------------------------------------------------
|
||||
License
|
||||
This file is part of foam-extend.
|
||||
|
||||
foam-extend 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.
|
||||
|
||||
foam-extend 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 foam-extend. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
Application
|
||||
buoyantWallHeatFlux
|
||||
|
||||
Description
|
||||
Calculates and writes the heat flux in incompressible flow with Boussinesq's
|
||||
buoyancy assumption (e.g. buoyantBoussineqSimpleFoam) for all patches as the
|
||||
boundary field of a volScalarField and also prints the integrated flux for
|
||||
all wall patches.
|
||||
|
||||
\*---------------------------------------------------------------------------*/
|
||||
|
||||
#include "fvCFD.H"
|
||||
#include "RASModel.H"
|
||||
#include "LESModel.H"
|
||||
#include "singlePhaseTransportModel.H"
|
||||
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
timeSelector::addOptions();
|
||||
#include "setRootCase.H"
|
||||
#include "createTime.H"
|
||||
instantList timeDirs = timeSelector::select0(runTime, args);
|
||||
#include "createMesh.H"
|
||||
|
||||
forAll(timeDirs, timeI)
|
||||
{
|
||||
runTime.setTime(timeDirs[timeI], timeI);
|
||||
Info<< "Time = " << runTime.timeName() << endl;
|
||||
mesh.readUpdate();
|
||||
|
||||
#include "createFields.H"
|
||||
|
||||
// Calculate effective kappa
|
||||
const volScalarField kappaEff
|
||||
(
|
||||
"kappaEff",
|
||||
turbulence->nu()/Pr + turbulence->nut()/Prt
|
||||
);
|
||||
|
||||
// Calculate the heat flux
|
||||
const surfaceScalarField heatFlux =
|
||||
rhoRef*c*fvc::interpolate(kappaEff)*fvc::snGrad(T);
|
||||
|
||||
// Get the heat flux at the patch
|
||||
const surfaceScalarField::GeometricBoundaryField& patchHeatFlux =
|
||||
heatFlux.boundaryField();
|
||||
|
||||
Info<< "\nWall heat fluxes [W]" << endl;
|
||||
forAll(patchHeatFlux, patchi)
|
||||
{
|
||||
if (mesh.boundary()[patchi].isWall())
|
||||
{
|
||||
Info<< mesh.boundary()[patchi].name()
|
||||
<< " "
|
||||
<< gSum
|
||||
(
|
||||
mesh.magSf().boundaryField()[patchi]
|
||||
*patchHeatFlux[patchi]
|
||||
)
|
||||
<< endl;
|
||||
}
|
||||
}
|
||||
Info<< endl;
|
||||
|
||||
// Create the volScalarField which will have heat fluxes at the boundary
|
||||
volScalarField buoyantWallHeatFlux
|
||||
(
|
||||
IOobject
|
||||
(
|
||||
"buoyantWallHeatFlux",
|
||||
runTime.timeName(),
|
||||
mesh
|
||||
),
|
||||
mesh,
|
||||
dimensionedScalar("buoyantWallHeatFlux", heatFlux.dimensions(), 0.0)
|
||||
);
|
||||
|
||||
forAll(buoyantWallHeatFlux.boundaryField(), patchi)
|
||||
{
|
||||
buoyantWallHeatFlux.boundaryField()[patchi] = patchHeatFlux[patchi];
|
||||
}
|
||||
|
||||
buoyantWallHeatFlux.write();
|
||||
}
|
||||
|
||||
Info<< "End" << endl;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
|
@ -0,0 +1,44 @@
|
|||
// Read velocity field for turbulence
|
||||
volVectorField U
|
||||
(
|
||||
IOobject
|
||||
(
|
||||
"U",
|
||||
runTime.timeName(),
|
||||
mesh,
|
||||
IOobject::MUST_READ,
|
||||
IOobject::AUTO_WRITE
|
||||
),
|
||||
mesh
|
||||
);
|
||||
|
||||
// Read temperature field
|
||||
volScalarField T
|
||||
(
|
||||
IOobject
|
||||
(
|
||||
"T",
|
||||
runTime.timeName(),
|
||||
mesh,
|
||||
IOobject::MUST_READ,
|
||||
IOobject::AUTO_WRITE
|
||||
),
|
||||
mesh
|
||||
);
|
||||
|
||||
// Create the flux for turbulence
|
||||
#include "createPhi.H"
|
||||
|
||||
// Read transport properties and all necessary coefficients
|
||||
#include "readTransportProperties.H"
|
||||
|
||||
// Create generic turbulence model (RAS/LES)
|
||||
autoPtr<incompressible::turbulenceModel> turbulence
|
||||
(
|
||||
incompressible::turbulenceModel::New
|
||||
(
|
||||
U,
|
||||
phi,
|
||||
laminarTransport
|
||||
)
|
||||
);
|
|
@ -0,0 +1,13 @@
|
|||
singlePhaseTransportModel laminarTransport(U, phi);
|
||||
|
||||
// Laminar Prandtl number
|
||||
const dimensionedScalar Pr(laminarTransport.lookup("Pr"));
|
||||
|
||||
// Turbulent Prandtl number
|
||||
const dimensionedScalar Prt(laminarTransport.lookup("Prt"));
|
||||
|
||||
// Reference density
|
||||
const dimensionedScalar rhoRef(laminarTransport.lookup("rhoRef"));
|
||||
|
||||
// Specific heat capacity
|
||||
const dimensionedScalar c(laminarTransport.lookup("c"));
|
Reference in a new issue