RINGMesh  Version 5.0.0
A programming library for geological model meshes
io_smesh.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 
36 namespace {
37 
42  class SMESHIOHandler final: public GeoModelIOHandler< 3 > {
43  public:
44  void load( const std::string& filename, GeoModel3D& geomodel ) final
45  {
46  ringmesh_unused( filename );
47  ringmesh_unused( geomodel );
48  throw RINGMeshException( "I/O",
49  "Geological model loading of a from UCD mesh not yet implemented" );
50  }
51 
52  void save( const GeoModel3D& geomodel, const std::string& filename ) final
53  {
54  std::ofstream out( filename.c_str() );
55  if( out.bad() ) {
56  Logger::err( "I/O", "Error when opening the file: ",
57  filename.c_str() );
58  return;
59  }
60  out.precision( 16 );
61 
63  out << "# Node list" << EOL;
64  out << "# node count, 3 dim, no attribute, no boundary marker"
65  << EOL;
66  out << geomodel.mesh.vertices.nb() << " 3 0 0" << EOL;
67  out << "# node index, node coordinates " << EOL;
68  for( auto p : range( geomodel.mesh.vertices.nb() ) ) {
69  const vec3& V = geomodel.mesh.vertices.vertex( p );
70  out << p << " " << " " << V.x << " " << V.y << " " << V.z
71  << EOL;
72  }
73 
75  out << "# Part 2 - facet list" << EOL;
76  out << "# facet count, no boundary marker" << EOL;
77  out << nb_polygons( geomodel ) << " 0 " << EOL;
78 
79  for( const auto& surface : geomodel.surfaces() ) {
80  for( auto p : range( surface.nb_mesh_elements() ) ) {
81  out << surface.nb_mesh_element_vertices( p ) << " ";
82  for( auto v : range( surface.nb_mesh_element_vertices( p ) ) ) {
83  out
84  << geomodel.mesh.vertices.geomodel_vertex_id(
85  surface.gmme(), ElementLocalVertex( p, v ) ) << " ";
86  }
87  out << EOL;
88  }
89  }
90 
91  // Do not forget the stupid zeros at the end of the file
92  out << EOL << "0" << EOL << "0" << EOL;
93  out << std::flush;
94  }
95  };
96 
97 }
vecn< 3 > vec3
Definition: types.h:76
void ringmesh_unused(const T &)
Definition: common.h:105
const char EOL
Definition: io.h:45