Files
opm-common/opm/input/eclipse/EclipseState/Runspec.hpp
2023-10-11 23:38:42 +02:00

529 lines
13 KiB
C++

/*
Copyright 2016 Statoil ASA.
This file is part of the Open Porous Media project (OPM).
OPM is free software: you can redistribute it and/or modify it under the terms
of the GNU General Public License as published by the Free Software
Foundation, either version 3 of the License, or (at your option) any later
version.
OPM is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with
OPM. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef OPM_RUNSPEC_HPP
#define OPM_RUNSPEC_HPP
#include <opm/common/OpmLog/KeywordLocation.hpp>
#include <opm/input/eclipse/EclipseState/Phase.hpp>
#include <opm/input/eclipse/EclipseState/Tables/Tabdims.hpp>
#include <opm/input/eclipse/EclipseState/Tables/Regdims.hpp>
#include <opm/input/eclipse/EclipseState/EndpointScaling.hpp>
#include <opm/input/eclipse/Schedule/UDQ/UDQParams.hpp>
#include <opm/input/eclipse/Schedule/Action/Actdims.hpp>
#include <optional>
#include <string>
namespace Opm {
class Deck;
class Phases {
public:
Phases() noexcept = default;
Phases( bool oil, bool gas, bool wat, bool solvent = false, bool polymer = false, bool energy = false,
bool polymw = false, bool foam = false, bool brine = false, bool zfraction = false ) noexcept;
static Phases serializationTestObject();
bool active( Phase ) const noexcept;
size_t size() const noexcept;
bool operator==(const Phases& data) const;
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(bits);
}
private:
std::bitset< NUM_PHASES_IN_ENUM > bits;
};
class Welldims {
public:
Welldims() = default;
explicit Welldims(const Deck& deck);
static Welldims serializationTestObject();
int maxConnPerWell() const
{
return this->nCWMax;
}
int maxWellsPerGroup() const
{
return this->nWGMax;
}
int maxGroupsInField() const
{
return this->nGMax;
}
int maxWellsInField() const
{
return this->nWMax;
}
int maxWellListsPrWell() const
{
return this->nWlistPrWellMax;
}
int maxDynamicWellLists() const
{
return this->nDynWlistMax;
}
const std::optional<KeywordLocation>& location() const
{
return this->m_location;
}
static bool rst_cmp(const Welldims& full_dims, const Welldims& rst_dims) {
return full_dims.maxConnPerWell() == rst_dims.maxConnPerWell() &&
full_dims.maxWellsPerGroup() == rst_dims.maxWellsPerGroup() &&
full_dims.maxGroupsInField() == rst_dims.maxGroupsInField() &&
full_dims.maxWellsInField() == rst_dims.maxWellsInField() &&
full_dims.maxWellListsPrWell() == rst_dims.maxWellListsPrWell() &&
full_dims.maxDynamicWellLists() == rst_dims.maxDynamicWellLists();
}
bool operator==(const Welldims& data) const {
return this->location() == data.location() &&
rst_cmp(*this, data);
}
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(nWMax);
serializer(nCWMax);
serializer(nWGMax);
serializer(nGMax);
serializer(nWlistPrWellMax);
serializer(nDynWlistMax);
serializer(m_location);
}
private:
int nWMax { 0 };
int nCWMax { 0 };
int nWGMax { 0 };
int nGMax { 0 };
int nWlistPrWellMax { 1 };
int nDynWlistMax { 1 };
std::optional<KeywordLocation> m_location;
};
class WellSegmentDims {
public:
WellSegmentDims();
explicit WellSegmentDims(const Deck& deck);
static WellSegmentDims serializationTestObject();
int maxSegmentedWells() const
{
return this->nSegWellMax;
}
int maxSegmentsPerWell() const
{
return this->nSegmentMax;
}
int maxLateralBranchesPerWell() const
{
return this->nLatBranchMax;
}
const std::optional<KeywordLocation>& location() const
{
return this->location_;
}
bool operator==(const WellSegmentDims& data) const;
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(nSegWellMax);
serializer(nSegmentMax);
serializer(nLatBranchMax);
serializer(location_);
}
private:
int nSegWellMax;
int nSegmentMax;
int nLatBranchMax;
std::optional<KeywordLocation> location_;
};
class NetworkDims {
public:
NetworkDims();
explicit NetworkDims(const Deck& deck);
static NetworkDims serializationTestObject();
int maxNONodes() const
{
return this->nMaxNoNodes;
}
int maxNoBranches() const
{
return this->nMaxNoBranches;
}
int maxNoBranchesConToNode() const
{
return this->nMaxNoBranchesConToNode;
}
bool active() const;
bool operator==(const NetworkDims& data) const;
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(nMaxNoNodes);
serializer(nMaxNoBranches);
serializer(nMaxNoBranchesConToNode);
}
private:
int nMaxNoNodes;
int nMaxNoBranches;
int nMaxNoBranchesConToNode;
};
class AquiferDimensions {
public:
AquiferDimensions();
explicit AquiferDimensions(const Deck& deck);
static AquiferDimensions serializationTestObject();
int maxAnalyticAquifers() const
{
return this->maxNumAnalyticAquifers;
}
int maxAnalyticAquiferConnections() const
{
return this->maxNumAnalyticAquiferConn;
}
template <class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(this->maxNumAnalyticAquifers);
serializer(this->maxNumAnalyticAquiferConn);
}
private:
int maxNumAnalyticAquifers;
int maxNumAnalyticAquiferConn;
};
bool operator==(const AquiferDimensions& lhs, const AquiferDimensions& rhs);
class EclHysterConfig
{
public:
EclHysterConfig() = default;
explicit EclHysterConfig(const Deck& deck);
static EclHysterConfig serializationTestObject();
/*!
* \brief Specify whether hysteresis is enabled or not.
*/
//void setActive(bool yesno);
/*!
* \brief Returns whether hysteresis is enabled (active).
*/
bool active() const;
/*!
* \brief Return the type of the hysteresis model which is used for capillary pressure.
*
* -1: capillary pressure hysteresis is disabled
* 0: use the Killough model for capillary pressure hysteresis
*/
int pcHysteresisModel() const;
/*!
* \brief Return the type of the hysteresis model which is used for relative permeability.
*
* -1: relperm hysteresis is disabled
* 0: use the Carlson model for relative permeability hysteresis
*/
int krHysteresisModel() const;
/*!
* \brief Regularisation parameter used for Killough model.
*
* default: 0.1
*/
double modParamTrapped() const;
/*!
* \brief Curvature parameter used for capillary pressure hysteresis.
*
* default: 0.1
*/
double curvatureCapPrs() const;
/*!
* \brief Wag hysteresis.
*/
bool activeWag() const;
bool operator==(const EclHysterConfig& data) const;
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(activeHyst);
serializer(pcHystMod);
serializer(krHystMod);
serializer(modParamTrappedValue);
serializer(curvatureCapPrsValue);
serializer(activeWagHyst);
}
private:
// enable hysteresis at all
bool activeHyst { false };
// the capillary pressure and the relperm hysteresis models to be used
int pcHystMod { -1 };
int krHystMod { -1 };
// regularisation parameter used for Killough model
double modParamTrappedValue { 0.1 };
// curvature parameter for capillary pressure
double curvatureCapPrsValue { 0.1 };
// enable WAG hysteresis
bool activeWagHyst { false };
};
class SatFuncControls {
public:
enum class ThreePhaseOilKrModel {
Default,
Stone1,
Stone2
};
enum class KeywordFamily {
Family_I, // SGOF, SWOF, SLGOF
Family_II, // SGFN, SOF{2,3}, SWFN, SGWFN
Family_III, // GSF, WSF
Undefined,
};
SatFuncControls();
explicit SatFuncControls(const Deck& deck);
explicit SatFuncControls(const double tolcritArg,
const ThreePhaseOilKrModel model,
const KeywordFamily family);
static SatFuncControls serializationTestObject();
double minimumRelpermMobilityThreshold() const
{
return this->tolcrit;
}
ThreePhaseOilKrModel krModel() const
{
return this->krmodel;
}
KeywordFamily family() const
{
return this->satfunc_family;
}
bool operator==(const SatFuncControls& rhs) const;
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(tolcrit);
serializer(krmodel);
serializer(satfunc_family);
}
private:
double tolcrit;
ThreePhaseOilKrModel krmodel = ThreePhaseOilKrModel::Default;
KeywordFamily satfunc_family = KeywordFamily::Undefined;
};
class Nupcol {
public:
Nupcol();
explicit Nupcol(int min_value);
void update(int value);
int value() const;
static Nupcol serializationTestObject();
bool operator==(const Nupcol& data) const;
template<class Serializer>
void serializeOp(Serializer& serializer) {
serializer(this->nupcol_value);
serializer(this->min_nupcol);
}
private:
int min_nupcol;
int nupcol_value;
};
class Tracers {
public:
Tracers() = default;
explicit Tracers(const Deck& );
int water_tracers() const;
template<class Serializer>
void serializeOp(Serializer& serializer) {
serializer(this->m_oil_tracers);
serializer(this->m_water_tracers);
serializer(this->m_gas_tracers);
serializer(this->m_env_tracers);
serializer(this->diffusion_control);
serializer(this->max_iter);
serializer(this->min_iter);
}
static Tracers serializationTestObject();
bool operator==(const Tracers& data) const;
private:
int m_oil_tracers;
int m_water_tracers;
int m_gas_tracers;
int m_env_tracers;
bool diffusion_control;
int max_iter;
int min_iter;
// The TRACERS keyword has some additional options which seem quite arcane,
// for now not included here.
};
class Runspec {
public:
Runspec() = default;
explicit Runspec( const Deck& );
static Runspec serializationTestObject();
std::time_t start_time() const noexcept;
const UDQParams& udqParams() const noexcept;
const Phases& phases() const noexcept;
const Tabdims& tabdims() const noexcept;
const Regdims& regdims() const noexcept;
const EndpointScaling& endpointScaling() const noexcept;
const Welldims& wellDimensions() const noexcept;
const WellSegmentDims& wellSegmentDimensions() const noexcept;
const NetworkDims& networkDimensions() const noexcept;
const AquiferDimensions& aquiferDimensions() const noexcept;
int eclPhaseMask( ) const noexcept;
const EclHysterConfig& hysterPar() const noexcept;
const Actdims& actdims() const noexcept;
const SatFuncControls& saturationFunctionControls() const noexcept;
const Nupcol& nupcol() const noexcept;
const Tracers& tracers() const;
bool co2Storage() const noexcept;
bool h2Storage() const noexcept;
bool micp() const noexcept;
bool mech() const noexcept;
bool operator==(const Runspec& data) const;
static bool rst_cmp(const Runspec& full_state, const Runspec& rst_state);
template<class Serializer>
void serializeOp(Serializer& serializer)
{
serializer(this->m_start_time);
serializer(active_phases);
serializer(m_tabdims);
serializer(m_regdims);
serializer(endscale);
serializer(welldims);
serializer(wsegdims);
serializer(netwrkdims);
serializer(aquiferdims);
serializer(udq_params);
serializer(hystpar);
serializer(m_actdims);
serializer(m_sfuncctrl);
serializer(m_nupcol);
serializer(m_co2storage);
serializer(m_h2storage);
serializer(m_micp);
serializer(m_mech);
}
private:
std::time_t m_start_time;
Phases active_phases;
Tabdims m_tabdims;
Regdims m_regdims;
EndpointScaling endscale;
Welldims welldims;
WellSegmentDims wsegdims;
NetworkDims netwrkdims;
AquiferDimensions aquiferdims;
UDQParams udq_params;
EclHysterConfig hystpar;
Actdims m_actdims;
SatFuncControls m_sfuncctrl;
Nupcol m_nupcol;
Tracers m_tracers;
bool m_co2storage;
bool m_h2storage;
bool m_micp;
bool m_mech;
};
}
#endif // OPM_RUNSPEC_HPP