1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
|
// This file is part of ff3d - http://www.freefem.org/ff3d
// Copyright (C) 2005 Stphane Del Pino
// This program 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, or (at your option)
// any later version.
// This program 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 this program; if not, write to the Free Software Foundation,
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
// $Id: MeshPeriodizer.hpp,v 1.3 2006/04/08 10:43:20 delpinux Exp $
#ifndef MESH_PERIODIZER_HPP
#define MESH_PERIODIZER_HPP
#include <MeshGenerator.hpp>
#include <list>
#include <utility>
/**
* @file MeshPeriodizer.hpp
* @author Stephane Del Pino
* @date Sat Jan 8 17:46:03 2005
*
* @brief builts a periodic mesh out from a given mesh
* @note works only for cartesian mesh by now
*/
class MeshPeriodizer
: public MeshGenerator
{
public:
typedef std::list<std::pair<size_t,size_t> > ReferencesMapping;
protected:
ConstReferenceCounting<Mesh> __input; /**< given mesh */
const ReferencesMapping __referencesMapping; /**< the periodic description */
/**
* This template function builds the mesh for a given type of input
* mesh
*
* @param builtLocalizationTools tells to build or not the localization tools
*/
template <typename MeshType>
void __build(const bool& builtLocalizationTools);
private:
/**
* Forbiden copy constructor
*
* @param M a given MeshPeriodizer
*
*/
MeshPeriodizer(const MeshPeriodizer& M);
public:
/**
* Runs the tetrahedral mesh generation
*
* @param builtLocalizationTools tells to build or not the localization tools
*
*/
virtual void run(const bool& builtLocalizationTools = true);
/**
* Constructor
*
* @param inputMesh the mesh to tetrahedrize
* @param referencesMapping periodic references mapping
*
*/
MeshPeriodizer(ConstReferenceCounting<Mesh> inputMesh,
const ReferencesMapping& referencesMapping)
: MeshGenerator(),
__input(inputMesh),
__referencesMapping(referencesMapping)
{
;
}
/**
* Destructor
*
*/
virtual ~MeshPeriodizer()
{
;
}
};
#endif // MESH_PERIODIZER_HPP
|