Remove from release
This commit is contained in:
parent
80b603ad1a
commit
1567f5c620
14 changed files with 0 additions and 441 deletions
|
@ -1,3 +0,0 @@
|
||||||
pUCoupledFullPicardFoam.C
|
|
||||||
|
|
||||||
EXE = $(FOAM_APPBIN)/pUCoupledFullPicardFoam
|
|
|
@ -1,12 +0,0 @@
|
||||||
EXE_INC = \
|
|
||||||
-I$(LIB_SRC)/turbulenceModels \
|
|
||||||
-I$(LIB_SRC)/turbulenceModels/incompressible/RAS/RASModel \
|
|
||||||
-I$(LIB_SRC)/transportModels \
|
|
||||||
-I$(LIB_SRC)/transportModels/incompressible/singlePhaseTransportModel \
|
|
||||||
-I$(LIB_SRC)/finiteVolume/lnInclude
|
|
||||||
|
|
||||||
EXE_LIBS = \
|
|
||||||
-lincompressibleRASModels \
|
|
||||||
-lincompressibleTransportModels \
|
|
||||||
-lfiniteVolume \
|
|
||||||
-llduSolvers
|
|
|
@ -1,12 +0,0 @@
|
||||||
// Momentum equation
|
|
||||||
fvVectorMatrix UEqn
|
|
||||||
(
|
|
||||||
fvm::div(phi, U)
|
|
||||||
+ fvc::div(-phi, U, "div(phi,U)")
|
|
||||||
+ turbulence->divDevReff(U)
|
|
||||||
);
|
|
||||||
|
|
||||||
UEqn.relax();
|
|
||||||
|
|
||||||
UpEqn.insertEquation(0, UEqn);
|
|
||||||
UpEqn.insertPicardTensor(0, U, phi);
|
|
|
@ -1,52 +0,0 @@
|
||||||
Info << "Reading field p\n" << endl;
|
|
||||||
volScalarField p
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"p",
|
|
||||||
runTime.timeName(),
|
|
||||||
mesh,
|
|
||||||
IOobject::MUST_READ,
|
|
||||||
IOobject::AUTO_WRITE
|
|
||||||
),
|
|
||||||
mesh
|
|
||||||
);
|
|
||||||
|
|
||||||
Info << "Reading field U\n" << endl;
|
|
||||||
volVectorField U
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"U",
|
|
||||||
runTime.timeName(),
|
|
||||||
mesh,
|
|
||||||
IOobject::MUST_READ,
|
|
||||||
IOobject::AUTO_WRITE
|
|
||||||
),
|
|
||||||
mesh
|
|
||||||
);
|
|
||||||
|
|
||||||
#include "createPhi.H"
|
|
||||||
|
|
||||||
singlePhaseTransportModel laminarTransport(U, phi);
|
|
||||||
autoPtr<incompressible::RASModel> turbulence
|
|
||||||
(
|
|
||||||
incompressible::RASModel::New(U, phi, laminarTransport)
|
|
||||||
);
|
|
||||||
|
|
||||||
// Block vector field for velocity (first entry) and pressure (second
|
|
||||||
// entry).
|
|
||||||
Info << "Creating field Up\n" << endl;
|
|
||||||
volVector4Field Up
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"Up",
|
|
||||||
runTime.timeName(),
|
|
||||||
mesh,
|
|
||||||
IOobject::NO_READ,
|
|
||||||
IOobject::AUTO_WRITE
|
|
||||||
),
|
|
||||||
mesh,
|
|
||||||
dimensionedVector4("zero", dimless, vector4::zero)
|
|
||||||
);
|
|
|
@ -1,23 +0,0 @@
|
||||||
// Pressure parts of the continuity equation
|
|
||||||
surfaceScalarField rUAf
|
|
||||||
(
|
|
||||||
"rUAf",
|
|
||||||
fvc::interpolate(1.0/UEqn.A())
|
|
||||||
);
|
|
||||||
|
|
||||||
surfaceScalarField presSource
|
|
||||||
(
|
|
||||||
"presSource",
|
|
||||||
rUAf*(fvc::interpolate(fvc::grad(p, "grad(pSource)")) & mesh.Sf())
|
|
||||||
);
|
|
||||||
|
|
||||||
fvScalarMatrix pEqn
|
|
||||||
(
|
|
||||||
- fvm::laplacian(rUAf, p)
|
|
||||||
==
|
|
||||||
- fvc::div(presSource)
|
|
||||||
);
|
|
||||||
|
|
||||||
pEqn.setReference(pRefCell, pRefValue);
|
|
||||||
|
|
||||||
UpEqn.insertEquation(3, pEqn);
|
|
|
@ -1,116 +0,0 @@
|
||||||
/*---------------------------------------------------------------------------*\
|
|
||||||
========= |
|
|
||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
||||||
\\ / O peration |
|
|
||||||
\\ / A nd | Copyright held by original author
|
|
||||||
\\/ 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 2 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, write to the Free Software Foundation,
|
|
||||||
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
|
|
||||||
Application
|
|
||||||
pUCoupledFullPicardFoam
|
|
||||||
|
|
||||||
Description
|
|
||||||
Steady-state solver for incompressible, turbulent flow, with implicit
|
|
||||||
coupling between pressure and velocity achieved by fvBlockMatrix.
|
|
||||||
Turbulence is in this version solved using the existing turbulence
|
|
||||||
structure.
|
|
||||||
Convective term is properly linearised using Picard linearisation and
|
|
||||||
additional block coefficients. This is full, proper variant!
|
|
||||||
VV, 23/July/2014.
|
|
||||||
|
|
||||||
Authors
|
|
||||||
Klas Jareteg, Chalmers University of Technology,
|
|
||||||
Vuko Vukcevic, FMENA Zagreb.
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#include "fvCFD.H"
|
|
||||||
#include "singlePhaseTransportModel.H"
|
|
||||||
#include "RASModel.H"
|
|
||||||
#include "fvBlockMatrix.H"
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
|
|
||||||
# include "setRootCase.H"
|
|
||||||
# include "createTime.H"
|
|
||||||
# include "createMesh.H"
|
|
||||||
# include "createFields.H"
|
|
||||||
# include "initContinuityErrs.H"
|
|
||||||
# include "readBlockSolverControls.H"
|
|
||||||
|
|
||||||
// Calculate div U coupling only once since it is only geometry dependant.
|
|
||||||
BlockLduSystem<vector, scalar> UInp(fvm::div(U));
|
|
||||||
|
|
||||||
Info<< "\nStarting time loop\n" << endl;
|
|
||||||
while (runTime.loop())
|
|
||||||
{
|
|
||||||
Info<< "Time = " << runTime.timeName() << nl << endl;
|
|
||||||
|
|
||||||
p.storePrevIter();
|
|
||||||
|
|
||||||
// Initialize the Up block system (matrix, source and reference to Up)
|
|
||||||
fvBlockMatrix<vector4> UpEqn(Up);
|
|
||||||
|
|
||||||
// Assemble and insert momentum equation
|
|
||||||
# include "UEqn.H"
|
|
||||||
|
|
||||||
// Assemble and insert pressure equation
|
|
||||||
# include "pEqn.H"
|
|
||||||
|
|
||||||
// Calculate grad p coupling matrix. Needs to be here if one uses
|
|
||||||
// gradient schemes with limiters. VV, 9/June/2014
|
|
||||||
BlockLduSystem<vector, vector> pInU(fvm::grad(p));
|
|
||||||
|
|
||||||
// Last argument in insertBlockCoupling says if the column direction
|
|
||||||
// should be incremented. This is needed for arbitrary positioning
|
|
||||||
// of U and p in the system. This could be better. VV, 30/April/2014
|
|
||||||
UpEqn.insertBlockCoupling(0, 3, pInU, true);
|
|
||||||
UpEqn.insertBlockCoupling(3, 0, UInp, false);
|
|
||||||
|
|
||||||
// Solve the block matrix
|
|
||||||
UpEqn.solve();
|
|
||||||
|
|
||||||
// Retrieve solution
|
|
||||||
UpEqn.retrieveSolution(0, U.internalField());
|
|
||||||
UpEqn.retrieveSolution(3, p.internalField());
|
|
||||||
|
|
||||||
U.correctBoundaryConditions();
|
|
||||||
p.correctBoundaryConditions();
|
|
||||||
|
|
||||||
phi = (fvc::interpolate(U) & mesh.Sf()) + pEqn.flux() + presSource;
|
|
||||||
|
|
||||||
# include "continuityErrs.H"
|
|
||||||
|
|
||||||
p.relax();
|
|
||||||
|
|
||||||
turbulence->correct();
|
|
||||||
runTime.write();
|
|
||||||
|
|
||||||
Info<< "ExecutionTime = " << runTime.elapsedCpuTime() << " s"
|
|
||||||
<< " ClockTime = " << runTime.elapsedClockTime() << " s"
|
|
||||||
<< nl << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
Info<< "End\n" << endl;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
|
@ -1,3 +0,0 @@
|
||||||
label pRefCell = 0;
|
|
||||||
scalar pRefValue = 0;
|
|
||||||
setRefCell(p, mesh.solutionDict().subDict("blockSolver"), pRefCell, pRefValue);
|
|
|
@ -1,3 +0,0 @@
|
||||||
pUCoupledSemiPicardFoam.C
|
|
||||||
|
|
||||||
EXE = $(FOAM_APPBIN)/pUCoupledSemiPicardFoam
|
|
|
@ -1,12 +0,0 @@
|
||||||
EXE_INC = \
|
|
||||||
-I$(LIB_SRC)/turbulenceModels \
|
|
||||||
-I$(LIB_SRC)/turbulenceModels/incompressible/RAS/RASModel \
|
|
||||||
-I$(LIB_SRC)/transportModels \
|
|
||||||
-I$(LIB_SRC)/transportModels/incompressible/singlePhaseTransportModel \
|
|
||||||
-I$(LIB_SRC)/finiteVolume/lnInclude
|
|
||||||
|
|
||||||
EXE_LIBS = \
|
|
||||||
-lincompressibleRASModels \
|
|
||||||
-lincompressibleTransportModels \
|
|
||||||
-lfiniteVolume \
|
|
||||||
-llduSolvers
|
|
|
@ -1,11 +0,0 @@
|
||||||
// Momentum equation
|
|
||||||
fvVectorMatrix UEqn
|
|
||||||
(
|
|
||||||
fvm::div(2*phi, U,"div(phi,U)")
|
|
||||||
+ fvc::div(-phi, U,"div(phi,U)")
|
|
||||||
+ turbulence->divDevReff(U)
|
|
||||||
);
|
|
||||||
|
|
||||||
UEqn.relax();
|
|
||||||
|
|
||||||
UpEqn.insertEquation(0, UEqn);
|
|
|
@ -1,52 +0,0 @@
|
||||||
Info << "Reading field p\n" << endl;
|
|
||||||
volScalarField p
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"p",
|
|
||||||
runTime.timeName(),
|
|
||||||
mesh,
|
|
||||||
IOobject::MUST_READ,
|
|
||||||
IOobject::AUTO_WRITE
|
|
||||||
),
|
|
||||||
mesh
|
|
||||||
);
|
|
||||||
|
|
||||||
Info << "Reading field U\n" << endl;
|
|
||||||
volVectorField U
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"U",
|
|
||||||
runTime.timeName(),
|
|
||||||
mesh,
|
|
||||||
IOobject::MUST_READ,
|
|
||||||
IOobject::AUTO_WRITE
|
|
||||||
),
|
|
||||||
mesh
|
|
||||||
);
|
|
||||||
|
|
||||||
#include "createPhi.H"
|
|
||||||
|
|
||||||
singlePhaseTransportModel laminarTransport(U, phi);
|
|
||||||
autoPtr<incompressible::RASModel> turbulence
|
|
||||||
(
|
|
||||||
incompressible::RASModel::New(U, phi, laminarTransport)
|
|
||||||
);
|
|
||||||
|
|
||||||
// Block vector field for velocity (first entry) and pressure (second
|
|
||||||
// entry).
|
|
||||||
Info << "Creating field Up\n" << endl;
|
|
||||||
volVector4Field Up
|
|
||||||
(
|
|
||||||
IOobject
|
|
||||||
(
|
|
||||||
"Up",
|
|
||||||
runTime.timeName(),
|
|
||||||
mesh,
|
|
||||||
IOobject::NO_READ,
|
|
||||||
IOobject::AUTO_WRITE
|
|
||||||
),
|
|
||||||
mesh,
|
|
||||||
dimensionedVector4("zero", dimless, vector4::zero)
|
|
||||||
);
|
|
|
@ -1,23 +0,0 @@
|
||||||
// Pressure parts of the continuity equation
|
|
||||||
surfaceScalarField rUAf
|
|
||||||
(
|
|
||||||
"rUAf",
|
|
||||||
fvc::interpolate(1.0/UEqn.A())
|
|
||||||
);
|
|
||||||
|
|
||||||
surfaceScalarField presSource
|
|
||||||
(
|
|
||||||
"presSource",
|
|
||||||
rUAf*(fvc::interpolate(fvc::grad(p, "grad(pSource)")) & mesh.Sf())
|
|
||||||
);
|
|
||||||
|
|
||||||
fvScalarMatrix pEqn
|
|
||||||
(
|
|
||||||
- fvm::laplacian(rUAf, p)
|
|
||||||
==
|
|
||||||
- fvc::div(presSource)
|
|
||||||
);
|
|
||||||
|
|
||||||
pEqn.setReference(pRefCell, pRefValue);
|
|
||||||
|
|
||||||
UpEqn.insertEquation(3, pEqn);
|
|
|
@ -1,116 +0,0 @@
|
||||||
/*---------------------------------------------------------------------------*\
|
|
||||||
========= |
|
|
||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
||||||
\\ / O peration |
|
|
||||||
\\ / A nd | Copyright held by original author
|
|
||||||
\\/ 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 2 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, write to the Free Software Foundation,
|
|
||||||
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
|
|
||||||
Application
|
|
||||||
pUCoupledSemiPicardFoam
|
|
||||||
|
|
||||||
Description
|
|
||||||
Steady-state solver for incompressible, turbulent flow, with implicit
|
|
||||||
coupling between pressure and velocity achieved by fvBlockMatrix.
|
|
||||||
Turbulence is in this version solved using the existing turbulence
|
|
||||||
structure.
|
|
||||||
Convective term is properly linearised using Picard linearisation and
|
|
||||||
additional block coefficients. This is semi variant where the difference
|
|
||||||
between succesive velocity fields is neglected! VV, 23/July/2014.
|
|
||||||
|
|
||||||
Authors
|
|
||||||
Klas Jareteg, Chalmers University of Technology,
|
|
||||||
Vuko Vukcevic, FMENA Zagreb.
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#include "fvCFD.H"
|
|
||||||
#include "singlePhaseTransportModel.H"
|
|
||||||
#include "RASModel.H"
|
|
||||||
#include "fvBlockMatrix.H"
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
|
|
||||||
# include "setRootCase.H"
|
|
||||||
# include "createTime.H"
|
|
||||||
# include "createMesh.H"
|
|
||||||
# include "createFields.H"
|
|
||||||
# include "initContinuityErrs.H"
|
|
||||||
# include "readBlockSolverControls.H"
|
|
||||||
|
|
||||||
// Calculate div U coupling only once since it is only geometry dependant.
|
|
||||||
BlockLduSystem<vector, scalar> UInp(fvm::div(U));
|
|
||||||
|
|
||||||
Info<< "\nStarting time loop\n" << endl;
|
|
||||||
while (runTime.loop())
|
|
||||||
{
|
|
||||||
Info<< "Time = " << runTime.timeName() << nl << endl;
|
|
||||||
|
|
||||||
p.storePrevIter();
|
|
||||||
|
|
||||||
// Initialize the Up block system (matrix, source and reference to Up)
|
|
||||||
fvBlockMatrix<vector4> UpEqn(Up);
|
|
||||||
|
|
||||||
// Assemble and insert momentum equation
|
|
||||||
# include "UEqn.H"
|
|
||||||
|
|
||||||
// Assemble and insert pressure equation
|
|
||||||
# include "pEqn.H"
|
|
||||||
|
|
||||||
// Calculate grad p coupling matrix. Needs to be here if one uses
|
|
||||||
// gradient schemes with limiters. VV, 9/June/2014
|
|
||||||
BlockLduSystem<vector, vector> pInU(fvm::grad(p));
|
|
||||||
|
|
||||||
// Last argument in insertBlockCoupling says if the column direction
|
|
||||||
// should be incremented. This is needed for arbitrary positioning
|
|
||||||
// of U and p in the system. This could be better. VV, 30/April/2014
|
|
||||||
UpEqn.insertBlockCoupling(0, 3, pInU, true);
|
|
||||||
UpEqn.insertBlockCoupling(3, 0, UInp, false);
|
|
||||||
|
|
||||||
// Solve the block matrix
|
|
||||||
UpEqn.solve();
|
|
||||||
|
|
||||||
// Retrieve solution
|
|
||||||
UpEqn.retrieveSolution(0, U.internalField());
|
|
||||||
UpEqn.retrieveSolution(3, p.internalField());
|
|
||||||
|
|
||||||
U.correctBoundaryConditions();
|
|
||||||
p.correctBoundaryConditions();
|
|
||||||
|
|
||||||
phi = (fvc::interpolate(U) & mesh.Sf()) + pEqn.flux() + presSource;
|
|
||||||
|
|
||||||
# include "continuityErrs.H"
|
|
||||||
|
|
||||||
p.relax();
|
|
||||||
|
|
||||||
turbulence->correct();
|
|
||||||
runTime.write();
|
|
||||||
|
|
||||||
Info<< "ExecutionTime = " << runTime.elapsedCpuTime() << " s"
|
|
||||||
<< " ClockTime = " << runTime.elapsedClockTime() << " s"
|
|
||||||
<< nl << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
Info<< "End\n" << endl;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
|
@ -1,3 +0,0 @@
|
||||||
label pRefCell = 0;
|
|
||||||
scalar pRefValue = 0;
|
|
||||||
setRefCell(p, mesh.solutionDict().subDict("blockSolver"), pRefCell, pRefValue);
|
|
Reference in a new issue