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;
140 const JFunc& getJFunc()
const;
142 const std::vector<PvtgTable>& getPvtgTables()
const;
143 const std::vector<PvtgwTable>& getPvtgwTables()
const;
144 const std::vector<PvtgwoTable>& getPvtgwoTables()
const;
145 const std::vector<PvtoTable>& getPvtoTables()
const;
146 const std::vector<PvtsolTable>& getPvtsolTables()
const;
147 const std::vector<Rock2dTable>& getRock2dTables()
const;
148 const std::vector<Rock2dtrTable>& getRock2dtrTables()
const;
152 const DenT& WatDenT()
const;
153 const DenT& GasDenT()
const;
154 const DenT& OilDenT()
const;
159 std::size_t gas_comp_index()
const;
161 const std::vector<PvtwsaltTable>& getPvtwSaltTables()
const;
162 const std::vector<RwgsaltTable>& getRwgSaltTables()
const;
163 const std::vector<BrineDensityTable>& getBrineDensityTables()
const;
164 const std::vector<SolventDensityTable>& getSolventDensityTables()
const;
180 const std::map<int, PlymwinjTable>& getPlymwinjTables()
const;
181 const std::map<int, SkprwatTable>& getSkprwatTables()
const;
182 const std::map<int, SkprpolyTable>& getSkprpolyTables()
const;
183 const std::map<std::string, TableContainer>& getSimpleTables()
const;
200 double rtemp()
const;
202 double salinity()
const;
206 template<
class Serializer>
209 auto simpleTables = m_simpleTables;
210 auto split = splitSimpleTable(simpleTables);
211 serializer(simpleTables);
212 serializer(split.plyshMax);
213 serializer(split.plyshMap);
214 serializer(split.rockMax);
215 serializer(split.rockMap);
216 serializer(m_pvtgTables);
217 serializer(m_pvtgwTables);
218 serializer(m_pvtgwoTables);
219 serializer(m_pvtoTables);
220 serializer(m_pvtsolTables);
221 serializer(m_rock2dTables);
222 serializer(m_rock2dtrTables);
223 serializer(m_pvtwTable);
224 serializer(m_pvcdoTable);
225 serializer(m_densityTable);
226 serializer(m_diffCoeffTable);
227 serializer(m_diffCoeffWatTable);
228 serializer(m_diffCoeffGasTable);
229 serializer(m_plyvmhTable);
230 serializer(m_rockTable);
231 serializer(m_plmixparTable);
232 serializer(m_shrateTable);
233 serializer(m_stone1exTable);
234 serializer(m_viscrefTable);
235 serializer(m_watdentTable);
236 serializer(m_sgofletTable);
237 serializer(m_swofletTable);
238 serializer(m_pvtwsaltTables);
239 serializer(m_rwgsaltTables);
240 serializer(m_bdensityTables);
241 serializer(m_sdensityTables);
242 serializer(m_plymwinjTables);
243 serializer(m_skprwatTables);
244 serializer(m_skprpolyTables);
245 serializer(m_tabdims);
246 serializer(m_regdims);
247 serializer(m_eqldims);
248 serializer(m_aqudims);
249 serializer(hasImptvd);
250 serializer(hasEnptvd);
251 serializer(hasEqlnum);
252 serializer(hasShrate);
261 serializer(m_gas_comp_index);
263 serializer(m_salinity);
264 serializer(m_tlmixpar);
265 serializer(m_ppcwmax);
267 m_simpleTables = simpleTables;
268 if (split.plyshMax > 0) {
270 for (
const auto& it : split.plyshMap) {
271 container.addTable(it.first, it.second);
273 m_simpleTables.insert(std::make_pair(
"PLYSHLOG", container));
275 if (split.rockMax > 0) {
276 TableContainer container(split.rockMax);
277 for (
const auto& it : split.rockMap) {
278 container.addTable(it.first, it.second);
280 m_simpleTables.insert(std::make_pair(
"ROCKTAB", container));
286 TableContainer& forceGetTables(
const std::string& tableName ,
size_t numTables);
288 void complainAboutAmbiguousKeyword(
const Deck& deck,
const std::string& keywordName);
290 void addTables(
const std::string& tableName ,
size_t numTables);
291 void initSimpleTables(
const Deck& deck);
292 void initRTempTables(
const Deck& deck);
293 void initDims(
const Deck& deck);
294 void initRocktabTables(
const Deck& deck);
296 void initPlymaxTables(
const Deck& deck);
297 void initPlyrockTables(
const Deck& deck);
298 void initPlyshlogTables(
const Deck& deck);
300 void initPlymwinjTables(
const Deck& deck);
301 void initSkprwatTables(
const Deck& deck);
302 void initSkprpolyTables(
const Deck& deck);
306 template <
class TableType>
307 void initRockTables(
const Deck& deck,
const std::string& keywordName, std::vector<TableType>& rocktable );
309 template <
class TableType>
310 void initPvtwsaltTables(
const Deck& deck, std::vector<TableType>& pvtwtables );
312 template <
class TableType>
313 void initRwgsaltTables(
const Deck& deck, std::vector<TableType>& rwgtables );
315 template <
class TableType>
316 void initBrineTables(
const Deck& deck, std::vector<TableType>& brinetables );
318 void initSolventTables(
const Deck& deck, std::vector<SolventDensityTable>& solventtables);
323 template <
class TableType>
324 void initSimpleTableContainerWithJFunc(
const Deck& deck,
325 const std::string& keywordName,
326 const std::string& tableName,
329 template <
class TableType>
330 void initSimpleTableContainer(
const Deck& deck,
331 const std::string& keywordName,
332 const std::string& tableName,
335 template <
class TableType>
336 void initSimpleTableContainer(
const Deck& deck,
337 const std::string& keywordName,
340 template <
class TableType>
341 void initSimpleTableContainerWithJFunc(
const Deck& deck,
342 const std::string& keywordName,
345 template <
class TableType>
346 void initSimpleTable(
const Deck& deck,
347 const std::string& keywordName,
348 std::vector<TableType>& tableVector);
350 template <
class TableType>
351 void initFullTables(
const Deck& deck,
352 const std::string& keywordName,
353 std::vector<TableType>& tableVector);
355 void checkPVTOMonotonicity(
const Deck& deck)
const;
357 void logPVTOMonotonicityFailure(
const Deck& deck,
358 const std::size_t tableID,
359 const std::vector<PvtoTable::FlippedFVF>& flipped_Bo)
const;
361 std::map<std::string , TableContainer> m_simpleTables;
362 std::vector<PvtgTable> m_pvtgTables;
363 std::vector<PvtgwTable> m_pvtgwTables;
364 std::vector<PvtgwoTable> m_pvtgwoTables;
365 std::vector<PvtoTable> m_pvtoTables;
366 std::vector<PvtsolTable> m_pvtsolTables;
367 std::vector<Rock2dTable> m_rock2dTables;
368 std::vector<Rock2dtrTable> m_rock2dtrTables;
369 PvtwTable m_pvtwTable;
370 PvcdoTable m_pvcdoTable;
371 DensityTable m_densityTable;
372 DiffCoeffTable m_diffCoeffTable;
373 DiffCoeffWatTable m_diffCoeffWatTable;
374 DiffCoeffGasTable m_diffCoeffGasTable;
375 PlyvmhTable m_plyvmhTable;
376 RockTable m_rockTable;
377 PlmixparTable m_plmixparTable;
378 ShrateTable m_shrateTable;
379 Stone1exTable m_stone1exTable;
380 ViscrefTable m_viscrefTable;
381 WatdentTable m_watdentTable;
382 SgofletTable m_sgofletTable;
383 SwofletTable m_swofletTable;
384 std::vector<PvtwsaltTable> m_pvtwsaltTables;
385 std::vector<RwgsaltTable> m_rwgsaltTables;
386 std::vector<BrineDensityTable> m_bdensityTables;
387 std::vector<SolventDensityTable> m_sdensityTables;
388 std::map<int, PlymwinjTable> m_plymwinjTables;
389 std::map<int, SkprwatTable> m_skprwatTables;
390 std::map<int, SkprpolyTable> m_skprpolyTables;
399 bool hasImptvd =
false;
400 bool hasEnptvd =
false;
401 bool hasEqlnum =
false;
402 bool hasShrate =
false;
403 std::optional<JFunc> jfunc;
412 std::size_t m_gas_comp_index = 77;
413 double m_rtemp {288.7056};
414 double m_salinity {0.0};
416 struct SplitSimpleTables {
419 std::map<size_t, std::shared_ptr<PlyshlogTable>> plyshMap;
420 std::map<size_t, std::shared_ptr<RocktabTable>> rockMap;
423 SplitSimpleTables splitSimpleTable(std::map<std::string,TableContainer>& simpleTables);