Gudhi  1.1.0
 All Classes Functions Typedefs Friends Groups Pages
Top_faces.h
1  /* This file is part of the Gudhi Library. The Gudhi library
2  * (Geometric Understanding in Higher Dimensions) is a generic C++
3  * library for computational topology.
4  *
5  * Author(s): David Salinas
6  *
7  * Copyright (C) 2014 INRIA Sophia Antipolis-Mediterranee (France)
8  *
9  * This program is free software: you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation, either version 3 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program. If not, see <http://www.gnu.org/licenses/>.
21  */
22 #ifndef TOP_FACES_H_
23 #define TOP_FACES_H_
24 
25 #include <list>
26 #include <vector>
27 #include <set>
28 
29 template<typename SimplexHandle>
30 std::list<SimplexHandle> subfaces(SimplexHandle top_face){
31  std::list<SimplexHandle> res;
32  if(top_face.dimension()==-1) return res;
33  if(top_face.dimension()==0) {
34  res.push_back(top_face);
35  return res;
36  }
37  else{
38  auto first_vertex = top_face.first_vertex();
39  top_face.remove_vertex(first_vertex);
40  res = subfaces(top_face);
41  std::list<SimplexHandle> copy = res;
42  for(auto& simplex : copy){
43  simplex.add_vertex(first_vertex);
44  }
45  res.push_back(SimplexHandle(first_vertex));
46  res.splice(res.end(),copy);
47  return res;
48  }
49 }
50 
54 template<typename SimplexHandle>
55 void register_faces(
56  std::vector< std::set<SimplexHandle> >& simplices_per_dimension,
57  const SimplexHandle& top_face){
58  std::list<SimplexHandle> subfaces_list = subfaces(top_face);
59  for(auto& simplex : subfaces_list ){
60  simplices_per_dimension[simplex.dimension()].insert(simplex);
61  }
62 }
63 
64 
65 
66 
67 #endif /* TOP_FACES_H_ */