ug4
mark_util.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014-2015: G-CSC, Goethe University Frankfurt
3  * Author: Sebastian Reiter
4  *
5  * This file is part of UG4.
6  *
7  * UG4 is free software: you can redistribute it and/or modify it under the
8  * terms of the GNU Lesser General Public License version 3 (as published by the
9  * Free Software Foundation) with the following additional attribution
10  * requirements (according to LGPL/GPL v3 §7):
11  *
12  * (1) The following notice must be displayed in the Appropriate Legal Notices
13  * of covered and combined works: "Based on UG4 (www.ug4.org/license)".
14  *
15  * (2) The following notice must be displayed at a prominent place in the
16  * terminal output of covered works: "Based on UG4 (www.ug4.org/license)".
17  *
18  * (3) The following bibliography is recommended for citation and must be
19  * preserved in all covered files:
20  * "Reiter, S., Vogel, A., Heppner, I., Rupp, M., and Wittum, G. A massively
21  * parallel geometric multigrid solver on hierarchically distributed grids.
22  * Computing and visualization in science 16, 4 (2013), 151-164"
23  * "Vogel, A., Reiter, S., Rupp, M., Nägel, A., and Wittum, G. UG4 -- a novel
24  * flexible software system for simulating pde based models on high performance
25  * computers. Computing and visualization in science 16, 4 (2013), 165-179"
26  *
27  * This program is distributed in the hope that it will be useful,
28  * but WITHOUT ANY WARRANTY; without even the implied warranty of
29  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
30  * GNU Lesser General Public License for more details.
31  */
32 
33 #ifndef __H__UG_mark_util
34 #define __H__UG_mark_util
35 
36 namespace ug{
37 
39 
45 template <class TEdgeIterator>
46 UG_API
47 void MarkCreaseEdges(Grid& grid, ISubsetHandler& sh,
48  TEdgeIterator edgesBegin, TEdgeIterator edgesEnd,
49  int subsetIndex, number angle,
50  APosition& aPos = aPosition,
51  ANormal* paFaceNormal = NULL);
52 
54 
58 template <class TVertexIterator, class TAPosition>
59 UG_API
60 void MarkCorners(Grid& grid, ISubsetHandler& sh,
61  TVertexIterator vrtsBegin, TVertexIterator vrtsEnd,
62  Grid::edge_traits::callback cbPathEdge,
63  int subsetIndex, number angle,
64  TAPosition& aPos);
65 
66 
67 }// end of namespace
68 
70 // include implementation
71 #include "mark_util_impl.h"
72 
73 #endif //__H__mark_util
#define UG_API
Definition: ug_config.h:65
double number
Definition: types.h:124
the ug namespace
APosition3 APosition
Definition: common_attachments.h:76
ANormal3 ANormal
Definition: common_attachments.h:77
APosition aPosition("position", true)
The standard 3d position type.
Definition: common_attachments.h:84
UG_API void MarkCorners(Grid &grid, ISubsetHandler &sh, TVertexIterator vrtsBegin, TVertexIterator vrtsEnd, Grid::edge_traits::callback cbPathEdge, int subsetIndex, number angle, TAPosition &aPos)
Definition: mark_util_impl.h:84
UG_API void MarkCreaseEdges(Grid &grid, ISubsetHandler &sh, TEdgeIterator edgesBegin, TEdgeIterator edgesEnd, int subsetIndex, number angle, APosition &aPos=aPosition, ANormal *paFaceNormal=NULL)
Definition: mark_util_impl.h:40
boost::function< bool(base_object *)> callback
callback type for the elements base type.
Definition: grid.h:150