23 #include <opm/io/eclipse/EclFile.hpp>
24 #include <opm/io/eclipse/ERst.hpp>
26 #include <opm/input/eclipse/EclipseState/Grid/EclipseGrid.hpp>
40 explicit EModel(
const std::string& filename);
42 bool hasParameter(
const std::string &name)
const;
44 int getActiveReportStep() {
return activeReportStep; }
45 bool hasReportStep(
int rstep);
46 void setReportStep(
int rstep);
48 std::vector<std::tuple<std::string, Opm::EclIO::eclArrType>> getListOfParameters()
const;
50 std::vector<int> getListOfReportSteps()
const {
return rstfile->listOfReportStepNumbers(); };
53 const std::vector<T>& getParam(
const std::string& name);
58 void addFilter(
const std::string& param1,
const std::string& opperator, T num);
61 void addFilter(
const std::string& param1,
const std::string& opperator, T num1, T num2);
63 void setDepthfwl(
const std::vector<float>& fwl);
65 void addHCvolFilter();
67 int getNumberOfActiveCells();
70 std::tuple<int, int, int> gridDims(){
return std::make_tuple(nI, nJ, nK); };
80 bool activeFilter, celVolCalculated;
82 std::vector<float> filteredFloatVect;
83 std::vector<int> filteredIntVect;
85 std::vector<float> PORV;
86 std::vector<float> CELLVOL;
87 std::vector<int> I, J, K;
88 std::vector<bool> ActFilter;
91 std::optional<Opm::EclipseGrid> grid;
92 std::optional<Opm::EclIO::ERst> rstfile;
95 std::map<std::string, int> initParam;
96 std::vector<std::string> initParamName;
97 std::vector<Opm::EclIO::eclArrType> initParamType;
98 std::vector<int> indInInitEclfile;
100 std::map<std::string, int> solutionParam;
101 std::vector<std::string> solutionParamName;
102 std::vector<Opm::EclIO::eclArrType> solutionParamType;
103 std::vector<int> indInRstEclfile;
106 std::vector<float> FreeWaterlevel = {};
108 void get_cell_volumes_from_grid();
109 void initSolutionData(
int rstep);
111 bool hasInitParameter(
const std::string &name)
const;
112 bool hasSolutionParameter(
const std::string &name)
const;
114 const std::vector<float>& getInitFloat(
const std::string& name);
116 const std::vector<float>& getSolutionFloat(
const std::string& name);
118 template <
typename T>
119 const std::vector<T>& get_filter_param(
const std::string& param1);
121 template <
typename T>
122 void updateActiveFilter(
const std::vector<T>& paramVect,
const std::string& opperator, T value);
124 template <
typename T>
125 void updateActiveFilter(
const std::vector<T>& paramVect,
const std::string& opperator, T value1, T value2);
Definition: EModel.hpp:37
Definition: EclFile.hpp:35