/*---------------------------------------------------------------------------*\
========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration |
\\ / A nd | www.openfoam.com
\\/ M anipulation |
-------------------------------------------------------------------------------
Copyright (C) 2007-2023 PCOpt/NTUA
Copyright (C) 2013-2023 FOSS GP
Copyright (C) 2019 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 .
\*---------------------------------------------------------------------------*/
#include "elasticityMotionSolver.H"
#include "motionInterpolation.H"
#include "motionDiffusivity.H"
#include "wallDist.H"
#include "fixedValuePointPatchFields.H"
#include "fvMatrices.H"
#include "fvcDiv.H"
#include "fvmDiv.H"
#include "fvmDiv.H"
#include "fvmLaplacian.H"
#include "surfaceInterpolate.H"
#include "addToRunTimeSelectionTable.H"
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
namespace Foam
{
defineTypeNameAndDebug(elasticityMotionSolver, 1);
addToRunTimeSelectionTable
(
motionSolver,
elasticityMotionSolver,
dictionary
);
}
// * * * * * * * * * * * * Protected Member Functions * * * * * * * * * * * //
void Foam::elasticityMotionSolver::setBoundaryConditions()
{
// Adjust boundary conditions based on the steps to be executed
forAll(cellMotionU_.boundaryField(), patchI)
{
fvPatchVectorField& bc =
cellMotionU_.boundaryFieldRef()[patchI];
if (isA(bc))
{
auto& fixedValueBCs =
refCast(bc);
fixedValueBCs == fixedValueBCs/scalar(nSteps_);
}
}
/*
// Adjust boundary conditions based on the steps to be executed
forAll(pointMotionU_.boundaryField(), patchI)
{
pointPatchVectorField& pointBCs =
pointMotionU_.boundaryFieldRef()[patchI];
if (isA(pointBCs))
{
auto& fixedValueBCs =
refCast(pointBCs);
fixedValueBCs == fixedValueBCs/scalar(nSteps_);
}
}
// Copy boundary conditions to internalField
// Needed for interpolation to faces
pointMotionU_.boundaryFieldRef().updateCoeffs();
// Interpolate boundary conditions from points to faces
forAll(cellMotionU_.boundaryField(), pI)
{
fvPatchVectorField& bField = cellMotionU_.boundaryFieldRef()[pI];
if (isA(bField))
{
const pointField& points = fvMesh_.points();
const polyPatch& patch = mesh().boundaryMesh()[pI];
forAll(bField, fI)
{
bField[fI] = patch[fI].average(points, pointMotionU_);
}
}
}
*/
}
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
Foam::elasticityMotionSolver::elasticityMotionSolver
(
const polyMesh& mesh,
const IOdictionary& dict
)
:
motionSolver(mesh, dict, typeName),
fvMesh_
(
const_cast
(
refCast(mesh)
)
),
pointMotionU_
(
IOobject
(
"pointMotionU",
mesh.time().timeName(),
mesh,
IOobject::READ_IF_PRESENT,
IOobject::AUTO_WRITE
),
pointMesh::New(mesh),
dimensionedVector(dimless, Zero),
fixedValuePointPatchVectorField::typeName
),
cellMotionU_
(
IOobject
(
"cellMotionU",
mesh.time().timeName(),
mesh,
IOobject::READ_IF_PRESENT,
IOobject::AUTO_WRITE
),
fvMesh_,
dimensionedVector(pointMotionU_.dimensions(), Zero),
pointMotionU_.boundaryField().types()
),
interpolationPtr_
(
coeffDict().found("interpolation")
? motionInterpolation::New(fvMesh_, coeffDict().lookup("interpolation"))
: motionInterpolation::New(fvMesh_)
),
diffusivityPtr_
(
motionDiffusivity::New(fvMesh_, coeffDict().lookup("diffusivity"))
),
nSteps_(this->coeffDict().get