This repository has been archived on 2023-11-20. You can view files and clone it, but cannot push or open issues or pull requests.
foam-extend4.1-coherent-io/applications/utilities/mesh/manipulation/attachMesh/attachPolyTopoChanger.H

109 lines
3.4 KiB
C
Raw Normal View History

/*---------------------------------------------------------------------------*\
========= |
2013-12-11 16:09:41 +00:00
\\ / F ield | foam-extend: Open Source CFD
2016-06-20 15:00:40 +00:00
\\ / O peration | Version: 4.0
\\ / A nd | Web: http://www.foam-extend.org
\\/ M anipulation | For copyright notice see file Copyright
-------------------------------------------------------------------------------
License
2013-12-11 16:09:41 +00:00
This file is part of foam-extend.
2013-12-11 16:09:41 +00:00
foam-extend is free software: you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by the
2013-12-11 16:09:41 +00:00
Free Software Foundation, either version 3 of the License, or (at your
option) any later version.
2013-12-11 16:09:41 +00:00
foam-extend 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
2013-12-11 16:09:41 +00:00
along with foam-extend. If not, see <http://www.gnu.org/licenses/>.
Class
2010-09-22 18:13:13 +00:00
Foam::attachPolyTopoChanger
Description
2010-09-22 18:13:13 +00:00
This class is derived from polyMesh and serves as a tool for
statically connecting pieces of a mesh by executing the mesh
modifiers and cleaning the mesh.
The idea is that a mesh can be built from pieces and put together
using various mesh modifiers (mainly sliding interfaces) which are
not needed during the run. Therefore, once the mesh is assembled
and mesh modification triggered, the newly created point, face and
cell zones can be cleared together with the mesh modifiers thus
creating a singly connected static mesh.
Note:
All point, face and cell zoning will be lost! Do it after
attaching the parts of the mesh, as the point, face and cell
numbering changes.
\*---------------------------------------------------------------------------*/
2010-09-22 18:13:13 +00:00
#ifndef attachPolyTopoChanger_H
#define attachPolyTopoChanger_H
2010-09-22 18:13:13 +00:00
#include "polyTopoChanger.H"
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
namespace Foam
{
/*---------------------------------------------------------------------------*\
2010-09-22 18:13:13 +00:00
Class attachPolyTopoChanger Declaration
\*---------------------------------------------------------------------------*/
2010-09-22 18:13:13 +00:00
class attachPolyTopoChanger
:
2010-09-22 18:13:13 +00:00
public polyTopoChanger
{
// Private data
// Private Member Functions
2010-09-22 18:13:13 +00:00
//- Disallow default bitwise copy construct
attachPolyTopoChanger(const attachPolyTopoChanger&);
2010-09-22 18:13:13 +00:00
//- Disallow default bitwise assignment
void operator=(const attachPolyTopoChanger&);
2010-09-22 18:13:13 +00:00
public:
// Constructors
2010-09-22 18:13:13 +00:00
//- Read constructor from IOobject and a polyMesh
attachPolyTopoChanger(const IOobject& io, polyMesh&);
//- Read constructor for given polyMesh
explicit attachPolyTopoChanger(polyMesh&);
// Destructor
2010-09-22 18:13:13 +00:00
virtual ~attachPolyTopoChanger()
{}
// Member Functions
2010-09-22 18:13:13 +00:00
//- Attach mesh. By default filter out empty patches.
void attach(const bool removeEmptyPatches = true);
};
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
} // End namespace Foam
2010-09-22 18:13:13 +00:00
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
#endif
// ************************************************************************* //