SpecgridWrapper.hpp
Go to the documentation of this file.
1 /*
2  Copyright (C) 2014 by Andreas Lauser
3 
4  This file is part of the Open Porous Media project (OPM).
5 
6  OPM is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  OPM is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with OPM. If not, see <http://www.gnu.org/licenses/>.
18  */
19 #ifndef OPM_PARSER_SPECGRID_WRAPPER_HPP
20 #define OPM_PARSER_SPECGRID_WRAPPER_HPP
21 
23 
24 #include <vector>
25 #include <algorithm>
26 
27 namespace Opm {
29  public:
35  : m_keyword(keyword)
36  {
37  }
38 
42  int numGridBlocksI() const
43  { return m_keyword->getRecord(0)->getItem(0)->getInt(0); }
44 
48  int numGridBlocksJ() const
49  { return m_keyword->getRecord(0)->getItem(1)->getInt(0); }
50 
54  int numGridBlocksK() const
55  { return m_keyword->getRecord(0)->getItem(2)->getInt(0); }
56 
60  std::vector<int> numBlocksVector() const
61  {
62  std::vector<int> dim(3);
63  dim[0] = numGridBlocksI();
64  dim[1] = numGridBlocksJ();
65  dim[2] = numGridBlocksK();
66  return dim;
67  }
68 
72  int numReservoirs() const
73  { return m_keyword->getRecord(0)->getItem(3)->getInt(0); }
74 
82  std::string coordSystemType() const
83  { return m_keyword->getRecord(0)->getItem(4)->getString(0); }
84 
85  private:
86  Opm::DeckKeywordConstPtr m_keyword;
87  };
88 }
89 
90 #endif // OPM_PARSER_SPECGRID_WRAPPER_HPP
91 
SpecgridWrapper(Opm::DeckKeywordConstPtr keyword)
A wrapper class to provide convenient access to the data of the 'SPECGRID' keyword.
Definition: SpecgridWrapper.hpp:34
Definition: Deck.hpp:29
std::string coordSystemType() const
Type of the coordinate system.
Definition: SpecgridWrapper.hpp:82
std::shared_ptr< const DeckKeyword > DeckKeywordConstPtr
Definition: DeckKeyword.hpp:71
int numGridBlocksK() const
Return the number of grid blocks in K direction.
Definition: SpecgridWrapper.hpp:54
int numReservoirs() const
Return the number of reservoirs.
Definition: SpecgridWrapper.hpp:72
int numGridBlocksJ() const
Return the number of grid blocks in J direction.
Definition: SpecgridWrapper.hpp:48
int numGridBlocksI() const
Return the number of grid blocks in I direction.
Definition: SpecgridWrapper.hpp:42
std::vector< int > numBlocksVector() const
The number of IJK grid blocks as a vector.
Definition: SpecgridWrapper.hpp:60
Definition: SpecgridWrapper.hpp:28