68 explicit TableManager(
const Deck& deck );
69 TableManager() =
default;
71 static TableManager serializationTestObject();
73 const TableContainer& getTables(
const std::string& tableName )
const;
74 const TableContainer& operator[](
const std::string& tableName)
const;
75 bool hasTables(
const std::string& tableName )
const;
77 const Tabdims& getTabdims()
const;
78 const Eqldims& getEqldims()
const;
79 const Aqudims& getAqudims()
const;
80 const Regdims& getRegdims()
const;
82 const Ppcwmax& getPpcwmax()
const;
86 size_t numFIPRegions()
const;
145 const JFunc& getJFunc()
const;
147 const std::vector<PvtgTable>& getPvtgTables()
const;
148 const std::vector<PvtgwTable>& getPvtgwTables()
const;
149 const std::vector<PvtgwoTable>& getPvtgwoTables()
const;
150 const std::vector<PvtoTable>& getPvtoTables()
const;
151 const std::vector<PvtsolTable>& getPvtsolTables()
const;
152 const std::vector<Rock2dTable>& getRock2dTables()
const;
153 const std::vector<Rock2dtrTable>& getRock2dtrTables()
const;
157 const DenT& WatDenT()
const;
158 const DenT& GasDenT()
const;
159 const DenT& OilDenT()
const;
164 std::size_t gas_comp_index()
const;
166 const std::vector<PvtwsaltTable>& getPvtwSaltTables()
const;
167 const std::vector<RwgsaltTable>& getRwgSaltTables()
const;
168 const std::vector<BrineDensityTable>& getBrineDensityTables()
const;
169 const std::vector<SolventDensityTable>& getSolventDensityTables()
const;
185 const std::map<int, PlymwinjTable>& getPlymwinjTables()
const;
186 const std::map<int, SkprwatTable>& getSkprwatTables()
const;
187 const std::map<int, SkprpolyTable>& getSkprpolyTables()
const;
188 const std::map<std::string, TableContainer>& getSimpleTables()
const;
205 double rtemp()
const;
209 bool diffMoleFraction()
const;
211 bool operator==(
const TableManager& data)
const;
213 template<
class Serializer>
216 auto simpleTables = m_simpleTables;
217 auto split = splitSimpleTable(simpleTables);
218 serializer(simpleTables);
219 serializer(split.plyshMax);
220 serializer(split.plyshMap);
221 serializer(split.rockMax);
222 serializer(split.rockMap);
223 serializer(m_pvtgTables);
224 serializer(m_pvtgwTables);
225 serializer(m_pvtgwoTables);
226 serializer(m_pvtoTables);
227 serializer(m_pvtsolTables);
228 serializer(m_rock2dTables);
229 serializer(m_rock2dtrTables);
230 serializer(m_pvtwTable);
231 serializer(m_pvcdoTable);
232 serializer(m_densityTable);
233 serializer(m_diffCoeffTable);
234 serializer(m_diffCoeffWatTable);
235 serializer(m_diffCoeffGasTable);
236 serializer(m_plyvmhTable);
237 serializer(m_rockTable);
238 serializer(m_plmixparTable);
239 serializer(m_shrateTable);
240 serializer(m_stone1exTable);
241 serializer(m_viscrefTable);
242 serializer(m_watdentTable);
243 serializer(m_sgofletTable);
244 serializer(m_swofletTable);
245 serializer(m_pvtwsaltTables);
246 serializer(m_rwgsaltTables);
247 serializer(m_bdensityTables);
248 serializer(m_sdensityTables);
249 serializer(m_plymwinjTables);
250 serializer(m_skprwatTables);
251 serializer(m_skprpolyTables);
252 serializer(m_tabdims);
253 serializer(m_regdims);
254 serializer(m_eqldims);
255 serializer(m_aqudims);
256 serializer(hasImptvd);
257 serializer(hasEnptvd);
258 serializer(hasEqlnum);
259 serializer(hasShrate);
268 serializer(m_gas_comp_index);
270 serializer(m_salinity);
271 serializer(m_diff_mole_fraction);
272 serializer(m_tlmixpar);
273 serializer(m_ppcwmax);
275 m_simpleTables = simpleTables;
276 if (split.plyshMax > 0) {
278 for (
const auto& it : split.plyshMap) {
279 container.addTable(it.first, it.second);
281 m_simpleTables.insert(std::make_pair(
"PLYSHLOG", container));
283 if (split.rockMax > 0) {
285 for (
const auto& it : split.rockMap) {
286 container.addTable(it.first, it.second);
288 m_simpleTables.insert(std::make_pair(
"ROCKTAB", container));
294 TableContainer& forceGetTables(
const std::string& tableName ,
size_t numTables);
296 void complainAboutAmbiguousKeyword(
const Deck& deck,
const std::string& keywordName);
298 void addTables(
const std::string& tableName ,
size_t numTables);
299 void initSimpleTables(
const Deck& deck);
300 void initRTempTables(
const Deck& deck);
301 void initZmfvdTables(
const Deck& deck);
302 void initDims(
const Deck& deck);
303 void initRocktabTables(
const Deck& deck);
305 void initPlymaxTables(
const Deck& deck);
306 void initRsconstTables(
const Deck& deck);
307 void initPlyrockTables(
const Deck& deck);
308 void initPlyshlogTables(
const Deck& deck);
310 void initPlymwinjTables(
const Deck& deck);
311 void initSkprwatTables(
const Deck& deck);
312 void initSkprpolyTables(
const Deck& deck);
316 template <
class TableType>
317 void initRockTables(
const Deck& deck,
const std::string& keywordName, std::vector<TableType>& rocktable );
319 template <
class TableType>
320 void initPvtwsaltTables(
const Deck& deck, std::vector<TableType>& pvtwtables );
322 template <
class TableType>
323 void initRwgsaltTables(
const Deck& deck, std::vector<TableType>& rwgtables );
325 template <
class TableType>
326 void initBrineTables(
const Deck& deck, std::vector<TableType>& brinetables );
328 void initSolventTables(
const Deck& deck, std::vector<SolventDensityTable>& solventtables);
333 template <
class TableType>
334 void initSimpleTableContainerWithJFunc(
const Deck& deck,
335 const std::string& keywordName,
336 const std::string& tableName,
339 template <
class TableType>
340 void initSimpleTableContainer(
const Deck& deck,
341 const std::string& keywordName,
342 const std::string& tableName,
345 template <
class TableType>
346 void initSimpleTableContainer(
const Deck& deck,
347 const std::string& keywordName,
350 template <
class TableType>
351 void initSimpleTableContainerWithJFunc(
const Deck& deck,
352 const std::string& keywordName,
355 template <
class TableType>
356 void initSimpleTable(
const Deck& deck,
357 const std::string& keywordName,
358 std::vector<TableType>& tableVector);
360 template <
class TableType>
361 void initFullTables(
const Deck& deck,
362 const std::string& keywordName,
363 std::vector<TableType>& tableVector);
365 void checkPVTOMonotonicity(
const Deck& deck)
const;
367 void logPVTOMonotonicityFailure(
const Deck& deck,
368 const std::size_t tableID,
369 const std::vector<PvtoTable::FlippedFVF>& flipped_Bo)
const;
371 std::map<std::string , TableContainer> m_simpleTables;
372 std::vector<PvtgTable> m_pvtgTables;
373 std::vector<PvtgwTable> m_pvtgwTables;
374 std::vector<PvtgwoTable> m_pvtgwoTables;
375 std::vector<PvtoTable> m_pvtoTables;
376 std::vector<PvtsolTable> m_pvtsolTables;
377 std::vector<Rock2dTable> m_rock2dTables;
378 std::vector<Rock2dtrTable> m_rock2dtrTables;
394 std::vector<PvtwsaltTable> m_pvtwsaltTables;
395 std::vector<RwgsaltTable> m_rwgsaltTables;
396 std::vector<BrineDensityTable> m_bdensityTables;
397 std::vector<SolventDensityTable> m_sdensityTables;
398 std::map<int, PlymwinjTable> m_plymwinjTables;
399 std::map<int, SkprwatTable> m_skprwatTables;
400 std::map<int, SkprpolyTable> m_skprpolyTables;
409 bool hasImptvd =
false;
410 bool hasEnptvd =
false;
411 bool hasEqlnum =
false;
412 bool hasShrate =
false;
413 std::optional<JFunc> jfunc;
422 std::size_t m_gas_comp_index = 77;
423 double m_rtemp {288.7056};
424 double m_salinity {0.0};
425 bool m_diff_mole_fraction {
true};
427 struct SplitSimpleTables {
430 std::map<size_t, std::shared_ptr<PlyshlogTable>> plyshMap;
431 std::map<size_t, std::shared_ptr<RocktabTable>> rockMap;
434 SplitSimpleTables splitSimpleTable(std::map<std::string,TableContainer>& simpleTables);