RINGMesh  Version 5.0.0
A programming library for geological model meshes
geomodel_builder_from_mesh.cpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2012-2017, Association Scientifique pour la Geologie et ses
3  * Applications (ASGA). All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  * * Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * * Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  * * Neither the name of ASGA nor the
13  * names of its contributors may be used to endorse or promote products
14  * derived from this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
18  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ASGA BE LIABLE FOR ANY DIRECT,
20  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  *
27  * http://www.ring-team.org
28  *
29  * RING Project
30  * Ecole Nationale Superieure de Geologie - GeoRessources
31  * 2 Rue du Doyen Marcel Roubault - TSA 70605
32  * 54518 VANDOEUVRE-LES-NANCY
33  * FRANCE
34  */
35 
37 
38 #include <stack>
39 
40 #include <geogram/mesh/mesh.h>
41 
48 namespace RINGMesh
49 {
52  {
53  std::vector< index_t > global_vertex_id_to_id_in_cc(
54  mesh_.vertices.nb(), NO_ID );
55 
56  std::vector< bool > visited( mesh_.facets.nb(), false );
57  for( auto i : range( mesh_.facets.nb() ) )
58  {
59  if( !visited[i] )
60  {
61  std::vector< index_t > cc_corners;
62  std::vector< index_t > cc_facets_ptr;
63  std::vector< vec3 > cc_vertices;
64 
68  std::fill( global_vertex_id_to_id_in_cc.begin(),
69  global_vertex_id_to_id_in_cc.end(), NO_ID );
70 
71  // First facet begin at corner 0
72  cc_facets_ptr.push_back( 0 );
73 
74  // Propagate from facet #i
75  std::stack< index_t > S;
76  S.push( i );
77  while( !S.empty() )
78  {
79  index_t f{ S.top() };
80  S.pop();
81  visited[f] = true;
82 
83  for( auto c : range( mesh_.facets.corners_begin( f ),
84  mesh_.facets.corners_end( f ) ) )
85  {
86  index_t v{ mesh_.facet_corners.vertex( c ) };
87  if( global_vertex_id_to_id_in_cc[v] == NO_ID )
88  {
89  index_t index{ static_cast< index_t >(
90  cc_vertices.size() ) };
91  global_vertex_id_to_id_in_cc[v] = index;
92  cc_vertices.push_back( mesh_.vertices.point( v ) );
93  }
94  cc_corners.push_back( global_vertex_id_to_id_in_cc[v] );
95 
96  index_t n{ mesh_.facet_corners.adjacent_facet( c ) };
97  if( n != NO_ID && !visited[n] )
98  {
99  visited[n] = true;
100  S.push( n );
101  }
102  }
103  index_t nb_cc_corners{ static_cast< index_t >(
104  cc_corners.size() ) };
105  cc_facets_ptr.push_back( nb_cc_corners );
106  }
107 
108  gmme_id surface_gme{ topology.create_mesh_entity(
109  Surface3D::type_name_static() ) };
110  geometry.set_surface_geometry( surface_gme.index(), cc_vertices,
111  cc_corners, cc_facets_ptr );
112  }
113  }
114  }
115 
116 } // namespace RINGMesh
GeoModelBuilderGeometry< DIMENSION > geometry
GeoModelBuilderTopology< DIMENSION > topology
Classes to build GeoModel from various inputs.
Definition: algorithm.h:48
This template is a specialization of a gme_id to the GeoModelMeshEntity.
Definition: entity_type.h:285