Units/Dimension.hpp
Go to the documentation of this file.
1 /*
2  Copyright 2013 Statoil ASA.
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 
20 #ifndef DIMENSION_H
21 #define DIMENSION_H
22 
23 #include <string>
24 
25 namespace Opm {
26 
27  class Dimension {
28  public:
29  Dimension(const std::string& name, double SIfactor, double SIoffset = 0.0);
30 
31  double getSIScaling() const;
32  double getSIOffset() const;
33 
34  double convertRawToSi(double rawValue) const;
35  double convertSiToRaw(double siValue) const;
36 
37  bool equal(const Dimension& other) const;
38  const std::string& getName() const;
39  bool isCompositable() const;
40  static Dimension * newComposite(const std::string& dim, double SIfactor, double SIoffset = 0.0);
41 
42  private:
43  Dimension();
44  std::string m_name;
45  double m_SIfactor;
46  double m_SIoffset;
47  };
48 }
49 
50 
51 #endif
52 
bool equal(const Dimension &other) const
double convertRawToSi(double rawValue) const
Definition: Deck.hpp:29
bool isCompositable() const
static Dimension * newComposite(const std::string &dim, double SIfactor, double SIoffset=0.0)
double getSIOffset() const
const std::string & getName() const
double convertSiToRaw(double siValue) const
double getSIScaling() const
Dimension(const std::string &name, double SI_factor)