Compare commits
4 Commits
feature-co
...
develop.mo
| Author | SHA1 | Date | |
|---|---|---|---|
| 8c9b0d9f1d | |||
| aad9dff0fb | |||
| 3154b7766d | |||
| 60840eb031 |
@ -49,10 +49,10 @@
|
|||||||
|
|
||||||
<!--
|
<!--
|
||||||
Providing details of your set-up can help us identify any issues, e.g.
|
Providing details of your set-up can help us identify any issues, e.g.
|
||||||
OpenFOAM version : v2406|v2312|v2306|v2212|v2206 etc
|
OpenFOAM version : v2312|v2306|v2212|v2206|v2112 etc
|
||||||
Operating system : ubuntu|openSUSE|RedHat etc
|
Operating system : ubuntu|openSUSE|centos etc
|
||||||
Hardware info : any info that may help?
|
Hardware info : any info that may help?
|
||||||
Compiler : gcc|clang etc
|
Compiler : gcc|intel|clang etc
|
||||||
-->
|
-->
|
||||||
|
|
||||||
- OpenFOAM version :
|
- OpenFOAM version :
|
||||||
|
|||||||
9
.gitmodules
vendored
9
.gitmodules
vendored
@ -1,8 +1,8 @@
|
|||||||
[submodule "cfmesh"]
|
[submodule "cfmesh"]
|
||||||
path = plugins/cfmesh
|
path = modules/cfmesh
|
||||||
url = https://develop.openfoam.com/Community/integration-cfmesh.git
|
url = https://develop.openfoam.com/Community/integration-cfmesh.git
|
||||||
[submodule "avalanche"]
|
[submodule "avalanche"]
|
||||||
path = plugins/avalanche
|
path = modules/avalanche
|
||||||
url = https://develop.openfoam.com/Community/avalanche.git
|
url = https://develop.openfoam.com/Community/avalanche.git
|
||||||
[submodule "adios"]
|
[submodule "adios"]
|
||||||
path = modules/adios
|
path = modules/adios
|
||||||
@ -18,8 +18,5 @@
|
|||||||
path = modules/external-solver
|
path = modules/external-solver
|
||||||
url = https://develop.openfoam.com/Modules/external-solver.git
|
url = https://develop.openfoam.com/Modules/external-solver.git
|
||||||
[submodule "turbulence-community"]
|
[submodule "turbulence-community"]
|
||||||
path = plugins/turbulence-community
|
path = modules/turbulence-community
|
||||||
url = https://gitlab.com/openfoam/community/tc-turbulence/turbulence-community.git
|
url = https://gitlab.com/openfoam/community/tc-turbulence/turbulence-community.git
|
||||||
[submodule "plugins/data-community"]
|
|
||||||
path = plugins/data-community
|
|
||||||
url = https://gitlab.com/openfoam/community/sig-data-modelling/data-community.git
|
|
||||||
|
|||||||
@ -9,7 +9,6 @@ It is likely incomplete...
|
|||||||
- Yu Ankun
|
- Yu Ankun
|
||||||
- Tetsuo Aoyagi
|
- Tetsuo Aoyagi
|
||||||
- Akira Azami
|
- Akira Azami
|
||||||
- Pete Bachant
|
|
||||||
- William Bainbridge
|
- William Bainbridge
|
||||||
- Gabriel Barajas
|
- Gabriel Barajas
|
||||||
- Kutalmis Bercin
|
- Kutalmis Bercin
|
||||||
@ -47,7 +46,6 @@ It is likely incomplete...
|
|||||||
- Victor Olesen
|
- Victor Olesen
|
||||||
- Evangelos Papoutsis-Kiachagias
|
- Evangelos Papoutsis-Kiachagias
|
||||||
- Juho Peltola
|
- Juho Peltola
|
||||||
- Josep Pocurull
|
|
||||||
- Johan Roenby
|
- Johan Roenby
|
||||||
- Henrik Rusche
|
- Henrik Rusche
|
||||||
- Bruno Santos
|
- Bruno Santos
|
||||||
|
|||||||
@ -1,2 +1,2 @@
|
|||||||
api=2406
|
api=2310
|
||||||
patch=0
|
patch=0
|
||||||
|
|||||||
16
README.md
16
README.md
@ -40,9 +40,9 @@ Violations of the Trademark are monitored, and will be duly prosecuted.
|
|||||||
|
|
||||||
If OpenFOAM has already been compiled on your system, simply source
|
If OpenFOAM has already been compiled on your system, simply source
|
||||||
the appropriate `etc/bashrc` or `etc/cshrc` file and get started.
|
the appropriate `etc/bashrc` or `etc/cshrc` file and get started.
|
||||||
For example, for the OpenFOAM-v2406 version:
|
For example, for the OpenFOAM-v2312 version:
|
||||||
```
|
```
|
||||||
source /installation/path/OpenFOAM-v2406/etc/bashrc
|
source /installation/path/OpenFOAM-v2312/etc/bashrc
|
||||||
```
|
```
|
||||||
|
|
||||||
## Compiling OpenFOAM
|
## Compiling OpenFOAM
|
||||||
@ -127,8 +127,8 @@ These 3rd-party sources are normally located in a directory parallel
|
|||||||
to the OpenFOAM directory. For example,
|
to the OpenFOAM directory. For example,
|
||||||
```
|
```
|
||||||
/path/parent
|
/path/parent
|
||||||
|-- OpenFOAM-v2406
|
|-- OpenFOAM-v2312
|
||||||
\-- ThirdParty-v2406
|
\-- ThirdParty-v2312
|
||||||
```
|
```
|
||||||
There are, however, many cases where this simple convention is inadequate:
|
There are, however, many cases where this simple convention is inadequate:
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ There are, however, many cases where this simple convention is inadequate:
|
|||||||
operating system or cluster installation provides it)
|
operating system or cluster installation provides it)
|
||||||
|
|
||||||
* When we have changed the OpenFOAM directory name to some arbitrary
|
* When we have changed the OpenFOAM directory name to some arbitrary
|
||||||
directory name, e.g. openfoam-sandbox2406, etc..
|
directory name, e.g. openfoam-sandbox2312, etc..
|
||||||
|
|
||||||
* When we would like any additional 3rd party software to be located
|
* When we would like any additional 3rd party software to be located
|
||||||
inside of the OpenFOAM directory to ensure that the installation is
|
inside of the OpenFOAM directory to ensure that the installation is
|
||||||
@ -156,9 +156,9 @@ when locating the ThirdParty directory with the following precedence:
|
|||||||
2. PREFIX/ThirdParty-VERSION
|
2. PREFIX/ThirdParty-VERSION
|
||||||
* this corresponds to the traditional approach
|
* this corresponds to the traditional approach
|
||||||
3. PREFIX/ThirdParty-vAPI
|
3. PREFIX/ThirdParty-vAPI
|
||||||
* allows for an updated value of VERSION, *eg*, `v2406-myCustom`,
|
* allows for an updated value of VERSION, *eg*, `v2312-myCustom`,
|
||||||
without requiring a renamed ThirdParty. The API value would still
|
without requiring a renamed ThirdParty. The API value would still
|
||||||
be `2406` and the original `ThirdParty-v2406/` would be found.
|
be `2312` and the original `ThirdParty-v2312/` would be found.
|
||||||
4. PREFIX/ThirdParty-API
|
4. PREFIX/ThirdParty-API
|
||||||
* same as the previous example, but using an unadorned API value.
|
* same as the previous example, but using an unadorned API value.
|
||||||
5. PREFIX/ThirdParty-common
|
5. PREFIX/ThirdParty-common
|
||||||
@ -213,4 +213,4 @@ ThirdParty directory will contain either an `Allwmake` file or a
|
|||||||
- [Governance](http://www.openfoam.com/governance/), [Governance Projects](https://www.openfoam.com/governance/projects)
|
- [Governance](http://www.openfoam.com/governance/), [Governance Projects](https://www.openfoam.com/governance/projects)
|
||||||
- [Contacting OpenCFD](http://www.openfoam.com/contact/)
|
- [Contacting OpenCFD](http://www.openfoam.com/contact/)
|
||||||
|
|
||||||
Copyright 2016-2024 OpenCFD Ltd
|
Copyright 2016-2023 OpenCFD Ltd
|
||||||
|
|||||||
@ -6,7 +6,6 @@
|
|||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2011-2016 OpenFOAM Foundation
|
Copyright (C) 2011-2016 OpenFOAM Foundation
|
||||||
Copyright (C) 2023 OpenCFD Ltd.
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -94,14 +93,24 @@ Foam::PDRDragModels::basic::~basic()
|
|||||||
|
|
||||||
Foam::tmp<Foam::volSymmTensorField> Foam::PDRDragModels::basic::Dcu() const
|
Foam::tmp<Foam::volSymmTensorField> Foam::PDRDragModels::basic::Dcu() const
|
||||||
{
|
{
|
||||||
auto tDragDcu = volSymmTensorField::New
|
tmp<volSymmTensorField> tDragDcu
|
||||||
(
|
(
|
||||||
"tDragDcu",
|
new volSymmTensorField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
U_.mesh(),
|
IOobject
|
||||||
dimensionedSymmTensor(dimMass/dimTime/dimVolume, Zero)
|
(
|
||||||
|
"tDragDcu",
|
||||||
|
U_.mesh().time().constant(),
|
||||||
|
U_.mesh(),
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
U_.mesh(),
|
||||||
|
dimensionedSymmTensor(dimMass/dimTime/dimVolume, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& DragDcu = tDragDcu.ref();
|
|
||||||
|
volSymmTensorField& DragDcu = tDragDcu.ref();
|
||||||
|
|
||||||
if (on_)
|
if (on_)
|
||||||
{
|
{
|
||||||
@ -118,14 +127,24 @@ Foam::tmp<Foam::volSymmTensorField> Foam::PDRDragModels::basic::Dcu() const
|
|||||||
|
|
||||||
Foam::tmp<Foam::volScalarField> Foam::PDRDragModels::basic::Gk() const
|
Foam::tmp<Foam::volScalarField> Foam::PDRDragModels::basic::Gk() const
|
||||||
{
|
{
|
||||||
auto tGk = volScalarField::New
|
tmp<volScalarField> tGk
|
||||||
(
|
(
|
||||||
"tGk",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
U_.mesh(),
|
IOobject
|
||||||
dimensionedScalar(dimMass/dimLength/pow3(dimTime), Zero)
|
(
|
||||||
|
"tGk",
|
||||||
|
U_.mesh().time().constant(),
|
||||||
|
U_.mesh(),
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
U_.mesh(),
|
||||||
|
dimensionedScalar(dimMass/dimLength/pow3(dimTime), Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& Gk = tGk.ref();
|
|
||||||
|
volScalarField& Gk = tGk.ref();
|
||||||
|
|
||||||
if (on_)
|
if (on_)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -69,8 +69,7 @@ Foam::XiEqModels::Gulder::~Gulder()
|
|||||||
Foam::tmp<Foam::volScalarField> Foam::XiEqModels::Gulder::XiEq() const
|
Foam::tmp<Foam::volScalarField> Foam::XiEqModels::Gulder::XiEq() const
|
||||||
{
|
{
|
||||||
volScalarField up(sqrt((2.0/3.0)*turbulence_.k()));
|
volScalarField up(sqrt((2.0/3.0)*turbulence_.k()));
|
||||||
const tmp<volScalarField> tepsilon(turbulence_.epsilon());
|
const volScalarField& epsilon = turbulence_.epsilon();
|
||||||
const volScalarField& epsilon = tepsilon();
|
|
||||||
|
|
||||||
if (subGridSchelkin_)
|
if (subGridSchelkin_)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -6,7 +6,6 @@
|
|||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2011-2016 OpenFOAM Foundation
|
Copyright (C) 2011-2016 OpenFOAM Foundation
|
||||||
Copyright (C) 2023 OpenCFD Ltd.
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -76,10 +75,8 @@ Foam::XiEqModels::SCOPEXiEq::~SCOPEXiEq()
|
|||||||
|
|
||||||
Foam::tmp<Foam::volScalarField> Foam::XiEqModels::SCOPEXiEq::XiEq() const
|
Foam::tmp<Foam::volScalarField> Foam::XiEqModels::SCOPEXiEq::XiEq() const
|
||||||
{
|
{
|
||||||
const tmp<volScalarField> tk(turbulence_.k());
|
const volScalarField& k = turbulence_.k();
|
||||||
const volScalarField& k = tk();
|
const volScalarField& epsilon = turbulence_.epsilon();
|
||||||
const tmp<volScalarField> tepsilon(turbulence_.epsilon());
|
|
||||||
const volScalarField& epsilon = tepsilon();
|
|
||||||
|
|
||||||
volScalarField up(sqrt((2.0/3.0)*k));
|
volScalarField up(sqrt((2.0/3.0)*k));
|
||||||
if (subGridSchelkin_)
|
if (subGridSchelkin_)
|
||||||
@ -94,14 +91,23 @@ Foam::tmp<Foam::volScalarField> Foam::XiEqModels::SCOPEXiEq::XiEq() const
|
|||||||
volScalarField K(0.157*upBySu/sqrt(Rl));
|
volScalarField K(0.157*upBySu/sqrt(Rl));
|
||||||
volScalarField Ma(MaModel.Ma());
|
volScalarField Ma(MaModel.Ma());
|
||||||
|
|
||||||
auto tXiEq = volScalarField::New
|
tmp<volScalarField> tXiEq
|
||||||
(
|
(
|
||||||
"XiEq",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
epsilon.mesh(),
|
IOobject
|
||||||
dimensionedScalar(dimless, Zero)
|
(
|
||||||
|
"XiEq",
|
||||||
|
epsilon.time().timeName(),
|
||||||
|
epsilon.db(),
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
epsilon.mesh(),
|
||||||
|
dimensionedScalar(dimless, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& xieq = tXiEq.ref();
|
volScalarField& xieq = tXiEq.ref();
|
||||||
|
|
||||||
forAll(xieq, celli)
|
forAll(xieq, celli)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -78,10 +78,11 @@ bool Foam::XiEqModel::read(const dictionary& XiEqProperties)
|
|||||||
void Foam::XiEqModel::writeFields() const
|
void Foam::XiEqModel::writeFields() const
|
||||||
{
|
{
|
||||||
//***HGW It is not clear why B is written here
|
//***HGW It is not clear why B is written here
|
||||||
const auto* B = Su_.mesh().cfindObject<volSymmTensorField>("B");
|
if (Su_.mesh().foundObject<volSymmTensorField>("B"))
|
||||||
if (B)
|
|
||||||
{
|
{
|
||||||
B->write();
|
const volSymmTensorField& B =
|
||||||
|
Su_.mesh().lookupObject<volSymmTensorField>("B");
|
||||||
|
B.write();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,26 +98,39 @@ Foam::XiEqModel::calculateSchelkinEffect(const scalar uPrimeCoef) const
|
|||||||
const volSymmTensorField& nsv =
|
const volSymmTensorField& nsv =
|
||||||
mesh.lookupObject<volSymmTensorField>("nsv");
|
mesh.lookupObject<volSymmTensorField>("nsv");
|
||||||
|
|
||||||
auto tN = volScalarField::New
|
tmp<volScalarField> tN
|
||||||
(
|
(
|
||||||
"tN",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh,
|
IOobject
|
||||||
dimensionedScalar(Nv.dimensions(), Zero)
|
(
|
||||||
|
"tN",
|
||||||
|
mesh.time().timeName(),
|
||||||
|
mesh,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE,
|
||||||
|
IOobject::NO_REGISTER
|
||||||
|
),
|
||||||
|
mesh,
|
||||||
|
dimensionedScalar(Nv.dimensions(), Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& N = tN.ref();
|
volScalarField& N = tN.ref();
|
||||||
|
|
||||||
N.primitiveFieldRef() = Nv.primitiveField()*pow(mesh.V(), 2.0/3.0);
|
N.primitiveFieldRef() = Nv.primitiveField()*pow(mesh.V(), 2.0/3.0);
|
||||||
|
|
||||||
auto tns = volSymmTensorField::New
|
volSymmTensorField ns
|
||||||
(
|
(
|
||||||
"tns",
|
IOobject
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
|
"tns",
|
||||||
|
mesh.time().timeName(),
|
||||||
|
mesh,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedSymmTensor(nsv.dimensions(), Zero)
|
dimensionedSymmTensor(nsv.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
auto& ns = tns.ref();
|
|
||||||
|
|
||||||
ns.primitiveFieldRef() = nsv.primitiveField()*pow(mesh.V(), 2.0/3.0);
|
ns.primitiveFieldRef() = nsv.primitiveField()*pow(mesh.V(), 2.0/3.0);
|
||||||
|
|
||||||
const volVectorField Uhat
|
const volVectorField Uhat
|
||||||
|
|||||||
@ -66,8 +66,7 @@ Foam::XiGModels::KTS::~KTS()
|
|||||||
Foam::tmp<Foam::volScalarField> Foam::XiGModels::KTS::G() const
|
Foam::tmp<Foam::volScalarField> Foam::XiGModels::KTS::G() const
|
||||||
{
|
{
|
||||||
volScalarField up(sqrt((2.0/3.0)*turbulence_.k()));
|
volScalarField up(sqrt((2.0/3.0)*turbulence_.k()));
|
||||||
const tmp<volScalarField> tepsilon(turbulence_.epsilon());
|
const volScalarField& epsilon = turbulence_.epsilon();
|
||||||
const volScalarField& epsilon = tepsilon();
|
|
||||||
|
|
||||||
volScalarField tauEta(sqrt(mag(thermo_.muu()/(thermo_.rhou()*epsilon))));
|
volScalarField tauEta(sqrt(mag(thermo_.muu()/(thermo_.rhou()*epsilon))));
|
||||||
|
|
||||||
|
|||||||
@ -6,7 +6,6 @@
|
|||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2011-2017 OpenFOAM Foundation
|
Copyright (C) 2011-2017 OpenFOAM Foundation
|
||||||
Copyright (C) 2023 OpenCFD Ltd.
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -256,14 +255,24 @@ Foam::tmp<Foam::volScalarField> Foam::laminarFlameSpeedModels::SCOPE::Su0pTphi
|
|||||||
scalar phi
|
scalar phi
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
auto tSu0 = volScalarField::New
|
tmp<volScalarField> tSu0
|
||||||
(
|
(
|
||||||
"Su0",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
p.mesh(),
|
IOobject
|
||||||
dimensionedScalar(dimVelocity, Zero)
|
(
|
||||||
|
"Su0",
|
||||||
|
p.time().timeName(),
|
||||||
|
p.db(),
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
p.mesh(),
|
||||||
|
dimensionedScalar(dimVelocity, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& Su0 = tSu0.ref();
|
|
||||||
|
volScalarField& Su0 = tSu0.ref();
|
||||||
|
|
||||||
forAll(Su0, celli)
|
forAll(Su0, celli)
|
||||||
{
|
{
|
||||||
@ -295,14 +304,24 @@ Foam::tmp<Foam::volScalarField> Foam::laminarFlameSpeedModels::SCOPE::Su0pTphi
|
|||||||
const volScalarField& phi
|
const volScalarField& phi
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
auto tSu0 = volScalarField::New
|
tmp<volScalarField> tSu0
|
||||||
(
|
(
|
||||||
"Su0",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
p.mesh(),
|
IOobject
|
||||||
dimensionedScalar(dimVelocity, Zero)
|
(
|
||||||
|
"Su0",
|
||||||
|
p.time().timeName(),
|
||||||
|
p.db(),
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
p.mesh(),
|
||||||
|
dimensionedScalar(dimVelocity, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& Su0 = tSu0.ref();
|
|
||||||
|
volScalarField& Su0 = tSu0.ref();
|
||||||
|
|
||||||
forAll(Su0, celli)
|
forAll(Su0, celli)
|
||||||
{
|
{
|
||||||
@ -339,14 +358,24 @@ Foam::tmp<Foam::volScalarField> Foam::laminarFlameSpeedModels::SCOPE::Ma
|
|||||||
const volScalarField& phi
|
const volScalarField& phi
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
auto tMa = volScalarField::New
|
tmp<volScalarField> tMa
|
||||||
(
|
(
|
||||||
"Ma",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
phi.mesh(),
|
IOobject
|
||||||
dimensionedScalar(dimless, Zero)
|
(
|
||||||
|
"Ma",
|
||||||
|
phi.time().timeName(),
|
||||||
|
phi.db(),
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
phi.mesh(),
|
||||||
|
dimensionedScalar(dimless, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& ma = tMa.ref();
|
|
||||||
|
volScalarField& ma = tMa.ref();
|
||||||
|
|
||||||
forAll(ma, celli)
|
forAll(ma, celli)
|
||||||
{
|
{
|
||||||
@ -389,12 +418,21 @@ Foam::laminarFlameSpeedModels::SCOPE::Ma() const
|
|||||||
{
|
{
|
||||||
const fvMesh& mesh = psiuReactionThermo_.p().mesh();
|
const fvMesh& mesh = psiuReactionThermo_.p().mesh();
|
||||||
|
|
||||||
return volScalarField::New
|
return tmp<volScalarField>
|
||||||
(
|
(
|
||||||
"Ma",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh,
|
IOobject
|
||||||
dimensionedScalar("Ma", dimless, Ma(equivalenceRatio_))
|
(
|
||||||
|
"Ma",
|
||||||
|
mesh.time().timeName(),
|
||||||
|
mesh,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
mesh,
|
||||||
|
dimensionedScalar("Ma", dimless, Ma(equivalenceRatio_))
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -10,8 +10,7 @@ if (pimple.dict().getOrDefault("hydrostaticInitialization", false))
|
|||||||
"0",
|
"0",
|
||||||
mesh,
|
mesh,
|
||||||
IOobject::MUST_READ,
|
IOobject::MUST_READ,
|
||||||
IOobject::NO_WRITE,
|
IOobject::NO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
),
|
),
|
||||||
mesh
|
mesh
|
||||||
)
|
)
|
||||||
|
|||||||
@ -21,11 +21,6 @@
|
|||||||
+ fvOptions(rho, he)
|
+ fvOptions(rho, he)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (MRF.active())
|
|
||||||
{
|
|
||||||
EEqn += fvc::div(MRF.phi(), p);
|
|
||||||
}
|
|
||||||
|
|
||||||
EEqn.relax();
|
EEqn.relax();
|
||||||
|
|
||||||
fvOptions.constrain(EEqn);
|
fvOptions.constrain(EEqn);
|
||||||
|
|||||||
@ -110,6 +110,15 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchScalarField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new smoluchowskiJumpTFvPatchScalarField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
smoluchowskiJumpTFvPatchScalarField
|
smoluchowskiJumpTFvPatchScalarField
|
||||||
(
|
(
|
||||||
@ -117,22 +126,18 @@ public:
|
|||||||
const DimensionedField<scalar, volMesh>&
|
const DimensionedField<scalar, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<scalar>> clone() const
|
virtual tmp<fvPatchScalarField> clone
|
||||||
{
|
|
||||||
return fvPatchField<scalar>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<scalar>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<scalar, volMesh>& iF
|
const DimensionedField<scalar, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<scalar>::Clone(*this, iF);
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new smoluchowskiJumpTFvPatchScalarField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Mapping functions
|
// Mapping functions
|
||||||
|
|
||||||
//- Map (and resize as needed) from self given a mapping object
|
//- Map (and resize as needed) from self given a mapping object
|
||||||
|
|||||||
@ -118,6 +118,15 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchVectorField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new maxwellSlipUFvPatchVectorField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
maxwellSlipUFvPatchVectorField
|
maxwellSlipUFvPatchVectorField
|
||||||
(
|
(
|
||||||
@ -125,19 +134,16 @@ public:
|
|||||||
const DimensionedField<vector, volMesh>&
|
const DimensionedField<vector, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<vector>> clone() const
|
virtual tmp<fvPatchVectorField> clone
|
||||||
{
|
|
||||||
return fvPatchField<vector>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<vector>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<vector, volMesh>& iF
|
const DimensionedField<vector, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<vector>::Clone(*this, iF);
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new maxwellSlipUFvPatchVectorField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -135,6 +135,15 @@ public:
|
|||||||
const fixedRhoFvPatchScalarField&
|
const fixedRhoFvPatchScalarField&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchScalarField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new fixedRhoFvPatchScalarField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
fixedRhoFvPatchScalarField
|
fixedRhoFvPatchScalarField
|
||||||
(
|
(
|
||||||
@ -142,19 +151,16 @@ public:
|
|||||||
const DimensionedField<scalar, volMesh>&
|
const DimensionedField<scalar, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<scalar>> clone() const
|
virtual tmp<fvPatchScalarField> clone
|
||||||
{
|
|
||||||
return fvPatchField<scalar>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<scalar>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<scalar, volMesh>& iF
|
const DimensionedField<scalar, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<scalar>::Clone(*this, iF);
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new fixedRhoFvPatchScalarField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -1,9 +1,10 @@
|
|||||||
volScalarField& p = thermo.p();
|
volScalarField& p = thermo.p();
|
||||||
const volScalarField& T = thermo.T();
|
const volScalarField& T = thermo.T();
|
||||||
const volScalarField& psi = thermo.psi();
|
const volScalarField& psi = thermo.psi();
|
||||||
|
const volScalarField& mu = thermo.mu();
|
||||||
|
|
||||||
bool inviscid(true);
|
bool inviscid(true);
|
||||||
if (max(thermo.mu().cref().primitiveField()) > 0.0)
|
if (max(mu.primitiveField()) > 0.0)
|
||||||
{
|
{
|
||||||
inviscid = false;
|
inviscid = false;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -20,11 +20,6 @@
|
|||||||
fvOptions(rho, he)
|
fvOptions(rho, he)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (MRF.active())
|
|
||||||
{
|
|
||||||
EEqn += fvc::div(MRF.phi(), p);
|
|
||||||
}
|
|
||||||
|
|
||||||
EEqn.relax();
|
EEqn.relax();
|
||||||
|
|
||||||
fvOptions.constrain(EEqn);
|
fvOptions.constrain(EEqn);
|
||||||
|
|||||||
@ -14,11 +14,6 @@
|
|||||||
fvOptions(rho, he)
|
fvOptions(rho, he)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (MRF.active())
|
|
||||||
{
|
|
||||||
EEqn += fvc::div(MRF.phi(), p);
|
|
||||||
}
|
|
||||||
|
|
||||||
EEqn.relax();
|
EEqn.relax();
|
||||||
|
|
||||||
fvOptions.constrain(EEqn);
|
fvOptions.constrain(EEqn);
|
||||||
|
|||||||
@ -9,11 +9,6 @@
|
|||||||
fvOptions(rho, e)
|
fvOptions(rho, e)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (MRF.active())
|
|
||||||
{
|
|
||||||
EEqn += fvc::div(MRF.phi(), p);
|
|
||||||
}
|
|
||||||
|
|
||||||
EEqn.relax();
|
EEqn.relax();
|
||||||
|
|
||||||
fvOptions.constrain(EEqn);
|
fvOptions.constrain(EEqn);
|
||||||
|
|||||||
@ -196,6 +196,18 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchScalarField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new turbulentTemperatureTwoPhaseRadCoupledMixedFvPatchScalarField
|
||||||
|
(
|
||||||
|
*this
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
turbulentTemperatureTwoPhaseRadCoupledMixedFvPatchScalarField
|
turbulentTemperatureTwoPhaseRadCoupledMixedFvPatchScalarField
|
||||||
(
|
(
|
||||||
@ -203,19 +215,20 @@ public:
|
|||||||
const DimensionedField<scalar, volMesh>&
|
const DimensionedField<scalar, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<scalar>> clone() const
|
virtual tmp<fvPatchScalarField> clone
|
||||||
{
|
|
||||||
return fvPatchField<scalar>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<scalar>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<scalar, volMesh>& iF
|
const DimensionedField<scalar, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<scalar>::Clone(*this, iF);
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new turbulentTemperatureTwoPhaseRadCoupledMixedFvPatchScalarField
|
||||||
|
(
|
||||||
|
*this,
|
||||||
|
iF
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -43,8 +43,6 @@ Description
|
|||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
#include "postProcess.H"
|
|
||||||
|
|
||||||
#include "setRootCase.H"
|
#include "setRootCase.H"
|
||||||
#include "createTime.H"
|
#include "createTime.H"
|
||||||
#include "createMesh.H"
|
#include "createMesh.H"
|
||||||
@ -66,13 +64,13 @@ int main(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
// Solve all primal equations
|
// Solve all primal equations
|
||||||
om.solvePrimalEquations();
|
om.solvePrimalEquations();
|
||||||
|
|
||||||
// Clear sensitivities
|
|
||||||
om.clearSensitivities();
|
|
||||||
|
|
||||||
// Solve all adjoint equations
|
|
||||||
om.solveAdjointEquations();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update primal-based quantities of the adjoint solvers
|
||||||
|
om.updatePrimalBasedQuantities();
|
||||||
|
|
||||||
|
// Solve all adjoint equations
|
||||||
|
om.solveAdjointEquations();
|
||||||
}
|
}
|
||||||
|
|
||||||
Info<< "End\n" << endl;
|
Info<< "End\n" << endl;
|
||||||
|
|||||||
@ -85,6 +85,15 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchScalarField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new adjointOutletPressureFvPatchScalarField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
adjointOutletPressureFvPatchScalarField
|
adjointOutletPressureFvPatchScalarField
|
||||||
(
|
(
|
||||||
@ -92,19 +101,16 @@ public:
|
|||||||
const DimensionedField<scalar, volMesh>&
|
const DimensionedField<scalar, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<scalar>> clone() const
|
virtual tmp<fvPatchScalarField> clone
|
||||||
{
|
|
||||||
return fvPatchField<scalar>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<scalar>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<scalar, volMesh>& iF
|
const DimensionedField<scalar, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<scalar>::Clone(*this, iF);
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new adjointOutletPressureFvPatchScalarField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -85,6 +85,15 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchVectorField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new adjointOutletVelocityFvPatchVectorField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
adjointOutletVelocityFvPatchVectorField
|
adjointOutletVelocityFvPatchVectorField
|
||||||
(
|
(
|
||||||
@ -92,19 +101,16 @@ public:
|
|||||||
const DimensionedField<vector, volMesh>&
|
const DimensionedField<vector, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<vector>> clone() const
|
virtual tmp<fvPatchVectorField> clone
|
||||||
{
|
|
||||||
return fvPatchField<vector>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<vector>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<vector, volMesh>& iF
|
const DimensionedField<vector, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<vector>::Clone(*this, iF);
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new adjointOutletVelocityFvPatchVectorField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,12 @@ if (nAlphaSubCycles > 1)
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -3,7 +3,12 @@ if (nAlphaSubCycles > 1)
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -4,19 +4,26 @@ if (nAlphaSubCycles > 1)
|
|||||||
{
|
{
|
||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
|
|
||||||
talphaPhi1.reset
|
talphaPhi1 = new surfaceScalarField
|
||||||
(
|
(
|
||||||
new surfaceScalarField
|
IOobject
|
||||||
(
|
(
|
||||||
mesh.newIOobject("alphaPhi1"),
|
"alphaPhi1",
|
||||||
mesh,
|
runTime.timeName(),
|
||||||
dimensionedScalar(alphaPhi10.dimensions(), Zero)
|
mesh
|
||||||
)
|
),
|
||||||
|
mesh,
|
||||||
|
dimensionedScalar(alphaPhi10.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -160,8 +160,7 @@ void VoFPatchTransfer::correct
|
|||||||
const volScalarField& heVoF = thermo.thermo1().he();
|
const volScalarField& heVoF = thermo.thermo1().he();
|
||||||
const volScalarField& TVoF = thermo.thermo1().T();
|
const volScalarField& TVoF = thermo.thermo1().T();
|
||||||
const volScalarField CpVoF(thermo.thermo1().Cp());
|
const volScalarField CpVoF(thermo.thermo1().Cp());
|
||||||
const tmp<volScalarField> trhoVoF(thermo.thermo1().rho());
|
const volScalarField& rhoVoF = thermo.thermo1().rho()();
|
||||||
const volScalarField& rhoVoF = trhoVoF();
|
|
||||||
const volScalarField& alphaVoF = thermo.alpha1();
|
const volScalarField& alphaVoF = thermo.alpha1();
|
||||||
|
|
||||||
forAll(patchIDs_, pidi)
|
forAll(patchIDs_, pidi)
|
||||||
|
|||||||
@ -13,19 +13,26 @@ if (nAlphaSubCycles > 1)
|
|||||||
{
|
{
|
||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
|
|
||||||
talphaPhi1.reset
|
talphaPhi1 = new surfaceScalarField
|
||||||
(
|
(
|
||||||
new surfaceScalarField
|
IOobject
|
||||||
(
|
(
|
||||||
mesh.newIOobject("alphaPhi1"),
|
"alphaPhi1",
|
||||||
mesh,
|
runTime.timeName(),
|
||||||
dimensionedScalar(alphaPhi10.dimensions(), Zero)
|
mesh
|
||||||
)
|
),
|
||||||
|
mesh,
|
||||||
|
dimensionedScalar(alphaPhi10.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -135,14 +135,14 @@ public:
|
|||||||
virtual volScalarField& he()
|
virtual volScalarField& he()
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return const_cast<volScalarField&>(volScalarField::null());
|
return thermo1_->he();
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Enthalpy/Internal energy [J/kg]
|
//- Enthalpy/Internal energy [J/kg]
|
||||||
virtual const volScalarField& he() const
|
virtual const volScalarField& he() const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return volScalarField::null();
|
return thermo1_->he();
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Enthalpy/Internal energy
|
//- Enthalpy/Internal energy
|
||||||
@ -213,7 +213,7 @@ public:
|
|||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return nullptr;
|
return tmp<scalarField>::New(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Heat capacity at constant volume [J/kg/K]
|
//- Heat capacity at constant volume [J/kg/K]
|
||||||
@ -236,7 +236,7 @@ public:
|
|||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return nullptr;
|
return tmp<scalarField>::New(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Gamma = Cp/Cv []
|
//- Gamma = Cp/Cv []
|
||||||
|
|||||||
@ -164,6 +164,15 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchScalarField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new alphaContactAngleFvPatchScalarField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
alphaContactAngleFvPatchScalarField
|
alphaContactAngleFvPatchScalarField
|
||||||
(
|
(
|
||||||
@ -171,19 +180,16 @@ public:
|
|||||||
const DimensionedField<scalar, volMesh>&
|
const DimensionedField<scalar, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<scalar>> clone() const
|
virtual tmp<fvPatchScalarField> clone
|
||||||
{
|
|
||||||
return fvPatchField<scalar>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<scalar>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<scalar, volMesh>& iF
|
const DimensionedField<scalar, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<scalar>::Clone(*this, iF);
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new alphaContactAngleFvPatchScalarField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -99,8 +99,7 @@ Foam::multiphaseMixtureThermo::multiphaseMixtureThermo
|
|||||||
mesh_.time().timeName(),
|
mesh_.time().timeName(),
|
||||||
mesh_,
|
mesh_,
|
||||||
IOobject::NO_READ,
|
IOobject::NO_READ,
|
||||||
IOobject::AUTO_WRITE,
|
IOobject::AUTO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
),
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(dimless, Zero)
|
dimensionedScalar(dimless, Zero)
|
||||||
@ -999,12 +998,19 @@ Foam::tmp<Foam::volScalarField> Foam::multiphaseMixtureThermo::K
|
|||||||
Foam::tmp<Foam::volScalarField>
|
Foam::tmp<Foam::volScalarField>
|
||||||
Foam::multiphaseMixtureThermo::nearInterface() const
|
Foam::multiphaseMixtureThermo::nearInterface() const
|
||||||
{
|
{
|
||||||
auto tnearInt = volScalarField::New
|
tmp<volScalarField> tnearInt
|
||||||
(
|
(
|
||||||
"nearInterface",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar(dimless, Zero)
|
(
|
||||||
|
"nearInterface",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar(dimless, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
for (const phaseModel& phase : phases_)
|
for (const phaseModel& phase : phases_)
|
||||||
|
|||||||
@ -243,14 +243,14 @@ public:
|
|||||||
virtual volScalarField& he()
|
virtual volScalarField& he()
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return const_cast<volScalarField&>(volScalarField::null());
|
return phases_[0].thermo().he();
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Enthalpy/Internal energy [J/kg]
|
//- Enthalpy/Internal energy [J/kg]
|
||||||
virtual const volScalarField& he() const
|
virtual const volScalarField& he() const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return volScalarField::null();
|
return phases_[0].thermo().he();
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Enthalpy/Internal energy
|
//- Enthalpy/Internal energy
|
||||||
@ -327,7 +327,7 @@ public:
|
|||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return nullptr;
|
return tmp<scalarField>::New(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Heat capacity at constant volume [J/kg/K]
|
//- Heat capacity at constant volume [J/kg/K]
|
||||||
@ -350,7 +350,7 @@ public:
|
|||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return nullptr;
|
return tmp<scalarField>::New(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Gamma = Cp/Cv []
|
//- Gamma = Cp/Cv []
|
||||||
|
|||||||
@ -28,8 +28,7 @@
|
|||||||
forAllConstIters(mixture.phases(), phase)
|
forAllConstIters(mixture.phases(), phase)
|
||||||
{
|
{
|
||||||
const rhoThermo& thermo = phase().thermo();
|
const rhoThermo& thermo = phase().thermo();
|
||||||
const tmp<volScalarField> trho(thermo.rho());
|
const volScalarField& rho = thermo.rho()();
|
||||||
const volScalarField& rho = trho();
|
|
||||||
|
|
||||||
p_rghEqnComps.set
|
p_rghEqnComps.set
|
||||||
(
|
(
|
||||||
|
|||||||
@ -18,7 +18,12 @@
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField alphaPhiSum
|
surfaceScalarField alphaPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("alphaPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"alphaPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(phi.dimensions(), Zero)
|
dimensionedScalar(phi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -158,11 +158,13 @@ Foam::tmp<Foam::volSymmTensorField> Foam::relativeVelocityModel::tauDm() const
|
|||||||
// Calculate the relative velocity of the continuous phase w.r.t the mean
|
// Calculate the relative velocity of the continuous phase w.r.t the mean
|
||||||
volVectorField Ucm(betad*Udm_/betac);
|
volVectorField Ucm(betad*Udm_/betac);
|
||||||
|
|
||||||
return volSymmTensorField::New
|
return tmp<volSymmTensorField>
|
||||||
(
|
(
|
||||||
"tauDm",
|
new volSymmTensorField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
betad*sqr(Udm_) + betac*sqr(Ucm)
|
"tauDm",
|
||||||
|
betad*sqr(Udm_) + betac*sqr(Ucm)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -130,17 +130,10 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#include "UEqn.H"
|
||||||
#include "YEqns.H"
|
#include "YEqns.H"
|
||||||
#include "TEqn.H"
|
#include "TEqn.H"
|
||||||
|
|
||||||
if (pimple.frozenFlow())
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "UEqn.H"
|
|
||||||
|
|
||||||
// --- Pressure corrector loop
|
// --- Pressure corrector loop
|
||||||
while (pimple.correct())
|
while (pimple.correct())
|
||||||
{
|
{
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
\\ / A nd | www.openfoam.com
|
\\ / A nd | www.openfoam.com
|
||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2017-2024 OpenCFD Ltd
|
Copyright (C) 2017-2019 OpenCFD Ltd
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -206,13 +206,9 @@ public:
|
|||||||
//- Construct as copy
|
//- Construct as copy
|
||||||
DTRMParticle(const DTRMParticle& p);
|
DTRMParticle(const DTRMParticle& p);
|
||||||
|
|
||||||
//- Return a clone
|
|
||||||
virtual autoPtr<particle> clone() const
|
|
||||||
{
|
|
||||||
return particle::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Factory class to read-construct particles (for parallel transfer)
|
//- Factory class to read-construct particles used for
|
||||||
|
// parallel transfer
|
||||||
class iNew
|
class iNew
|
||||||
{
|
{
|
||||||
const polyMesh& mesh_;
|
const polyMesh& mesh_;
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
\\ / A nd | www.openfoam.com
|
\\ / A nd | www.openfoam.com
|
||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2017-2023 OpenCFD Ltd.
|
Copyright (C) 2017-2022 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -407,8 +407,7 @@ Foam::radiation::laserDTRM::laserDTRM(const volScalarField& T)
|
|||||||
mesh_.time().timeName(),
|
mesh_.time().timeName(),
|
||||||
mesh_,
|
mesh_,
|
||||||
IOobject::NO_READ,
|
IOobject::NO_READ,
|
||||||
IOobject::AUTO_WRITE,
|
IOobject::AUTO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
),
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(dimPower/dimVolume, Zero)
|
dimensionedScalar(dimPower/dimVolume, Zero)
|
||||||
@ -505,8 +504,7 @@ Foam::radiation::laserDTRM::laserDTRM
|
|||||||
mesh_.time().timeName(),
|
mesh_.time().timeName(),
|
||||||
mesh_,
|
mesh_,
|
||||||
IOobject::NO_READ,
|
IOobject::NO_READ,
|
||||||
IOobject::AUTO_WRITE,
|
IOobject::AUTO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
),
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(dimPower/pow3(dimLength), Zero)
|
dimensionedScalar(dimPower/pow3(dimLength), Zero)
|
||||||
@ -537,23 +535,42 @@ Foam::label Foam::radiation::laserDTRM::nBands() const
|
|||||||
|
|
||||||
void Foam::radiation::laserDTRM::calculate()
|
void Foam::radiation::laserDTRM::calculate()
|
||||||
{
|
{
|
||||||
auto treflectingCells = volScalarField::New
|
tmp<volScalarField> treflectingCells
|
||||||
(
|
(
|
||||||
"reflectingCellsVol",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar("zero", dimless, -1)
|
(
|
||||||
|
"reflectingCellsVol",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar("zero", dimless, -1)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& reflectingCellsVol = treflectingCells.ref();
|
volScalarField& reflectingCellsVol = treflectingCells.ref();
|
||||||
|
|
||||||
auto tnHat = volVectorField::New
|
|
||||||
|
tmp<volVectorField> tnHat
|
||||||
(
|
(
|
||||||
"nHat",
|
new volVectorField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedVector(dimless, Zero)
|
(
|
||||||
|
"nHat",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedVector(dimless, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& nHat = tnHat.ref();
|
volVectorField& nHat = tnHat.ref();
|
||||||
|
|
||||||
|
|
||||||
// Reset the field
|
// Reset the field
|
||||||
@ -669,9 +686,9 @@ void Foam::radiation::laserDTRM::calculate()
|
|||||||
|
|
||||||
globalIndex::gatherInplaceOp(lines);
|
globalIndex::gatherInplaceOp(lines);
|
||||||
|
|
||||||
if (UPstream::master())
|
if (Pstream::master())
|
||||||
{
|
{
|
||||||
OBJstream os(type() + "-particlePath.obj");
|
OBJstream os(type() + ":particlePath.obj");
|
||||||
|
|
||||||
for (label pointi = 0; pointi < lines.size(); pointi += 2)
|
for (label pointi = 0; pointi < lines.size(); pointi += 2)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -88,14 +88,25 @@ Foam::radiation::localDensityAbsorptionEmission::localDensityAbsorptionEmission
|
|||||||
Foam::tmp<Foam::volScalarField>
|
Foam::tmp<Foam::volScalarField>
|
||||||
Foam::radiation::localDensityAbsorptionEmission::aCont(const label bandI) const
|
Foam::radiation::localDensityAbsorptionEmission::aCont(const label bandI) const
|
||||||
{
|
{
|
||||||
auto ta = volScalarField::New
|
tmp<volScalarField> ta
|
||||||
(
|
(
|
||||||
"a",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar(inv(dimLength), Zero)
|
(
|
||||||
|
"a",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE,
|
||||||
|
IOobject::NO_REGISTER
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar(inv(dimLength), Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& a = ta.ref();
|
|
||||||
|
volScalarField& a = ta.ref();
|
||||||
|
|
||||||
forAll(alphaNames_, i)
|
forAll(alphaNames_, i)
|
||||||
{
|
{
|
||||||
@ -110,14 +121,25 @@ Foam::radiation::localDensityAbsorptionEmission::aCont(const label bandI) const
|
|||||||
Foam::tmp<Foam::volScalarField>
|
Foam::tmp<Foam::volScalarField>
|
||||||
Foam::radiation::localDensityAbsorptionEmission::eCont(const label bandI) const
|
Foam::radiation::localDensityAbsorptionEmission::eCont(const label bandI) const
|
||||||
{
|
{
|
||||||
auto te = volScalarField::New
|
tmp<volScalarField> te
|
||||||
(
|
(
|
||||||
"e",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar(inv(dimLength), Zero)
|
(
|
||||||
|
"e",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE,
|
||||||
|
IOobject::NO_REGISTER
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar(inv(dimLength), Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
auto& e = te.ref();
|
|
||||||
|
volScalarField& e = te.ref();
|
||||||
|
|
||||||
forAll(alphaNames_, i)
|
forAll(alphaNames_, i)
|
||||||
{
|
{
|
||||||
@ -132,12 +154,22 @@ Foam::radiation::localDensityAbsorptionEmission::eCont(const label bandI) const
|
|||||||
Foam::tmp<Foam::volScalarField>
|
Foam::tmp<Foam::volScalarField>
|
||||||
Foam::radiation::localDensityAbsorptionEmission::ECont(const label bandI) const
|
Foam::radiation::localDensityAbsorptionEmission::ECont(const label bandI) const
|
||||||
{
|
{
|
||||||
auto tE = volScalarField::New
|
tmp<volScalarField> tE
|
||||||
(
|
(
|
||||||
"E",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar(dimMass/dimLength/pow3(dimTime), Zero)
|
(
|
||||||
|
"E",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE,
|
||||||
|
IOobject::NO_REGISTER
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar(dimMass/dimLength/pow3(dimTime), Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
scalarField& E = tE.ref().primitiveFieldRef();
|
scalarField& E = tE.ref().primitiveFieldRef();
|
||||||
|
|||||||
@ -171,8 +171,16 @@ Foam::temperaturePhaseChangeTwoPhaseMixtures::constant::TSource() const
|
|||||||
|
|
||||||
const volScalarField& T = mesh_.lookupObject<volScalarField>("T");
|
const volScalarField& T = mesh_.lookupObject<volScalarField>("T");
|
||||||
|
|
||||||
auto tTSource = tmp<fvScalarMatrix>::New(T, dimEnergy/dimTime);
|
tmp<fvScalarMatrix> tTSource
|
||||||
auto& TSource = tTSource.ref();
|
(
|
||||||
|
new fvScalarMatrix
|
||||||
|
(
|
||||||
|
T,
|
||||||
|
dimEnergy/dimTime
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
fvScalarMatrix& TSource = tTSource.ref();
|
||||||
|
|
||||||
const twoPhaseMixtureEThermo& thermo =
|
const twoPhaseMixtureEThermo& thermo =
|
||||||
refCast<const twoPhaseMixtureEThermo>
|
refCast<const twoPhaseMixtureEThermo>
|
||||||
|
|||||||
@ -382,7 +382,7 @@ Foam::tmp<Foam::volScalarField> Foam::twoPhaseMixtureEThermo::kappaEff
|
|||||||
const volScalarField& kappat
|
const volScalarField& kappat
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
tmp<volScalarField> kappaEff(kappa() + kappat);
|
tmp<Foam::volScalarField> kappaEff(kappa() + kappat);
|
||||||
kappaEff.ref().rename("kappaEff");
|
kappaEff.ref().rename("kappaEff");
|
||||||
return kappaEff;
|
return kappaEff;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -86,14 +86,14 @@ public:
|
|||||||
virtual volScalarField& he()
|
virtual volScalarField& he()
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return const_cast<volScalarField&>(volScalarField::null());
|
return p();
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Return access to the internal energy field [J/Kg]
|
//- Return access to the internal energy field [J/Kg]
|
||||||
virtual const volScalarField& he() const
|
virtual const volScalarField& he() const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return volScalarField::null();
|
return p();
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Enthalpy/Internal energy
|
//- Enthalpy/Internal energy
|
||||||
@ -182,7 +182,7 @@ public:
|
|||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return nullptr;
|
return tmp<scalarField>::New(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Return Cv of the mixture
|
//- Return Cv of the mixture
|
||||||
@ -205,7 +205,7 @@ public:
|
|||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
NotImplemented;
|
NotImplemented;
|
||||||
return nullptr;
|
return tmp<scalarField>::New(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//- Gamma = Cp/Cv []
|
//- Gamma = Cp/Cv []
|
||||||
|
|||||||
@ -3,7 +3,12 @@ if (nAlphaSubCycles > 1)
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -32,7 +32,12 @@ if (nAlphaSubCycles > 1)
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -21,7 +21,12 @@
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -50,8 +50,7 @@
|
|||||||
runTime.timeName(),
|
runTime.timeName(),
|
||||||
mesh,
|
mesh,
|
||||||
IOobject::NO_READ,
|
IOobject::NO_READ,
|
||||||
IOobject::AUTO_WRITE,
|
IOobject::AUTO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
),
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(dimVelocity*dimArea, Zero)
|
dimensionedScalar(dimVelocity*dimArea, Zero)
|
||||||
|
|||||||
@ -164,6 +164,15 @@ public:
|
|||||||
const fvPatchFieldMapper&
|
const fvPatchFieldMapper&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchScalarField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new alphaContactAngleFvPatchScalarField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
alphaContactAngleFvPatchScalarField
|
alphaContactAngleFvPatchScalarField
|
||||||
(
|
(
|
||||||
@ -171,19 +180,16 @@ public:
|
|||||||
const DimensionedField<scalar, volMesh>&
|
const DimensionedField<scalar, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<scalar>> clone() const
|
virtual tmp<fvPatchScalarField> clone
|
||||||
{
|
|
||||||
return fvPatchField<scalar>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<scalar>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<scalar, volMesh>& iF
|
const DimensionedField<scalar, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<scalar>::Clone(*this, iF);
|
return tmp<fvPatchScalarField>
|
||||||
|
(
|
||||||
|
new alphaContactAngleFvPatchScalarField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -68,9 +68,8 @@ Foam::multiphaseMixture::multiphaseMixture
|
|||||||
"transportProperties",
|
"transportProperties",
|
||||||
U.time().constant(),
|
U.time().constant(),
|
||||||
U.db(),
|
U.db(),
|
||||||
IOobject::READ_MODIFIED,
|
IOobject::MUST_READ_IF_MODIFIED,
|
||||||
IOobject::NO_WRITE,
|
IOobject::NO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|
||||||
@ -86,7 +85,9 @@ Foam::multiphaseMixture::multiphaseMixture
|
|||||||
(
|
(
|
||||||
"rhoPhi",
|
"rhoPhi",
|
||||||
mesh_.time().timeName(),
|
mesh_.time().timeName(),
|
||||||
mesh_
|
mesh_,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::NO_WRITE
|
||||||
),
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(dimMass/dimTime, Zero)
|
dimensionedScalar(dimMass/dimTime, Zero)
|
||||||
@ -100,8 +101,7 @@ Foam::multiphaseMixture::multiphaseMixture
|
|||||||
mesh_.time().timeName(),
|
mesh_.time().timeName(),
|
||||||
mesh_,
|
mesh_,
|
||||||
IOobject::NO_READ,
|
IOobject::NO_READ,
|
||||||
IOobject::AUTO_WRITE,
|
IOobject::AUTO_WRITE
|
||||||
IOobject::REGISTER
|
|
||||||
),
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(dimless, Zero)
|
dimensionedScalar(dimless, Zero)
|
||||||
@ -257,12 +257,19 @@ Foam::multiphaseMixture::nuf() const
|
|||||||
Foam::tmp<Foam::surfaceScalarField>
|
Foam::tmp<Foam::surfaceScalarField>
|
||||||
Foam::multiphaseMixture::surfaceTensionForce() const
|
Foam::multiphaseMixture::surfaceTensionForce() const
|
||||||
{
|
{
|
||||||
auto tstf = surfaceScalarField::New
|
tmp<surfaceScalarField> tstf
|
||||||
(
|
(
|
||||||
"surfaceTensionForce",
|
new surfaceScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar(dimensionSet(1, -2, -2, 0, 0), Zero)
|
(
|
||||||
|
"surfaceTensionForce",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar(dimensionSet(1, -2, -2, 0, 0), Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
surfaceScalarField& stf = tstf.ref();
|
surfaceScalarField& stf = tstf.ref();
|
||||||
@ -317,7 +324,12 @@ void Foam::multiphaseMixture::solve()
|
|||||||
{
|
{
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh_.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh_
|
||||||
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(rhoPhi_.dimensions(), Zero)
|
dimensionedScalar(rhoPhi_.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
@ -540,12 +552,19 @@ Foam::tmp<Foam::volScalarField> Foam::multiphaseMixture::K
|
|||||||
Foam::tmp<Foam::volScalarField>
|
Foam::tmp<Foam::volScalarField>
|
||||||
Foam::multiphaseMixture::nearInterface() const
|
Foam::multiphaseMixture::nearInterface() const
|
||||||
{
|
{
|
||||||
auto tnearInt = volScalarField::New
|
tmp<volScalarField> tnearInt
|
||||||
(
|
(
|
||||||
"nearInterface",
|
new volScalarField
|
||||||
IOobject::NO_REGISTER,
|
(
|
||||||
mesh_,
|
IOobject
|
||||||
dimensionedScalar(dimless, Zero)
|
(
|
||||||
|
"nearInterface",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_
|
||||||
|
),
|
||||||
|
mesh_,
|
||||||
|
dimensionedScalar(dimless, Zero)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
for (const phase& ph : phases_)
|
for (const phase& ph : phases_)
|
||||||
@ -630,7 +649,12 @@ void Foam::multiphaseMixture::solveAlphas
|
|||||||
|
|
||||||
volScalarField sumAlpha
|
volScalarField sumAlpha
|
||||||
(
|
(
|
||||||
mesh_.newIOobject("sumAlpha"),
|
IOobject
|
||||||
|
(
|
||||||
|
"sumAlpha",
|
||||||
|
mesh_.time().timeName(),
|
||||||
|
mesh_
|
||||||
|
),
|
||||||
mesh_,
|
mesh_,
|
||||||
dimensionedScalar(dimless, Zero)
|
dimensionedScalar(dimless, Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -272,7 +272,10 @@ while (pimple.correct())
|
|||||||
).ptr()
|
).ptr()
|
||||||
);
|
);
|
||||||
|
|
||||||
pEqnComps[phasei].faceFluxCorrectionPtr(nullptr);
|
deleteDemandDrivenData
|
||||||
|
(
|
||||||
|
pEqnComps[phasei].faceFluxCorrectionPtr()
|
||||||
|
);
|
||||||
|
|
||||||
pEqnComps[phasei].relax();
|
pEqnComps[phasei].relax();
|
||||||
}
|
}
|
||||||
|
|||||||
@ -5,7 +5,12 @@ if (nAlphaSubCycles > 1)
|
|||||||
dimensionedScalar totalDeltaT = runTime.deltaT();
|
dimensionedScalar totalDeltaT = runTime.deltaT();
|
||||||
surfaceScalarField rhoPhiSum
|
surfaceScalarField rhoPhiSum
|
||||||
(
|
(
|
||||||
mesh.newIOobject("rhoPhiSum"),
|
IOobject
|
||||||
|
(
|
||||||
|
"rhoPhiSum",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
dimensionedScalar(rhoPhi.dimensions(), Zero)
|
||||||
);
|
);
|
||||||
|
|||||||
@ -100,6 +100,15 @@ public:
|
|||||||
const tractionDisplacementFvPatchVectorField&
|
const tractionDisplacementFvPatchVectorField&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchVectorField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new tractionDisplacementFvPatchVectorField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
tractionDisplacementFvPatchVectorField
|
tractionDisplacementFvPatchVectorField
|
||||||
(
|
(
|
||||||
@ -107,19 +116,16 @@ public:
|
|||||||
const DimensionedField<vector, volMesh>&
|
const DimensionedField<vector, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<vector>> clone() const
|
virtual tmp<fvPatchVectorField> clone
|
||||||
{
|
|
||||||
return fvPatchField<vector>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<vector>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<vector, volMesh>& iF
|
const DimensionedField<vector, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<vector>::Clone(*this, iF);
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new tractionDisplacementFvPatchVectorField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -98,6 +98,15 @@ public:
|
|||||||
const tractionDisplacementCorrectionFvPatchVectorField&
|
const tractionDisplacementCorrectionFvPatchVectorField&
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//- Construct and return a clone
|
||||||
|
virtual tmp<fvPatchVectorField> clone() const
|
||||||
|
{
|
||||||
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new tractionDisplacementCorrectionFvPatchVectorField(*this)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
//- Construct as copy setting internal field reference
|
//- Construct as copy setting internal field reference
|
||||||
tractionDisplacementCorrectionFvPatchVectorField
|
tractionDisplacementCorrectionFvPatchVectorField
|
||||||
(
|
(
|
||||||
@ -105,19 +114,16 @@ public:
|
|||||||
const DimensionedField<vector, volMesh>&
|
const DimensionedField<vector, volMesh>&
|
||||||
);
|
);
|
||||||
|
|
||||||
//- Return a clone
|
//- Construct and return a clone setting internal field reference
|
||||||
virtual tmp<fvPatchField<vector>> clone() const
|
virtual tmp<fvPatchVectorField> clone
|
||||||
{
|
|
||||||
return fvPatchField<vector>::Clone(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//- Clone with an internal field reference
|
|
||||||
virtual tmp<fvPatchField<vector>> clone
|
|
||||||
(
|
(
|
||||||
const DimensionedField<vector, volMesh>& iF
|
const DimensionedField<vector, volMesh>& iF
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fvPatchField<vector>::Clone(*this, iF);
|
return tmp<fvPatchVectorField>
|
||||||
|
(
|
||||||
|
new tractionDisplacementCorrectionFvPatchVectorField(*this, iF)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,5 @@
|
|||||||
EXE_INC = \
|
EXE_INC = \
|
||||||
|
-DFULLDEBUG -g \
|
||||||
-I$(LIB_SRC)/meshTools/lnInclude
|
-I$(LIB_SRC)/meshTools/lnInclude
|
||||||
|
|
||||||
EXE_LIBS = \
|
EXE_LIBS = \
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -70,10 +70,7 @@ int main(int argc, char *argv[])
|
|||||||
);
|
);
|
||||||
|
|
||||||
labelList cellToCoarse(identity(mesh.nCells()));
|
labelList cellToCoarse(identity(mesh.nCells()));
|
||||||
CompactListList<label> coarseToCell
|
labelListList coarseToCell(invertOneToMany(mesh.nCells(), cellToCoarse));
|
||||||
(
|
|
||||||
invertOneToManyCompact(mesh.nCells(), cellToCoarse)
|
|
||||||
);
|
|
||||||
|
|
||||||
++runTime;
|
++runTime;
|
||||||
|
|
||||||
@ -81,11 +78,16 @@ int main(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
volScalarField scalarAgglomeration
|
volScalarField scalarAgglomeration
|
||||||
(
|
(
|
||||||
mesh.thisDb().newIOobject("agglomeration"),
|
IOobject
|
||||||
|
(
|
||||||
|
"agglomeration",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::AUTO_WRITE
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
Foam::zero{},
|
dimensionedScalar(dimless, Zero)
|
||||||
dimless,
|
|
||||||
fvPatchFieldBase::zeroGradientType()
|
|
||||||
);
|
);
|
||||||
scalarField& fld = scalarAgglomeration.primitiveFieldRef();
|
scalarField& fld = scalarAgglomeration.primitiveFieldRef();
|
||||||
forAll(fld, celli)
|
forAll(fld, celli)
|
||||||
@ -140,23 +142,31 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
forAll(addr, finei)
|
forAll(addr, fineI)
|
||||||
{
|
{
|
||||||
labelUIndList(cellToCoarse, coarseToCell[finei]) = addr[finei];
|
const labelList& cellLabels = coarseToCell[fineI];
|
||||||
|
forAll(cellLabels, i)
|
||||||
|
{
|
||||||
|
cellToCoarse[cellLabels[i]] = addr[fineI];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
coarseToCell = invertOneToManyCompact(coarseSize, cellToCoarse);
|
coarseToCell = invertOneToMany(coarseSize, cellToCoarse);
|
||||||
|
|
||||||
// Write agglomeration
|
// Write agglomeration
|
||||||
{
|
{
|
||||||
volScalarField scalarAgglomeration
|
volScalarField scalarAgglomeration
|
||||||
(
|
(
|
||||||
mesh.thisDb().newIOobject("agglomeration"),
|
IOobject
|
||||||
|
(
|
||||||
|
"agglomeration",
|
||||||
|
runTime.timeName(),
|
||||||
|
mesh,
|
||||||
|
IOobject::NO_READ,
|
||||||
|
IOobject::AUTO_WRITE
|
||||||
|
),
|
||||||
mesh,
|
mesh,
|
||||||
Foam::zero{},
|
dimensionedScalar(dimless, Zero)
|
||||||
dimless,
|
|
||||||
fvPatchFieldBase::zeroGradientType()
|
|
||||||
);
|
);
|
||||||
|
|
||||||
scalarField& fld = scalarAgglomeration.primitiveFieldRef();
|
scalarField& fld = scalarAgglomeration.primitiveFieldRef();
|
||||||
forAll(fld, celli)
|
forAll(fld, celli)
|
||||||
{
|
{
|
||||||
@ -183,9 +193,9 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Determine coarse cc
|
// Determine coarse cc
|
||||||
forAll(coarseToCell, coarsei)
|
forAll(coarseToCell, coarseI)
|
||||||
{
|
{
|
||||||
const auto& cellLabels = coarseToCell[coarsei];
|
const labelList& cellLabels = coarseToCell[coarseI];
|
||||||
|
|
||||||
point coarseCc = average
|
point coarseCc = average
|
||||||
(
|
(
|
||||||
@ -194,8 +204,10 @@ int main(int argc, char *argv[])
|
|||||||
meshTools::writeOBJ(str, coarseCc);
|
meshTools::writeOBJ(str, coarseCc);
|
||||||
vertI++;
|
vertI++;
|
||||||
|
|
||||||
for (label celli : cellLabels)
|
forAll(cellLabels, i)
|
||||||
{
|
{
|
||||||
|
label celli = cellLabels[i];
|
||||||
|
|
||||||
str << "l " << celli+1 << ' ' << vertI << nl;
|
str << "l " << celli+1 << ' ' << vertI << nl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -124,11 +124,11 @@ int main(int argc, char *argv[])
|
|||||||
<< "toc: " << flatOutput(table0.toc()) << nl;
|
<< "toc: " << flatOutput(table0.toc()) << nl;
|
||||||
|
|
||||||
HashTable<label, label, Hash<label>> table2
|
HashTable<label, label, Hash<label>> table2
|
||||||
(
|
({
|
||||||
// From key/value pairs
|
{3, 10},
|
||||||
labelList({3, 5, 7}),
|
{5, 12},
|
||||||
labelList({10, 12, 16})
|
{7, 16}
|
||||||
);
|
});
|
||||||
|
|
||||||
Info<< "table2: " << table2 << nl
|
Info<< "table2: " << table2 << nl
|
||||||
<< "toc: " << flatOutput(table2.toc()) << nl;
|
<< "toc: " << flatOutput(table2.toc()) << nl;
|
||||||
|
|||||||
@ -1,3 +1,3 @@
|
|||||||
Test-HashTable4.cxx
|
Test-HashTable4.C
|
||||||
|
|
||||||
EXE = $(FOAM_USER_APPBIN)/Test-HashTable4
|
EXE = $(FOAM_USER_APPBIN)/Test-HashTable4
|
||||||
|
|||||||
@ -159,6 +159,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
|
|
||||||
cpuTime timer;
|
cpuTime timer;
|
||||||
|
memInfo mem;
|
||||||
|
|
||||||
Info<< "insert " << nElem << " (int) elements";
|
Info<< "insert " << nElem << " (int) elements";
|
||||||
if (optFnd)
|
if (optFnd)
|
||||||
@ -206,7 +207,7 @@ int main(int argc, char *argv[])
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
loopInsert(map, nElem);
|
loopInsert(map, nElem);
|
||||||
timer.resetCpuTimeIncrement();
|
(void)timer.cpuTimeIncrement();
|
||||||
|
|
||||||
unsigned long sum = 0;
|
unsigned long sum = 0;
|
||||||
for (label loopi = 0; loopi < nFind*nLoops; ++loopi)
|
for (label loopi = 0; loopi < nFind*nLoops; ++loopi)
|
||||||
@ -268,7 +269,7 @@ int main(int argc, char *argv[])
|
|||||||
HashSet<label, Hash<label>> map(32);
|
HashSet<label, Hash<label>> map(32);
|
||||||
|
|
||||||
loopInsert(map, nElem);
|
loopInsert(map, nElem);
|
||||||
timer.resetCpuTimeIncrement();
|
(void)timer.cpuTimeIncrement();
|
||||||
|
|
||||||
unsigned long sum = 0;
|
unsigned long sum = 0;
|
||||||
for (label loopi = 0; loopi < nFind*nLoops; ++loopi)
|
for (label loopi = 0; loopi < nFind*nLoops; ++loopi)
|
||||||
@ -305,8 +306,7 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
Info<< timer.cpuTimeIncrement() << " s\n";
|
Info<< timer.cpuTimeIncrement() << " s\n";
|
||||||
Foam::memInfo{}.writeEntry("mem-info", Info);
|
Info<< "mem info: " << mem.update() << endl;
|
||||||
Info<< endl;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -188,6 +188,8 @@ int main(int argc, char *argv[])
|
|||||||
argList::addBoolOption("label", "Use label for tests (default)");
|
argList::addBoolOption("label", "Use label for tests (default)");
|
||||||
argList::addBoolOption("ref", "Test writing by ref");
|
argList::addBoolOption("ref", "Test writing by ref");
|
||||||
|
|
||||||
|
#include "addTimeOptions.H"
|
||||||
|
|
||||||
#include "setRootCase.H"
|
#include "setRootCase.H"
|
||||||
#include "createTime.H"
|
#include "createTime.H"
|
||||||
#include "createPolyMesh.H"
|
#include "createPolyMesh.H"
|
||||||
@ -278,6 +280,7 @@ int main(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
IOFieldRef<vector>(ioOutput, mesh.points()).write();
|
IOFieldRef<vector>(ioOutput, mesh.points()).write();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -1,2 +1,4 @@
|
|||||||
/* EXE_INC = */
|
EXE_INC = -DFULLDEBUG
|
||||||
/* EXE_LIBS = */
|
|
||||||
|
/* EXE_INC = -I$(LIB_SRC)/finiteVolume/lnInclude */
|
||||||
|
/* EXE_LIBS = -lfiniteVolume */
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2011 OpenFOAM Foundation
|
Copyright (C) 2011 OpenFOAM Foundation
|
||||||
Copyright (C) 2017-2024 OpenCFD Ltd.
|
Copyright (C) 2017-2022 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -156,24 +156,29 @@ int main(int argc, char *argv[])
|
|||||||
os.writeEntry("idl3", idl3);
|
os.writeEntry("idl3", idl3);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (UPstream::parRun())
|
if (Pstream::parRun())
|
||||||
{
|
{
|
||||||
if (UPstream::master())
|
if (Pstream::master())
|
||||||
{
|
{
|
||||||
Pout<< "full: " << flatOutput(idl3.values()) << nl
|
Pout<< "full: " << flatOutput(idl3.values()) << nl
|
||||||
<< "send: " << flatOutput(idl3) << endl;
|
<< "send: " << flatOutput(idl3) << endl;
|
||||||
|
|
||||||
for (const int proci : UPstream::subProcs())
|
for (const int proci : Pstream::subProcs())
|
||||||
{
|
{
|
||||||
OPstream::send(idl3, proci);
|
OPstream toSlave(Pstream::commsTypes::scheduled, proci);
|
||||||
|
toSlave << idl3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// From master
|
// From master
|
||||||
List<label> recv;
|
IPstream fromMaster
|
||||||
|
(
|
||||||
|
Pstream::commsTypes::scheduled,
|
||||||
|
Pstream::masterNo()
|
||||||
|
);
|
||||||
|
|
||||||
IPstream::recv(recv, UPstream::masterNo());
|
List<label> recv(fromMaster);
|
||||||
|
|
||||||
Pout<<"recv: " << flatOutput(recv) << endl;
|
Pout<<"recv: " << flatOutput(recv) << endl;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,3 +1,3 @@
|
|||||||
Test-OCountStream.cxx
|
Test-OCountStream.C
|
||||||
|
|
||||||
EXE = $(FOAM_USER_APPBIN)/Test-OCountStream
|
EXE = $(FOAM_USER_APPBIN)/Test-OCountStream
|
||||||
|
|||||||
@ -65,11 +65,11 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
OCountStream cnt;
|
OCountStream cnt;
|
||||||
OCharStream cstr;
|
OCharStream cstr;
|
||||||
OStringStream sstr;
|
OStringStream str;
|
||||||
ocountstream plain;
|
ocountstream plain;
|
||||||
|
|
||||||
generateOutput(cstr);
|
generateOutput(cstr);
|
||||||
generateOutput(sstr);
|
generateOutput(str);
|
||||||
generateOutput(cnt);
|
generateOutput(cnt);
|
||||||
generateOutput(plain);
|
generateOutput(plain);
|
||||||
|
|
||||||
@ -77,7 +77,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
Info<< "counter state: " << (cnt.stdStream().rdstate()) << nl
|
Info<< "counter state: " << (cnt.stdStream().rdstate()) << nl
|
||||||
<< "via char-stream: " << label(cstr.view().size()) << " chars" << nl
|
<< "via char-stream: " << label(cstr.view().size()) << " chars" << nl
|
||||||
<< "via string-stream: " << label(sstr.count()) << " chars" << nl
|
<< "via string-stream: " << str.str().size() << " chars" << nl
|
||||||
<< "via ocountstream: " << plain.count() << " chars" << endl;
|
<< "via ocountstream: " << plain.count() << " chars" << endl;
|
||||||
|
|
||||||
fileName outputName;
|
fileName outputName;
|
||||||
@ -5,7 +5,7 @@
|
|||||||
\\ / A nd | www.openfoam.com
|
\\ / A nd | www.openfoam.com
|
||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2022-2024 OpenCFD Ltd.
|
Copyright (C) 2022 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -32,14 +32,10 @@ Description
|
|||||||
#include "IOstreams.H"
|
#include "IOstreams.H"
|
||||||
#include "OSspecific.H"
|
#include "OSspecific.H"
|
||||||
#include "argList.H"
|
#include "argList.H"
|
||||||
#include "clock.H"
|
|
||||||
#include "Switch.H"
|
|
||||||
#include "ListOps.H"
|
#include "ListOps.H"
|
||||||
|
|
||||||
using namespace Foam;
|
using namespace Foam;
|
||||||
|
|
||||||
std::string time_stamp;
|
|
||||||
|
|
||||||
void listFiles(const fileName& dir)
|
void listFiles(const fileName& dir)
|
||||||
{
|
{
|
||||||
wordList files = ListOps::create<word>
|
wordList files = ListOps::create<word>
|
||||||
@ -59,150 +55,25 @@ void listFiles(const fileName& dir)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
OSstream& printInfo(OFstream& os)
|
|
||||||
{
|
|
||||||
InfoErr
|
|
||||||
<< "open: " << os.name() << nl
|
|
||||||
<< "appending: " << Switch::name(os.is_appending())
|
|
||||||
<< " tellp: "<< os.stdStream().tellp()
|
|
||||||
<< " gz: " << Switch::name(os.compression()) << nl;
|
|
||||||
|
|
||||||
return InfoErr.stream();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void withHeader(OFstream& os)
|
|
||||||
{
|
|
||||||
const auto tellp = os.stdStream().tellp();
|
|
||||||
|
|
||||||
if (tellp <= 0)
|
|
||||||
{
|
|
||||||
InfoErr
|
|
||||||
<< "Add header" << nl;
|
|
||||||
os << "HEADER: " << time_stamp.c_str() << nl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<class OSstreamType>
|
|
||||||
void generateLines(OSstreamType& os, label count = 1)
|
|
||||||
{
|
|
||||||
for (label line = 1; line <= count; ++line)
|
|
||||||
{
|
|
||||||
os << "[" << line
|
|
||||||
<< "] =============================================" << nl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<class OSstreamType>
|
|
||||||
void generateContent
|
|
||||||
(
|
|
||||||
OSstreamType& os,
|
|
||||||
const bool with_seekend,
|
|
||||||
const bool test_overwrite = false,
|
|
||||||
const int64_t seek_out = -1
|
|
||||||
)
|
|
||||||
{
|
|
||||||
if (with_seekend)
|
|
||||||
{
|
|
||||||
os.stdStream().seekp(0, std::ios_base::end);
|
|
||||||
// OR? os.seek_end();
|
|
||||||
}
|
|
||||||
|
|
||||||
printInfo(os);
|
|
||||||
|
|
||||||
withHeader(os);
|
|
||||||
|
|
||||||
if (test_overwrite && seek_out >= 0)
|
|
||||||
{
|
|
||||||
InfoErr<< "... seekp(" << seek_out << ")" << nl;
|
|
||||||
|
|
||||||
auto& oss = os.stdStream();
|
|
||||||
|
|
||||||
// Actually std::streampos, but cannot increment that
|
|
||||||
|
|
||||||
int64_t pos(seek_out);
|
|
||||||
|
|
||||||
const int64_t tellp_end = oss.tellp();
|
|
||||||
|
|
||||||
if (pos >= 0 && pos < tellp_end)
|
|
||||||
{
|
|
||||||
InfoErr
|
|
||||||
<< "... fill from " << label(pos)
|
|
||||||
<< " to " << label(tellp_end) << nl;
|
|
||||||
|
|
||||||
oss.seekp(pos);
|
|
||||||
|
|
||||||
while (pos < tellp_end)
|
|
||||||
{
|
|
||||||
// Fill with char 'X', rely on streambuf buffering
|
|
||||||
oss << 'X';
|
|
||||||
++pos;
|
|
||||||
}
|
|
||||||
|
|
||||||
oss.seekp(seek_out);
|
|
||||||
os << "More content [at " << seek_out << ']' << endl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
generateLines(os, 4);
|
|
||||||
|
|
||||||
printInfo(os)
|
|
||||||
<< "... sleep" << endl;
|
|
||||||
|
|
||||||
listFiles(os.name().path());
|
|
||||||
|
|
||||||
sleep(2);
|
|
||||||
|
|
||||||
os << "[new content] +++++++++++++++++++++++++++++++++++" << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<class OSstreamType>
|
|
||||||
void generateOverwriteContent
|
|
||||||
(
|
|
||||||
OSstreamType& os,
|
|
||||||
const bool with_seekend,
|
|
||||||
const int64_t seek_out = -1
|
|
||||||
)
|
|
||||||
{
|
|
||||||
generateContent(os, with_seekend, true, seek_out);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
// Main program:
|
// Main program:
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
argList::addBoolOption("gz", "Use compression");
|
argList::addBoolOption("gz", "Use compression");
|
||||||
argList::addBoolOption("append-app", "Use append app mode");
|
argList::addBoolOption("append", "Use append mode");
|
||||||
argList::addBoolOption("append-ate", "Use append ate mode");
|
|
||||||
argList::addBoolOption("seekend", "Seek to end after non-append open");
|
|
||||||
argList::addOption("seek", "value", "Seek from start (default: 100)");
|
|
||||||
argList::addBoolOption("atomic", "Use atomic");
|
argList::addBoolOption("atomic", "Use atomic");
|
||||||
argList::addBoolOption("keep", "Do not remove test directory");
|
argList::addBoolOption("keep", "Do not remove test directory");
|
||||||
argList::addOption("write", "file", "test writing to file");
|
argList::addOption("write", "file", "test writing to file");
|
||||||
|
|
||||||
#include "setRootCase.H"
|
#include "setRootCase.H"
|
||||||
|
|
||||||
// Same time-stamp for all generated files
|
|
||||||
time_stamp = clock::dateTime();
|
|
||||||
|
|
||||||
const fileName baseDir("Test-OFstream-directory");
|
const fileName baseDir("Test-OFstream-directory");
|
||||||
|
|
||||||
Foam::mkDir(baseDir);
|
Foam::mkDir(baseDir);
|
||||||
|
|
||||||
InfoErr<< "mkdir: " << baseDir << endl;
|
InfoErr<< "mkdir: " << baseDir << endl;
|
||||||
|
|
||||||
Info<< "start:" << nl;
|
|
||||||
listFiles(baseDir);
|
|
||||||
|
|
||||||
const bool with_seekend = args.found("seekend");
|
|
||||||
|
|
||||||
const int seek_out = args.getOrDefault<int>("seek", 100);
|
|
||||||
|
|
||||||
IOstreamOption streamOpt;
|
IOstreamOption streamOpt;
|
||||||
|
|
||||||
if (args.found("gz"))
|
if (args.found("gz"))
|
||||||
@ -212,11 +83,10 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
IOstreamOption::appendType append =
|
IOstreamOption::appendType append =
|
||||||
(
|
(
|
||||||
args.found("append-app") ? IOstreamOption::APPEND_APP
|
args.found("append")
|
||||||
: args.found("append-ate") ? IOstreamOption::APPEND_ATE
|
? IOstreamOption::APPEND
|
||||||
: IOstreamOption::NO_APPEND
|
: IOstreamOption::NON_APPEND
|
||||||
);
|
);
|
||||||
|
|
||||||
IOstreamOption::atomicType atomic =
|
IOstreamOption::atomicType atomic =
|
||||||
(
|
(
|
||||||
args.found("atomic")
|
args.found("atomic")
|
||||||
@ -227,6 +97,7 @@ int main(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
OFstream(baseDir/"dummy")() << "Some file content" << endl;
|
OFstream(baseDir/"dummy")() << "Some file content" << endl;
|
||||||
|
|
||||||
|
Foam::ln("dummy", baseDir/"Test2.txt");
|
||||||
Foam::ln("dummy", baseDir/"Test3.txt");
|
Foam::ln("dummy", baseDir/"Test3.txt");
|
||||||
Foam::ln("dummy", baseDir/"Test4.txt");
|
Foam::ln("dummy", baseDir/"Test4.txt");
|
||||||
Foam::ln("dummy", baseDir/"Test4.txt.gz");
|
Foam::ln("dummy", baseDir/"Test4.txt.gz");
|
||||||
@ -243,31 +114,16 @@ int main(int argc, char *argv[])
|
|||||||
append
|
append
|
||||||
);
|
);
|
||||||
|
|
||||||
generateOverwriteContent(os, with_seekend, seek_out);
|
os << "=========================" << endl;
|
||||||
}
|
|
||||||
|
|
||||||
{
|
InfoErr<< "open: " << os.name() << endl;
|
||||||
OFstream os
|
InfoErr<< "... sleep" << endl;
|
||||||
(
|
|
||||||
atomic,
|
|
||||||
baseDir/"Test1-app.txt",
|
|
||||||
streamOpt,
|
|
||||||
IOstreamOption::APPEND_APP
|
|
||||||
);
|
|
||||||
|
|
||||||
generateOverwriteContent(os, with_seekend, seek_out);
|
listFiles(baseDir);
|
||||||
}
|
|
||||||
|
|
||||||
{
|
sleep(2);
|
||||||
OFstream os
|
|
||||||
(
|
|
||||||
atomic,
|
|
||||||
baseDir/"Test1-ate.txt",
|
|
||||||
streamOpt,
|
|
||||||
IOstreamOption::APPEND_ATE
|
|
||||||
);
|
|
||||||
|
|
||||||
generateOverwriteContent(os, with_seekend, seek_out);
|
os << "+++++++++++++++++++++++++++++++++++" << endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -276,21 +132,39 @@ int main(int argc, char *argv[])
|
|||||||
atomic,
|
atomic,
|
||||||
baseDir/"Test2.txt",
|
baseDir/"Test2.txt",
|
||||||
streamOpt
|
streamOpt
|
||||||
|
// NON_APPEND
|
||||||
);
|
);
|
||||||
|
|
||||||
generateContent(os, with_seekend);
|
os << "=========================" << endl;
|
||||||
}
|
|
||||||
|
|
||||||
|
InfoErr<< "open: " << os.name() << endl;
|
||||||
|
InfoErr<< "... sleep" << endl;
|
||||||
|
|
||||||
|
listFiles(baseDir);
|
||||||
|
|
||||||
|
sleep(2);
|
||||||
|
|
||||||
|
os << "+++++++++++++++++++++++++++++++++++" << endl;
|
||||||
|
}
|
||||||
{
|
{
|
||||||
OFstream os
|
OFstream os
|
||||||
(
|
(
|
||||||
atomic,
|
atomic,
|
||||||
baseDir/"Test3.txt",
|
baseDir/"Test3.txt",
|
||||||
streamOpt,
|
streamOpt,
|
||||||
IOstreamOption::APPEND_APP
|
IOstreamOption::APPEND
|
||||||
);
|
);
|
||||||
|
|
||||||
generateContent(os, with_seekend, with_seekend);
|
os << "=========================" << endl;
|
||||||
|
|
||||||
|
InfoErr<< "open: " << os.name() << endl;
|
||||||
|
InfoErr<< "... sleep" << endl;
|
||||||
|
|
||||||
|
listFiles(baseDir);
|
||||||
|
|
||||||
|
sleep(2);
|
||||||
|
|
||||||
|
os << "+++++++++++++++++++++++++++++++++++" << endl;
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
OFstream os
|
OFstream os
|
||||||
@ -300,17 +174,35 @@ int main(int argc, char *argv[])
|
|||||||
IOstreamOption::COMPRESSED
|
IOstreamOption::COMPRESSED
|
||||||
);
|
);
|
||||||
|
|
||||||
// No seekend with COMPRESSED
|
os << "=========================" << endl;
|
||||||
generateContent(os, false);
|
|
||||||
|
InfoErr<< "open: " << os.name() << endl;
|
||||||
|
InfoErr<< "... sleep" << endl;
|
||||||
|
|
||||||
|
listFiles(baseDir);
|
||||||
|
|
||||||
|
sleep(2);
|
||||||
|
|
||||||
|
os << "+++++++++++++++++++++++++++++++++++" << endl;
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
OFstream os
|
OFstream os
|
||||||
(
|
(
|
||||||
IOstreamOption::ATOMIC,
|
IOstreamOption::ATOMIC,
|
||||||
baseDir/"Test5.txt"
|
baseDir/"Test5.txt"
|
||||||
|
// ASCII UNCOMPRESSED NON_APPEND
|
||||||
);
|
);
|
||||||
|
|
||||||
generateContent(os, with_seekend);
|
os << "=========================" << endl;
|
||||||
|
|
||||||
|
InfoErr<< "open: " << os.name() << endl;
|
||||||
|
InfoErr<< "... sleep" << endl;
|
||||||
|
|
||||||
|
listFiles(baseDir);
|
||||||
|
|
||||||
|
sleep(2);
|
||||||
|
|
||||||
|
os << "+++++++++++++++++++++++++++++++++++" << endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
Info<< nl << "done:" << endl;
|
Info<< nl << "done:" << endl;
|
||||||
|
|||||||
@ -1,4 +1,5 @@
|
|||||||
EXE_INC = \
|
EXE_INC = \
|
||||||
|
-DFULLDEBUG \
|
||||||
-I$(LIB_SRC)/mesh/blockMesh/lnInclude
|
-I$(LIB_SRC)/mesh/blockMesh/lnInclude
|
||||||
|
|
||||||
EXE_LIBS = \
|
EXE_LIBS = \
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,4 +1,5 @@
|
|||||||
EXE_INC = \
|
EXE_INC = \
|
||||||
|
-DFULLDEBUG -g -O0 \
|
||||||
-I$(LIB_SRC)/lagrangian/intermediate/lnInclude \
|
-I$(LIB_SRC)/lagrangian/intermediate/lnInclude \
|
||||||
-I$(LIB_SRC)/thermophysicalModels/radiation/lnInclude \
|
-I$(LIB_SRC)/thermophysicalModels/radiation/lnInclude \
|
||||||
-I$(LIB_SRC)/finiteVolume/lnInclude \
|
-I$(LIB_SRC)/finiteVolume/lnInclude \
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -67,8 +67,8 @@ using namespace Foam;
|
|||||||
// // (note:without calculating pointNormals
|
// // (note:without calculating pointNormals
|
||||||
// // to avoid them being stored)
|
// // to avoid them being stored)
|
||||||
//
|
//
|
||||||
// auto textrudeN = tmp<pointField>::New(p.nPoints(), Zero);
|
// tmp<pointField> textrudeN(new pointField(p.nPoints(), Zero));
|
||||||
// auto& extrudeN = textrudeN.ref();
|
// pointField& extrudeN = textrudeN();
|
||||||
// {
|
// {
|
||||||
// const faceList& localFaces = p.localFaces();
|
// const faceList& localFaces = p.localFaces();
|
||||||
// const vectorField& faceAreas = mesh.faceAreas();
|
// const vectorField& faceAreas = mesh.faceAreas();
|
||||||
@ -201,6 +201,7 @@ using namespace Foam;
|
|||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
#include "addTimeOptions.H"
|
||||||
argList::addArgument("patch");
|
argList::addArgument("patch");
|
||||||
#include "setRootCase.H"
|
#include "setRootCase.H"
|
||||||
#include "createTime.H"
|
#include "createTime.H"
|
||||||
|
|||||||
@ -412,7 +412,7 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
Info<< "range-for of list (" << list1.count_nonnull() << '/'
|
Info<< "range-for of list (" << list1.count() << '/'
|
||||||
<< list1.size() << ") non-null entries" << nl
|
<< list1.size() << ") non-null entries" << nl
|
||||||
<< "(" << nl;
|
<< "(" << nl;
|
||||||
for (const auto& item : list1)
|
for (const auto& item : list1)
|
||||||
|
|||||||
@ -53,37 +53,46 @@ int main(int argc, char *argv[])
|
|||||||
#include "setRootCase.H"
|
#include "setRootCase.H"
|
||||||
#include "createTime.H"
|
#include "createTime.H"
|
||||||
|
|
||||||
word coherentInst;
|
fileName coherentInst;
|
||||||
coherentInst =
|
coherentInst =
|
||||||
(
|
(
|
||||||
runTime.findInstance
|
runTime.findInstance
|
||||||
(
|
(
|
||||||
polyMesh::meshSubDir,
|
polyMesh::meshSubDir,
|
||||||
"coherent",
|
"coherent",
|
||||||
IOobject::READ_IF_PRESENT,
|
IOobject::READ_IF_PRESENT
|
||||||
word::null, // No stop instance
|
|
||||||
false // No "constant" fallback (word::null instead)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
Info<< "Found coherent \"" << coherentInst << '"' << nl;
|
// Unfortunately with READ_IF_PRESENT, cannot tell if the file
|
||||||
|
// was actually found or not
|
||||||
|
|
||||||
|
Info<< "check: " << (coherentInst/polyMesh::meshSubDir/"coherent") << nl;
|
||||||
|
|
||||||
|
if (!Foam::isFile(coherentInst/polyMesh::meshSubDir/"coherent"))
|
||||||
|
{
|
||||||
|
coherentInst.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
Info<< "found coherent: " << coherentInst << nl;
|
||||||
|
|
||||||
PtrList<entry> entries;
|
PtrList<entry> entries;
|
||||||
|
|
||||||
if (!coherentInst.empty())
|
if (!coherentInst.empty())
|
||||||
{
|
{
|
||||||
dictionary coherent =
|
IOdictionary coherent
|
||||||
IOdictionary::readContents
|
(
|
||||||
|
IOobject
|
||||||
(
|
(
|
||||||
IOobject
|
"coherent",
|
||||||
(
|
coherentInst,
|
||||||
"coherent",
|
polyMesh::meshSubDir,
|
||||||
coherentInst,
|
runTime,
|
||||||
polyMesh::meshSubDir,
|
IOobject::MUST_READ,
|
||||||
runTime,
|
IOobject::NO_WRITE,
|
||||||
IOobject::MUST_READ
|
IOobject::NO_REGISTER
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
ITstream& is = coherent.lookup("boundary");
|
ITstream& is = coherent.lookup("boundary");
|
||||||
is >> entries;
|
is >> entries;
|
||||||
@ -96,7 +105,7 @@ int main(int argc, char *argv[])
|
|||||||
Info<< "size: " << polyBoundaryMeshEntries::patchSizes(entries) << nl;
|
Info<< "size: " << polyBoundaryMeshEntries::patchSizes(entries) << nl;
|
||||||
Info<< nl;
|
Info<< nl;
|
||||||
|
|
||||||
word boundaryInst;
|
fileName boundaryInst;
|
||||||
boundaryInst =
|
boundaryInst =
|
||||||
(
|
(
|
||||||
runTime.findInstance
|
runTime.findInstance
|
||||||
@ -107,7 +116,7 @@ int main(int argc, char *argv[])
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
Info<< "Found boundary: \"" << boundaryInst << '"' << nl;
|
Info<< "found boundary: " << boundaryInst << nl;
|
||||||
|
|
||||||
polyBoundaryMeshEntries pbm
|
polyBoundaryMeshEntries pbm
|
||||||
(
|
(
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
\\ / A nd | www.openfoam.com
|
\\ / A nd | www.openfoam.com
|
||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2017-2024 OpenCFD Ltd.
|
Copyright (C) 2017-2023 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -24,7 +24,7 @@ License
|
|||||||
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
Application
|
Application
|
||||||
Test-checkDecomposePar
|
checkDecomposePar
|
||||||
|
|
||||||
Group
|
Group
|
||||||
grpParallelUtilities
|
grpParallelUtilities
|
||||||
@ -35,9 +35,8 @@ Description
|
|||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
#include "argList.H"
|
#include "OSspecific.H"
|
||||||
#include "timeSelector.H"
|
#include "fvCFD.H"
|
||||||
#include "polyMesh.H"
|
|
||||||
#include "cpuTime.H"
|
#include "cpuTime.H"
|
||||||
#include "IFstream.H"
|
#include "IFstream.H"
|
||||||
#include "regionProperties.H"
|
#include "regionProperties.H"
|
||||||
@ -45,14 +44,10 @@ Description
|
|||||||
#include "decompositionInformation.H"
|
#include "decompositionInformation.H"
|
||||||
#include "decompositionModel.H"
|
#include "decompositionModel.H"
|
||||||
|
|
||||||
using namespace Foam;
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
timeSelector::addOptions_singleTime(); // Single-time options
|
|
||||||
|
|
||||||
argList::addNote
|
argList::addNote
|
||||||
(
|
(
|
||||||
"Check decomposition from kaffpa (KaHIP) output"
|
"Check decomposition from kaffpa (KaHIP) output"
|
||||||
@ -70,6 +65,9 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
argList::addArgument("kaffpa-output-file");
|
argList::addArgument("kaffpa-output-file");
|
||||||
|
|
||||||
|
// Include explicit constant options, have zero from time range
|
||||||
|
timeSelector::addOptions(true, false);
|
||||||
|
|
||||||
#include "setRootCase.H"
|
#include "setRootCase.H"
|
||||||
|
|
||||||
const auto decompFile = args.get<fileName>(1);
|
const auto decompFile = args.get<fileName>(1);
|
||||||
@ -77,8 +75,8 @@ int main(int argc, char *argv[])
|
|||||||
// Set time from database
|
// Set time from database
|
||||||
#include "createTime.H"
|
#include "createTime.H"
|
||||||
|
|
||||||
// Allow override of time from specified time options, or no-op
|
// Allow override of time
|
||||||
timeSelector::setTimeIfPresent(runTime, args);
|
instantList times = timeSelector::selectIfPresent(runTime, args);
|
||||||
|
|
||||||
// Allow override of decomposeParDict location
|
// Allow override of decomposeParDict location
|
||||||
const fileName decompDictFile =
|
const fileName decompDictFile =
|
||||||
@ -97,7 +95,7 @@ int main(int argc, char *argv[])
|
|||||||
Info<< "\n\nDecomposing mesh " << regionName << nl << endl;
|
Info<< "\n\nDecomposing mesh " << regionName << nl << endl;
|
||||||
Info<< "Create mesh..." << flush;
|
Info<< "Create mesh..." << flush;
|
||||||
|
|
||||||
polyMesh mesh
|
fvMesh mesh
|
||||||
(
|
(
|
||||||
IOobject
|
IOobject
|
||||||
(
|
(
|
||||||
@ -113,7 +111,7 @@ int main(int argc, char *argv[])
|
|||||||
Info<< " nCells = " << mesh.nCells() << endl;
|
Info<< " nCells = " << mesh.nCells() << endl;
|
||||||
|
|
||||||
// Expected format is a simple ASCII list
|
// Expected format is a simple ASCII list
|
||||||
cellToProc.resize(mesh.nCells());
|
cellToProc.setSize(mesh.nCells());
|
||||||
{
|
{
|
||||||
IFstream is(decompFile);
|
IFstream is(decompFile);
|
||||||
|
|
||||||
@ -125,9 +123,15 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
const label nDomains = max(cellToProc) + 1;
|
const label nDomains = max(cellToProc) + 1;
|
||||||
|
|
||||||
// Local mesh connectivity
|
|
||||||
CompactListList<label> cellCells;
|
CompactListList<label> cellCells;
|
||||||
globalMeshData::calcCellCells(mesh, cellCells);
|
globalMeshData::calcCellCells
|
||||||
|
(
|
||||||
|
mesh,
|
||||||
|
identity(mesh.nCells()),
|
||||||
|
mesh.nCells(),
|
||||||
|
false,
|
||||||
|
cellCells
|
||||||
|
);
|
||||||
|
|
||||||
decompositionInformation info
|
decompositionInformation info
|
||||||
(
|
(
|
||||||
|
|||||||
@ -1,3 +0,0 @@
|
|||||||
Test-checkIOspeed.cxx
|
|
||||||
|
|
||||||
EXE = $(FOAM_USER_APPBIN)/Test-checkIOspeed
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
EXE_INC = \
|
|
||||||
-I$(LIB_SRC)/finiteVolume/lnInclude \
|
|
||||||
-I$(LIB_SRC)/mesh/blockMesh/lnInclude
|
|
||||||
|
|
||||||
EXE_LIBS = \
|
|
||||||
-lfiniteVolume \
|
|
||||||
-lblockMesh
|
|
||||||
@ -1,400 +0,0 @@
|
|||||||
/*---------------------------------------------------------------------------*\
|
|
||||||
========= |
|
|
||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
||||||
\\ / O peration |
|
|
||||||
\\ / A nd | www.openfoam.com
|
|
||||||
\\/ M anipulation |
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Copyright (C) 2024 OpenCFD Ltd.
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
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/>.
|
|
||||||
|
|
||||||
Application
|
|
||||||
Test-checkIOspeed
|
|
||||||
|
|
||||||
Description
|
|
||||||
Simple test of file writing, including timings
|
|
||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#include "argList.H"
|
|
||||||
#include "profiling.H"
|
|
||||||
#include "clockTime.H"
|
|
||||||
|
|
||||||
#include "fileName.H"
|
|
||||||
#include "fileOperation.H"
|
|
||||||
#include "IOstreams.H"
|
|
||||||
#include "OSspecific.H"
|
|
||||||
#include "globalIndex.H"
|
|
||||||
#include "volFields.H"
|
|
||||||
#include "IOField.H"
|
|
||||||
#include "PDRblock.H"
|
|
||||||
|
|
||||||
// Not really great since CoherentMesh only works with reading!
|
|
||||||
#ifdef USE_COHERENT
|
|
||||||
#include "OFCstream.H"
|
|
||||||
#include "SliceStreamRepo.H"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <numeric>
|
|
||||||
|
|
||||||
using namespace Foam;
|
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
||||||
// Main program:
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
argList::addNote("Rewrites fields multiple times");
|
|
||||||
|
|
||||||
argList::noFunctionObjects(); // Disallow function objects
|
|
||||||
argList::noCheckProcessorDirectories();
|
|
||||||
|
|
||||||
argList::addVerboseOption("additional verbosity");
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"output",
|
|
||||||
"N",
|
|
||||||
"Begin output iteration (default: 10000)"
|
|
||||||
);
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"count",
|
|
||||||
"N",
|
|
||||||
"Number of writes (default: 1)"
|
|
||||||
);
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"fields",
|
|
||||||
"N",
|
|
||||||
"Number of fields to write (default: 1)"
|
|
||||||
);
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"global",
|
|
||||||
"N",
|
|
||||||
"Global field size"
|
|
||||||
);
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"local",
|
|
||||||
"N",
|
|
||||||
"Local fields size (default: 1000)"
|
|
||||||
);
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"mesh",
|
|
||||||
"(nx ny nz)",
|
|
||||||
"Create with a mesh"
|
|
||||||
);
|
|
||||||
argList::addOption
|
|
||||||
(
|
|
||||||
"exclude",
|
|
||||||
"(int ... )",
|
|
||||||
"zero-sized on ranks with specified modulo"
|
|
||||||
);
|
|
||||||
|
|
||||||
argList::addBoolOption("coherent", "Force coherent output");
|
|
||||||
|
|
||||||
#include "setRootCase.H"
|
|
||||||
#include "createTime.H"
|
|
||||||
|
|
||||||
const label firstOutput = args.getOrDefault("output", 10000);
|
|
||||||
const label nOutput = args.getOrDefault("count", 1);
|
|
||||||
const label nFields = args.getOrDefault("fields", 1);
|
|
||||||
labelVector meshCells(0, 0, 0);
|
|
||||||
|
|
||||||
const int verbose = args.verbose();
|
|
||||||
|
|
||||||
const bool useCoherent = args.found("coherent");
|
|
||||||
|
|
||||||
labelList excludes;
|
|
||||||
args.readListIfPresent("exclude", excludes);
|
|
||||||
|
|
||||||
bool writeOnProc = true;
|
|
||||||
|
|
||||||
const label myProci = UPstream::myProcNo();
|
|
||||||
|
|
||||||
for (const label excl : excludes)
|
|
||||||
{
|
|
||||||
if (excl > 1 && myProci > 0 && (myProci % excl) == 0)
|
|
||||||
{
|
|
||||||
writeOnProc = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const label nProcsEff =
|
|
||||||
returnReduce((writeOnProc ? 1 : 0), sumOp<label>());
|
|
||||||
|
|
||||||
Info<< "Output " << nProcsEff
|
|
||||||
<< "/" << UPstream::nProcs()
|
|
||||||
<< " ranks" << nl;
|
|
||||||
|
|
||||||
|
|
||||||
if (args.readIfPresent("mesh", meshCells))
|
|
||||||
{
|
|
||||||
if (!writeOnProc)
|
|
||||||
{
|
|
||||||
meshCells = Zero;
|
|
||||||
}
|
|
||||||
|
|
||||||
PDRblock block(boundBox(point::zero, point::one), meshCells);
|
|
||||||
|
|
||||||
// Advance time
|
|
||||||
// - coherent currently still needs to read the mesh itself!
|
|
||||||
runTime.setTime(firstOutput, firstOutput);
|
|
||||||
|
|
||||||
IOobject meshIO
|
|
||||||
(
|
|
||||||
polyMesh::defaultRegion,
|
|
||||||
runTime.timeName(),
|
|
||||||
runTime,
|
|
||||||
IOobject::NO_READ,
|
|
||||||
IOobject::NO_WRITE,
|
|
||||||
IOobject::NO_REGISTER
|
|
||||||
);
|
|
||||||
|
|
||||||
autoPtr<polyMesh> pmeshPtr(block.innerMesh(meshIO));
|
|
||||||
|
|
||||||
fvMesh mesh
|
|
||||||
(
|
|
||||||
meshIO,
|
|
||||||
pointField(pmeshPtr->points()),
|
|
||||||
faceList(pmeshPtr->faces()),
|
|
||||||
labelList(pmeshPtr->faceOwner()),
|
|
||||||
labelList(pmeshPtr->faceNeighbour())
|
|
||||||
);
|
|
||||||
|
|
||||||
pmeshPtr.reset(nullptr);
|
|
||||||
|
|
||||||
const label fieldSize = mesh.nCells();
|
|
||||||
|
|
||||||
const globalIndex giCells(fieldSize);
|
|
||||||
|
|
||||||
// Create fields
|
|
||||||
Info<< nl << "Create " << nFields << " fields" << nl
|
|
||||||
<< "field-size:" << fieldSize
|
|
||||||
<< " total-size:" << giCells.totalSize() << nl;
|
|
||||||
|
|
||||||
// Dimensioned field (no proc boundaries)
|
|
||||||
|
|
||||||
PtrList<volScalarField::Internal> fields(nFields);
|
|
||||||
|
|
||||||
{
|
|
||||||
IOobject io
|
|
||||||
(
|
|
||||||
"field",
|
|
||||||
runTime.timeName(),
|
|
||||||
runTime,
|
|
||||||
IOobject::NO_READ,
|
|
||||||
IOobject::NO_WRITE,
|
|
||||||
IOobject::NO_REGISTER
|
|
||||||
);
|
|
||||||
|
|
||||||
forAll(fields, fieldi)
|
|
||||||
{
|
|
||||||
io.resetHeader("field" + Foam::name(fieldi));
|
|
||||||
|
|
||||||
fields.set
|
|
||||||
(
|
|
||||||
fieldi,
|
|
||||||
new volScalarField::Internal(io, mesh, dimless)
|
|
||||||
);
|
|
||||||
|
|
||||||
auto& fld = fields[fieldi];
|
|
||||||
std::iota(fld.begin(), fld.end(), scalar(0));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
IOstreamOption streamOpt(IOstreamOption::BINARY);
|
|
||||||
|
|
||||||
if (useCoherent)
|
|
||||||
{
|
|
||||||
#ifdef USE_COHERENT
|
|
||||||
streamOpt.format(IOstreamOption::COHERENT);
|
|
||||||
runTime.writeFormat(IOstreamOption::COHERENT);
|
|
||||||
|
|
||||||
mesh.writeObject(streamOpt, true);
|
|
||||||
|
|
||||||
Info<< nl
|
|
||||||
<< "Specified -coherent (instance: "
|
|
||||||
<< mesh.pointsInstance() << ")" << endl;
|
|
||||||
|
|
||||||
const auto& coherent = CoherentMesh::New(mesh);
|
|
||||||
|
|
||||||
Info<< " points = "
|
|
||||||
<< coherent.globalPointOffsets().totalSize() << nl
|
|
||||||
<< " cells = "
|
|
||||||
<< coherent.globalCellOffsets().totalSize() << nl
|
|
||||||
<< " patches = "
|
|
||||||
<< coherent.nNonProcessorPatches() << nl;
|
|
||||||
|
|
||||||
#else
|
|
||||||
Info<< "Warning: -coherent ignored" << nl;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
Info<< nl
|
|
||||||
<< "Writing " << nOutput << " times starting at "
|
|
||||||
<< firstOutput << nl;
|
|
||||||
|
|
||||||
clockTime timing;
|
|
||||||
|
|
||||||
if (verbose) Info<< "Time:";
|
|
||||||
|
|
||||||
for
|
|
||||||
(
|
|
||||||
label timeIndex = firstOutput, count = 0;
|
|
||||||
count < nOutput;
|
|
||||||
++timeIndex, ++count
|
|
||||||
)
|
|
||||||
{
|
|
||||||
runTime.setTime(timeIndex, timeIndex);
|
|
||||||
if (verbose) Info<< ' ' << runTime.timeName() << flush;
|
|
||||||
runTime.writeNow();
|
|
||||||
|
|
||||||
for (const auto& fld : fields)
|
|
||||||
{
|
|
||||||
fld.regIOobject::writeObject(streamOpt, writeOnProc);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (useCoherent)
|
|
||||||
{
|
|
||||||
#ifdef USE_COHERENT
|
|
||||||
SliceStreamRepo::closeInstance();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
if (verbose) Info<< nl;
|
|
||||||
Info<< nl << "Writing took "
|
|
||||||
<< timing.timeIncrement() << "s" << endl;
|
|
||||||
|
|
||||||
Info<< nl
|
|
||||||
<< "Cleanup newly generated files with" << nl << nl
|
|
||||||
<< " foamListTimes -rm -time "
|
|
||||||
<< firstOutput << ":" << nl
|
|
||||||
<< " foamListTimes -processor -rm -time "
|
|
||||||
<< firstOutput << ":" << nl;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
label fieldSize = 1000;
|
|
||||||
|
|
||||||
if (args.readIfPresent("global", fieldSize))
|
|
||||||
{
|
|
||||||
fieldSize /= nProcsEff;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
args.readIfPresent("local", fieldSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!writeOnProc)
|
|
||||||
{
|
|
||||||
fieldSize = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
const globalIndex giCells(fieldSize);
|
|
||||||
|
|
||||||
// Create fields
|
|
||||||
Info<< nl << "Create " << nFields << " fields" << nl
|
|
||||||
<< "field-size:" << fieldSize
|
|
||||||
<< " total-size:" << giCells.totalSize() << nl;
|
|
||||||
|
|
||||||
|
|
||||||
PtrList<IOField<scalar>> fields(nFields);
|
|
||||||
|
|
||||||
{
|
|
||||||
IOobject io
|
|
||||||
(
|
|
||||||
"field",
|
|
||||||
runTime.timeName(),
|
|
||||||
runTime,
|
|
||||||
IOobject::NO_READ,
|
|
||||||
IOobject::NO_WRITE,
|
|
||||||
IOobject::NO_REGISTER
|
|
||||||
);
|
|
||||||
|
|
||||||
forAll(fields, fieldi)
|
|
||||||
{
|
|
||||||
io.resetHeader("field" + Foam::name(fieldi));
|
|
||||||
|
|
||||||
fields.set
|
|
||||||
(
|
|
||||||
fieldi,
|
|
||||||
new IOField<scalar>(io, fieldSize)
|
|
||||||
);
|
|
||||||
|
|
||||||
auto& fld = fields[fieldi];
|
|
||||||
std::iota(fld.begin(), fld.end(), scalar(0));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
IOstreamOption streamOpt(IOstreamOption::BINARY);
|
|
||||||
|
|
||||||
if (useCoherent)
|
|
||||||
{
|
|
||||||
Info<< "Warning: -coherent ignored" << nl;
|
|
||||||
}
|
|
||||||
|
|
||||||
Info<< nl
|
|
||||||
<< "Writing " << nOutput << " times starting at "
|
|
||||||
<< firstOutput << nl;
|
|
||||||
|
|
||||||
clockTime timing;
|
|
||||||
|
|
||||||
if (verbose) Info<< "Time:";
|
|
||||||
|
|
||||||
for
|
|
||||||
(
|
|
||||||
label timeIndex = firstOutput, count = 0;
|
|
||||||
count < nOutput;
|
|
||||||
++timeIndex, ++count
|
|
||||||
)
|
|
||||||
{
|
|
||||||
runTime.setTime(timeIndex, timeIndex);
|
|
||||||
if (verbose) Info<< ' ' << runTime.timeName() << flush;
|
|
||||||
runTime.writeNow();
|
|
||||||
|
|
||||||
for (const auto& fld : fields)
|
|
||||||
{
|
|
||||||
fld.regIOobject::writeObject(streamOpt, writeOnProc);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (verbose) Info<< nl;
|
|
||||||
Info<< nl << "Writing took "
|
|
||||||
<< timing.timeIncrement() << "s" << endl;
|
|
||||||
|
|
||||||
Info<< nl
|
|
||||||
<< "Cleanup newly generated files with" << nl << nl
|
|
||||||
<< " foamListTimes -rm -time "
|
|
||||||
<< firstOutput << ":" << nl
|
|
||||||
<< " foamListTimes -processor -rm -time "
|
|
||||||
<< firstOutput << ":" << nl;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Info<< "\nEnd\n" << endl;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ************************************************************************* //
|
|
||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,3 +1,3 @@
|
|||||||
Test-cpuInfo.cxx
|
Test-cpuInfo.C
|
||||||
|
|
||||||
EXE = $(FOAM_USER_APPBIN)/Test-cpuInfo
|
EXE = $(FOAM_USER_APPBIN)/Test-cpuInfo
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
\\ / A nd | www.openfoam.com
|
\\ / A nd | www.openfoam.com
|
||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2016-2023 OpenCFD Ltd.
|
Copyright (C) 2016 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -39,7 +39,7 @@ using namespace Foam;
|
|||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
Foam::cpuInfo{}.writeEntry("cpu-info", Info);
|
cpuInfo().write(Info);
|
||||||
Info<< endl;
|
Info<< endl;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -1,3 +1,3 @@
|
|||||||
Test-cstring.cxx
|
Test-cstring.C
|
||||||
|
|
||||||
EXE = $(FOAM_USER_APPBIN)/Test-cstring
|
EXE = $(FOAM_USER_APPBIN)/Test-cstring
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
\\ / A nd | www.openfoam.com
|
\\ / A nd | www.openfoam.com
|
||||||
\\/ M anipulation |
|
\\/ M anipulation |
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Copyright (C) 2016-2024 OpenCFD Ltd.
|
Copyright (C) 2016-2017 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -81,7 +81,8 @@ int print(char *argv[])
|
|||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
DynamicList<string> dynlst(16);
|
DynamicList<string> dynlst;
|
||||||
|
dynlst.reserve(16);
|
||||||
|
|
||||||
dynlst.push_back("string1 with content");
|
dynlst.push_back("string1 with content");
|
||||||
dynlst.push_back("string2 other content");
|
dynlst.push_back("string2 other content");
|
||||||
@ -103,18 +104,6 @@ int main(int argc, char *argv[])
|
|||||||
Info<< nl;
|
Info<< nl;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
|
||||||
CStringList inC({ "string1", "string2", "string3", "end" });
|
|
||||||
|
|
||||||
Info<< "null-terminated string list from " << nl;
|
|
||||||
print(inC.strings());
|
|
||||||
|
|
||||||
Info<< "sublist: starting at " << inC.size()/2 << nl;
|
|
||||||
print(inC.strings(inC.size()/2));
|
|
||||||
|
|
||||||
Info<< nl;
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
string testInput
|
string testInput
|
||||||
(
|
(
|
||||||
@ -123,7 +112,7 @@ int main(int argc, char *argv[])
|
|||||||
);
|
);
|
||||||
|
|
||||||
Info<< testInput << nl;
|
Info<< testInput << nl;
|
||||||
auto args = stringOps::splitSpace(testInput);
|
SubStrings<string> args = stringOps::splitSpace(testInput);
|
||||||
Info<< "split into " << args.size() << " args" << nl;
|
Info<< "split into " << args.size() << " args" << nl;
|
||||||
|
|
||||||
CStringList inC(args);
|
CStringList inC(args);
|
||||||
@ -135,7 +124,7 @@ int main(int argc, char *argv[])
|
|||||||
Info<< nl;
|
Info<< nl;
|
||||||
}
|
}
|
||||||
|
|
||||||
Info<< "command-line with " << CStringList::count(argv) << " items" << nl;
|
Info<<"command-line with " << CStringList::count(argv) << " items"<< endl;
|
||||||
|
|
||||||
print(argc, argv);
|
print(argc, argv);
|
||||||
|
|
||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
/*--------------------------------*- C++ -*----------------------------------*\
|
/*--------------------------------*- C++ -*----------------------------------*\
|
||||||
| ========= | |
|
| ========= | |
|
||||||
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
| \\ / F ield | OpenFOAM: The Open Source CFD Toolbox |
|
||||||
| \\ / O peration | Version: v2312 |
|
| \\ / O peration | Version: v2306 |
|
||||||
| \\ / A nd | Website: www.openfoam.com |
|
| \\ / A nd | Website: www.openfoam.com |
|
||||||
| \\/ M anipulation | |
|
| \\/ M anipulation | |
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user