mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
303 lines
6.4 KiB
C
303 lines
6.4 KiB
C
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 1991-2009 OpenCFD Ltd.
|
|
\\/ M anipulation |
|
|
-------------------------------------------------------------------------------
|
|
License
|
|
This file is part of OpenFOAM.
|
|
|
|
OpenFOAM is free software; you can redistribute it and/or modify it
|
|
under the terms of the GNU General Public License as published by the
|
|
Free Software Foundation; either version 2 of the License, or (at your
|
|
option) any later version.
|
|
|
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with OpenFOAM; if not, write to the Free Software Foundation,
|
|
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#include "polyMesh.H"
|
|
#include "transform.H"
|
|
|
|
// * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
|
|
|
|
// Update this with w2.
|
|
inline bool Foam::pointEdgeStructuredWalk::update
|
|
(
|
|
const point& pt,
|
|
const pointEdgeStructuredWalk& w2,
|
|
const scalar tol
|
|
)
|
|
{
|
|
if (!valid())
|
|
{
|
|
// current not yet set. Walked from w2 to here (=pt)
|
|
dist_ = w2.dist_ + mag(pt-w2.previousPoint_);
|
|
previousPoint_ = pt;
|
|
data_ = w2.data_;
|
|
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
// Update this with w2 (information on same point)
|
|
inline bool Foam::pointEdgeStructuredWalk::update
|
|
(
|
|
const pointEdgeStructuredWalk& w2,
|
|
const scalar tol
|
|
)
|
|
{
|
|
if (!valid())
|
|
{
|
|
// current not yet set so use neighbour
|
|
dist_ = w2.dist_;
|
|
previousPoint_ = w2.previousPoint_;
|
|
data_ = w2.data_;
|
|
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
// already nearer to pt
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
|
|
|
// Null constructor
|
|
inline Foam::pointEdgeStructuredWalk::pointEdgeStructuredWalk()
|
|
:
|
|
inZone_(false),
|
|
previousPoint_(vector::max),
|
|
dist_(0),
|
|
data_(vector::zero)
|
|
{}
|
|
|
|
|
|
// Construct from origin, distance
|
|
inline Foam::pointEdgeStructuredWalk::pointEdgeStructuredWalk
|
|
(
|
|
const bool inZone,
|
|
const point& previousPoint,
|
|
const scalar dist,
|
|
const vector& data
|
|
)
|
|
:
|
|
inZone_(inZone),
|
|
previousPoint_(previousPoint),
|
|
dist_(dist),
|
|
data_(data)
|
|
{}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
|
|
|
|
inline bool Foam::pointEdgeStructuredWalk::inZone() const
|
|
{
|
|
return inZone_;
|
|
}
|
|
|
|
|
|
inline bool& Foam::pointEdgeStructuredWalk::inZone()
|
|
{
|
|
return inZone_;
|
|
}
|
|
|
|
|
|
inline const Foam::point& Foam::pointEdgeStructuredWalk::previousPoint() const
|
|
{
|
|
return previousPoint_;
|
|
}
|
|
|
|
|
|
inline Foam::scalar Foam::pointEdgeStructuredWalk::dist() const
|
|
{
|
|
return dist_;
|
|
}
|
|
|
|
|
|
inline const Foam::vector& Foam::pointEdgeStructuredWalk::data() const
|
|
{
|
|
return data_;
|
|
}
|
|
|
|
|
|
inline bool Foam::pointEdgeStructuredWalk::valid() const
|
|
{
|
|
return previousPoint_ != vector::max;
|
|
}
|
|
|
|
|
|
// Checks for cyclic points
|
|
inline bool Foam::pointEdgeStructuredWalk::sameGeometry
|
|
(
|
|
const pointEdgeStructuredWalk& w2,
|
|
const scalar tol
|
|
) const
|
|
{
|
|
scalar diff = Foam::mag(dist() - w2.dist());
|
|
|
|
if (diff < SMALL)
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
if ((dist() > SMALL) && ((diff/dist()) < tol))
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
inline void Foam::pointEdgeStructuredWalk::leaveDomain
|
|
(
|
|
const polyPatch& patch,
|
|
const label patchPointI,
|
|
const point& coord
|
|
)
|
|
{
|
|
previousPoint_ -= coord;
|
|
}
|
|
|
|
|
|
inline void Foam::pointEdgeStructuredWalk::transform(const tensor& rotTensor)
|
|
{
|
|
previousPoint_ = Foam::transform(rotTensor, previousPoint_);
|
|
}
|
|
|
|
|
|
// Update absolute geometric quantities. Note that distance (dist_)
|
|
// is not affected by leaving/entering domain.
|
|
inline void Foam::pointEdgeStructuredWalk::enterDomain
|
|
(
|
|
const polyPatch& patch,
|
|
const label patchPointI,
|
|
const point& coord
|
|
)
|
|
{
|
|
// back to absolute form
|
|
previousPoint_ += coord;
|
|
}
|
|
|
|
|
|
// Update this with information from connected edge
|
|
inline bool Foam::pointEdgeStructuredWalk::updatePoint
|
|
(
|
|
const polyMesh& mesh,
|
|
const label pointI,
|
|
const label edgeI,
|
|
const pointEdgeStructuredWalk& edgeInfo,
|
|
const scalar tol
|
|
)
|
|
{
|
|
if (inZone_)
|
|
{
|
|
return update(mesh.points()[pointI], edgeInfo, tol);
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
// Update this with new information on same point
|
|
inline bool Foam::pointEdgeStructuredWalk::updatePoint
|
|
(
|
|
const polyMesh& mesh,
|
|
const label pointI,
|
|
const pointEdgeStructuredWalk& newPointInfo,
|
|
const scalar tol
|
|
)
|
|
{
|
|
if (inZone_)
|
|
{
|
|
return update(mesh.points()[pointI], newPointInfo, tol);
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
// Update this with new information on same point. No extra information.
|
|
inline bool Foam::pointEdgeStructuredWalk::updatePoint
|
|
(
|
|
const pointEdgeStructuredWalk& newPointInfo,
|
|
const scalar tol
|
|
)
|
|
{
|
|
return update(newPointInfo, tol);
|
|
}
|
|
|
|
|
|
// Update this with information from connected point
|
|
inline bool Foam::pointEdgeStructuredWalk::updateEdge
|
|
(
|
|
const polyMesh& mesh,
|
|
const label edgeI,
|
|
const label pointI,
|
|
const pointEdgeStructuredWalk& pointInfo,
|
|
const scalar tol
|
|
)
|
|
{
|
|
if (inZone_)
|
|
{
|
|
const pointField& points = mesh.points();
|
|
|
|
const edge& e = mesh.edges()[edgeI];
|
|
|
|
const point edgeMid(0.5*(points[e[0]] + points[e[1]]));
|
|
|
|
return update(edgeMid, pointInfo, tol);
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * //
|
|
|
|
inline bool Foam::pointEdgeStructuredWalk::operator==
|
|
(
|
|
const Foam::pointEdgeStructuredWalk& rhs
|
|
) const
|
|
{
|
|
return previousPoint() == rhs.previousPoint();
|
|
}
|
|
|
|
|
|
inline bool Foam::pointEdgeStructuredWalk::operator!=
|
|
(
|
|
const Foam::pointEdgeStructuredWalk& rhs
|
|
) const
|
|
{
|
|
return !(*this == rhs);
|
|
}
|
|
|
|
|
|
// ************************************************************************* //
|