opm-simulators/opm/core/props/satfunc/RelpermDiagnostics.hpp

130 lines
4.4 KiB
C++
Raw Normal View History

2015-11-18 19:21:00 -06:00
/*
Copyright 2015 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_RELPERMDIAGNOSTICS_HEADER_INCLUDED
#define OPM_RELPERMDIAGNOSTICS_HEADER_INCLUDED
#include <vector>
#include <utility>
2015-11-29 20:20:43 -06:00
#if HAVE_CONFIG_H
#include "config.h"
2015-11-29 20:20:43 -06:00
#endif // HAVE_CONFIG_H
2015-11-18 19:21:00 -06:00
#include <opm/material/fluidmatrixinteractions/EclEpsScalingPoints.hpp>
namespace Opm {
class EclipseState;
class MiscTable;
class MsfnTable;
class SgcwimTable;
class Sof2Table;
class SorwmisTable;
class SsfnTable;
class SgwfnTable;
///This class is intend to be a relperm diagnostics, to detect
2015-11-18 19:21:00 -06:00
///wrong input of relperm table and endpoints.
2019-10-04 06:22:20 -05:00
class RelpermDiagnostics
2015-11-18 19:21:00 -06:00
{
public:
///This function is used to diagnosis relperm in
2019-10-04 06:22:20 -05:00
///eclipse data file. Errors and warings will be
///output if they're found.
///\param[in] eclState eclipse state.
///\param[in] grid unstructured grid.
template <class CartesianIndexMapper>
void diagnosis(const EclipseState& eclState,
const CartesianIndexMapper& cartesianIndexMapper);
private:
2015-11-29 20:20:43 -06:00
enum FluidSystem {
OilWater,
OilGas,
WaterGas,
2016-03-09 21:17:18 -06:00
BlackOil,
Solvent
2015-11-29 20:20:43 -06:00
};
2019-10-04 06:22:20 -05:00
2015-11-29 20:20:43 -06:00
FluidSystem fluidSystem_;
enum SaturationFunctionFamily {
FamilyI,
FamilyII,
NoFamily
};
2019-10-04 06:22:20 -05:00
SaturationFunctionFamily satFamily_;
2015-11-19 20:57:13 -06:00
std::vector<EclEpsScalingPointsInfo<double> > unscaledEpsInfo_;
std::vector<EclEpsScalingPointsInfo<double> > scaledEpsInfo_;
2015-11-18 19:21:00 -06:00
///Check the phase that used.
/// return false if one-phase system
bool phaseCheck_(const EclipseState& es);
2015-11-18 19:21:00 -06:00
///Check saturation family I and II.
void satFamilyCheck_(const EclipseState& eclState);
2019-10-04 06:22:20 -05:00
2015-11-18 19:21:00 -06:00
///Check saturation tables.
void tableCheck_(const EclipseState& eclState);
2015-11-18 19:21:00 -06:00
///Check endpoints in the saturation tables.
void unscaledEndPointsCheck_(const EclipseState& eclState);
template <class CartesianIndexMapper>
void scaledEndPointsCheck_(const EclipseState& eclState,
const CartesianIndexMapper& cartesianIndexMapper);
2015-11-19 20:57:13 -06:00
2015-11-18 19:21:00 -06:00
///For every table, need to deal with case by case.
void swofTableCheck_(const SwofTable& swofTables,
const int satnumIdx);
void sgofTableCheck_(const SgofTable& sgofTables,
const int satnumIdx);
void slgofTableCheck_(const SlgofTable& slgofTables,
const int satnumIdx);
void swfnTableCheck_(const SwfnTable& swfnTables,
const int satnumIdx);
void sgfnTableCheck_(const SgfnTable& sgfnTables,
const int satnumIdx);
void sof3TableCheck_(const Sof3Table& sof3Tables,
const int satnumIdx);
void sof2TableCheck_(const Sof2Table& sof2Tables,
const int satnumIdx);
void sgwfnTableCheck_(const SgwfnTable& sgwfnTables,
const int satnumIdx);
///Tables for solvent model
void sgcwmisTableCheck_(const SgcwmisTable& sgcwmisTables,
const int satnumIdx);
void sorwmisTableCheck_(const SorwmisTable& sorwmisTables,
const int satnumIdx);
void ssfnTableCheck_(const SsfnTable& ssfnTables,
const int satnumIdx);
void miscTableCheck_(const MiscTable& miscTables,
const int miscnumIdx);
void msfnTableCheck_(const MsfnTable& msfnTables,
const int satnumIdx);
2015-11-18 19:21:00 -06:00
};
} //namespace Opm
#endif // OPM_RELPERMDIAGNOSTICS_HEADER_INCLUDED