TstepWrapper.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_TSTEP_WRAPPER_HPP
20 #define OPM_PARSER_TSTEP_WRAPPER_HPP
21 
23 
24 #include <vector>
25 #include <algorithm>
26 
27 namespace Opm {
28  class TstepWrapper {
29  public:
35  {
36  m_timesteps = keyword->getSIDoubleData();
37  m_totalTime = std::accumulate(m_timesteps.begin(), m_timesteps.end(), 0.0);
38  }
39 
43  const std::vector<double> &timestepVector() const
44  { return m_timesteps; }
45 
49  double totalTime() const
50  { return m_totalTime; }
51 
52  private:
53  std::vector<double> m_timesteps;
54  double m_totalTime;
55  };
56 }
57 
58 #endif // OPM_PARSER_TSTEP_KEYWORD_HPP
59 
Definition: Deck.hpp:29
std::shared_ptr< const DeckKeyword > DeckKeywordConstPtr
Definition: DeckKeyword.hpp:71
TstepWrapper(Opm::DeckKeywordConstPtr keyword)
A wrapper class to provide convenient access to the data exposed by the 'TSTEP' keyword.
Definition: TstepWrapper.hpp:34
double totalTime() const
Return the total simulation time in seconds.
Definition: TstepWrapper.hpp:49
const std::vector< double > & timestepVector() const
Return the simulated timestep sizes in seconds.
Definition: TstepWrapper.hpp:43
Definition: TstepWrapper.hpp:28