RINGMesh  Version 5.0.0
A programming library for geological model meshes
io_wl.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 
38  class WLIOHandler final: public WellGroupIOHandler {
39  public:
40  void load( const std::string& filename, WellGroup3D& wells ) final
41  {
42  GEO::LineInput in( filename );
43  if( !in.OK() ) {
44  throw RINGMeshException( "I/O", "Could not open file" );
45  }
46 
47  std::unique_ptr< LineMesh3D > mesh = LineMesh3D::create_mesh(
48  GeogramLineMesh3D::type_name_static() );
49  std::unique_ptr< LineMeshBuilder3D > builder =
50  LineMeshBuilder3D::create_builder( *mesh );
51  std::string name;
52  double z_sign = 1.0;
53  vec3 vertex_ref;
54 
55  while( !in.eof() ) {
56  in.get_line();
57  in.get_fields();
58  if( in.nb_fields() == 0 ) continue;
59  if( in.field_matches( 0, "name:" ) ) {
60  name = in.field( 1 );
61  } else if( in.field_matches( 0, "ZPOSITIVE" ) ) {
62  if( in.field_matches( 1, "Depth" ) ) {
63  z_sign = -1.0;
64  }
65  } else if( in.field_matches( 0, "WREF" ) ) {
66  vertex_ref[0] = in.field_as_double( 1 );
67  vertex_ref[1] = in.field_as_double( 2 );
68  vertex_ref[2] = z_sign * in.field_as_double( 3 );
69  builder->create_vertex( vertex_ref );
70  } else if( in.field_matches( 0, "PATH" ) ) {
71  if( in.field_as_double( 1 ) == 0. ) continue;
72  vec3 vertex;
73  vertex[2] = z_sign * in.field_as_double( 2 );
74  vertex[0] = in.field_as_double( 3 ) + vertex_ref[0];
75  vertex[1] = in.field_as_double( 4 ) + vertex_ref[1];
76  index_t id = builder->create_vertex( vertex );
77  builder->create_edge( id - 1, id );
78  } else if( in.field_matches( 0, "END" ) ) {
79  wells.add_well( *mesh, name );
80  mesh = LineMesh < 3
81  > ::create_mesh( GeogramLineMesh3D::type_name_static() );
82  builder = LineMeshBuilder3D::create_builder( *mesh );
83  }
84  }
85  }
86  void save( const WellGroup3D& wells, const std::string& filename ) final
87  {
88  ringmesh_unused( wells );
89  ringmesh_unused( filename );
90  throw RINGMeshException( "I/O",
91  "Saving of a WellGroup from Gocad not implemented yet" );
92  }
93  };
94 
95 }
vecn< 3 > vec3
Definition: types.h:76
void ringmesh_unused(const T &)
Definition: common.h:105