mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
272 lines
7.9 KiB
C++
272 lines
7.9 KiB
C++
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2014-2017 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::fv::solidificationMeltingSource
|
|
|
|
Group
|
|
grpFvOptionsSources
|
|
|
|
Description
|
|
This source is designed to model the effect of solidification and melting
|
|
processes, e.g. windhield defrosting. The phase change occurs at the
|
|
melting temperature, \c Tmelt.
|
|
|
|
The presence of the solid phase in the flow field is incorporated into the
|
|
model as a momentum porosity contribution; the energy associated with the
|
|
phase change is added as an enthalpy contribution.
|
|
|
|
Based on the references:
|
|
-# V.R. Voller and C. Prakash, A fixed grid numerical modelling
|
|
methodology for convection-diffusion mushy phase-change problems,
|
|
Int. J. Heat Mass Transfer 30(8):17091719, 1987.
|
|
-# C.R. Swaminathan. and V.R. Voller, A general enthalpy model for
|
|
modeling solidification processes, Metallurgical Transactions
|
|
23B:651664, 1992.
|
|
|
|
The model generates a field \c \<name\>:alpha1 which can be visualised to
|
|
to show the melt distribution as a fraction [0-1]
|
|
|
|
Usage
|
|
Example usage:
|
|
\verbatim
|
|
solidificationMeltingSource1
|
|
{
|
|
type solidificationMeltingSource;
|
|
active yes;
|
|
|
|
selectionMode cellZone;
|
|
cellZone iceZone;
|
|
|
|
Tmelt 273;
|
|
L 334000;
|
|
thermoMode thermo;
|
|
beta 50e-6;
|
|
rhoRef 800;
|
|
}
|
|
\endverbatim
|
|
|
|
Where:
|
|
\table
|
|
Property | Description | Required | Default value
|
|
Tmelt | Melting temperature [K] | yes |
|
|
L | Latent heat of fusion [J/kg] | yes |
|
|
relax | Relaxation coefficient [0-1] | no | 0.9
|
|
thermoMode | Thermo mode [thermo|lookup] | yes |
|
|
rhoRef | Reference (solid) density | yes |
|
|
rho | Name of density field | no | rho
|
|
T | Name of temperature field | no | T
|
|
Cp | Name of specific heat capacity field | no | Cp
|
|
U | Name of velocity field | no | U
|
|
phi | Name of flux field | no | phi
|
|
Cu | Model coefficient | no | 100000
|
|
q | Model coefficient | no | 0.001
|
|
beta | Thermal expansion coefficient [1/K] | yes |
|
|
g | Accelerartion due to gravity | no |
|
|
\endtable
|
|
|
|
SourceFiles
|
|
solidificationMeltingSource.C
|
|
solidificationMeltingSourceIO.C
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#ifndef solidificationMeltingSource_H
|
|
#define solidificationMeltingSource_H
|
|
|
|
#include "fvMesh.H"
|
|
#include "volFields.H"
|
|
#include "cellSetOption.H"
|
|
#include "Enum.H"
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
namespace Foam
|
|
{
|
|
namespace fv
|
|
{
|
|
|
|
/*---------------------------------------------------------------------------*\
|
|
Class solidificationMeltingSource Declaration
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
class solidificationMeltingSource
|
|
:
|
|
public cellSetOption
|
|
{
|
|
public:
|
|
|
|
enum thermoMode
|
|
{
|
|
mdThermo,
|
|
mdLookup
|
|
};
|
|
|
|
static const Enum<thermoMode> thermoModeTypeNames_;
|
|
|
|
|
|
private:
|
|
|
|
// Private data
|
|
|
|
//- Temperature at which melting occurs [K]
|
|
scalar Tmelt_;
|
|
|
|
//- Latent heat of fusion [J/kg]
|
|
scalar L_;
|
|
|
|
//- Phase fraction under-relaxation coefficient
|
|
scalar relax_;
|
|
|
|
//- Thermodynamics mode
|
|
thermoMode mode_;
|
|
|
|
//- Reference density - typically the solid density
|
|
scalar rhoRef_;
|
|
|
|
//- Name of temperature field - default = "T" (optional)
|
|
word TName_;
|
|
|
|
//- Name of specific heat capacity field - default = "Cp" (optional)
|
|
word CpName_;
|
|
|
|
//- Name of velocity field - default = "U" (optional)
|
|
word UName_;
|
|
|
|
//- Name of flux field - default = "phi" (optional)
|
|
word phiName_;
|
|
|
|
//- Mushy region momentum sink coefficient [1/s]; default = 10^5
|
|
scalar Cu_;
|
|
|
|
//- Coefficient used in porosity calc - default = 0.001
|
|
scalar q_;
|
|
|
|
//- Thermal expansion coefficient [1/K]
|
|
scalar beta_;
|
|
|
|
//- Phase fraction indicator field
|
|
volScalarField alpha1_;
|
|
|
|
//- Current time index (used for updating)
|
|
label curTimeIndex_;
|
|
|
|
//- Temperature change cached for source calculation when alpha1 updated
|
|
scalarField deltaT_;
|
|
|
|
|
|
// Private Member Functions
|
|
|
|
//- Return the specific heat capacity field
|
|
tmp<volScalarField> Cp() const;
|
|
|
|
//- Return the gravity vector
|
|
vector g() const;
|
|
|
|
//- Update the model
|
|
void update(const volScalarField& Cp);
|
|
|
|
//- Helper function to apply to the energy equation
|
|
template<class RhoFieldType>
|
|
void apply(const RhoFieldType& rho, fvMatrix<scalar>& eqn);
|
|
|
|
//- No copy construct
|
|
solidificationMeltingSource
|
|
(
|
|
const solidificationMeltingSource&
|
|
) = delete;
|
|
|
|
//- No copy assignment
|
|
void operator=(const solidificationMeltingSource&) = delete;
|
|
|
|
|
|
public:
|
|
|
|
//- Runtime type information
|
|
TypeName("solidificationMeltingSource");
|
|
|
|
|
|
// Constructors
|
|
|
|
//- Construct from explicit source name and mesh
|
|
solidificationMeltingSource
|
|
(
|
|
const word& sourceName,
|
|
const word& modelType,
|
|
const dictionary& dict,
|
|
const fvMesh& mesh
|
|
);
|
|
|
|
|
|
//- Destructor
|
|
~solidificationMeltingSource() = default;
|
|
|
|
|
|
// Member Functions
|
|
|
|
//- Add explicit contribution to enthalpy equation
|
|
virtual void addSup(fvMatrix<scalar>& eqn, const label fieldi);
|
|
|
|
//- Add implicit contribution to momentum equation
|
|
virtual void addSup(fvMatrix<vector>& eqn, const label fieldi);
|
|
|
|
|
|
//- Add explicit contribution to compressible enthalpy equation
|
|
virtual void addSup
|
|
(
|
|
const volScalarField& rho,
|
|
fvMatrix<scalar>& eqn,
|
|
const label fieldi
|
|
);
|
|
|
|
//- Add implicit contribution to compressible momentum equation
|
|
virtual void addSup
|
|
(
|
|
const volScalarField& rho,
|
|
fvMatrix<vector>& eqn,
|
|
const label fieldi
|
|
);
|
|
|
|
|
|
//- Read source dictionary
|
|
virtual bool read(const dictionary& dict);
|
|
};
|
|
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
} // End namespace fv
|
|
} // End namespace Foam
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
#ifdef NoRepository
|
|
#include "solidificationMeltingSourceTemplates.C"
|
|
#endif
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
#endif
|
|
|
|
// ************************************************************************* //
|