mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-17 03:01:56 -06:00
1544f84fb4
Add keywords WSEGDFIN - WSEGTABL as not supported
499 lines
14 KiB
C++
499 lines
14 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/>.
|
|
*/
|
|
|
|
#include <opm/simulators/flow/MissingFeatures.hpp>
|
|
|
|
#include <opm/common/OpmLog/OpmLog.hpp>
|
|
|
|
#include <opm/parser/eclipse/Deck/DeckKeyword.hpp>
|
|
#include <opm/parser/eclipse/Parser/Parser.hpp>
|
|
#include <opm/parser/eclipse/Parser/ParseContext.hpp>
|
|
#include <opm/parser/eclipse/Parser/ErrorGuard.hpp>
|
|
#include <opm/parser/eclipse/Parser/ParserKeywords/C.hpp>
|
|
#include <opm/parser/eclipse/Parser/ParserKeywords/E.hpp>
|
|
#include <opm/parser/eclipse/Parser/ParserKeywords/P.hpp>
|
|
|
|
#include <unordered_set>
|
|
#include <string>
|
|
#include <map>
|
|
#include <boost/lexical_cast.hpp>
|
|
|
|
namespace Opm {
|
|
|
|
namespace MissingFeatures {
|
|
|
|
|
|
template <typename Keyword, typename Item, typename T>
|
|
void addSupported(std::multimap<std::string, PartiallySupported<T> >& map, T itemValue)
|
|
{
|
|
std::pair<std::string,PartiallySupported<T> > pair({Keyword::keywordName, PartiallySupported<T>{Item::itemName , itemValue}});
|
|
map.insert(pair);
|
|
}
|
|
|
|
|
|
template <typename T>
|
|
void checkOptions(const DeckKeyword& keyword, std::multimap<std::string , PartiallySupported<T> >& map, const ParseContext& parseContext, ErrorGuard& errorGuard)
|
|
{
|
|
// check for partially supported keywords.
|
|
typename std::multimap<std::string, PartiallySupported<T> >::iterator it, itlow, itup;
|
|
itlow = map.lower_bound(keyword.name());
|
|
itup = map.upper_bound(keyword.name());
|
|
for (it = itlow; it != itup; ++it) {
|
|
const auto& record = keyword.getRecord(0);
|
|
if (record.getItem(it->second.item).template get<T>(0) != it->second.item_value) {
|
|
std::string msg = "For keyword '" + it->first + "' only value " + boost::lexical_cast<std::string>(it->second.item_value)
|
|
+ " in item " + it->second.item + " is supported by flow.\n"
|
|
+ "In file " + keyword.getFileName() + ", line " + std::to_string(keyword.getLineNumber()) + "\n";
|
|
parseContext.handleError(ParseContext::SIMULATOR_KEYWORD_ITEM_NOT_SUPPORTED, msg, errorGuard);
|
|
}
|
|
}
|
|
}
|
|
|
|
template <typename T>
|
|
void checkKeywords(const Deck& deck, const ParseContext& parseContext, T&& errorGuard) {
|
|
checkKeywords(deck, parseContext, errorGuard);
|
|
}
|
|
|
|
void checkKeywords(const Deck& deck) {
|
|
checkKeywords(deck, ParseContext(), ErrorGuard());
|
|
}
|
|
|
|
void checkKeywords(const Deck& deck, const ParseContext& parseContext, ErrorGuard& errorGuard)
|
|
{
|
|
// These keywords are supported by opm-parser, but are not supported
|
|
// by flow. For some of them, only part of the options are supported.
|
|
// The list is used to output messages only.
|
|
std::unordered_set<std::string> unsupported_keywords = {
|
|
"ACTION",
|
|
"ACTIONG",
|
|
"ACTIONR",
|
|
"ACTIONW",
|
|
"ACTIONX",
|
|
"ACTPARAM",
|
|
"ADSALNOD",
|
|
"ADDZCORN",
|
|
"AITSOFF",
|
|
"ALKADS",
|
|
"ALKALINE",
|
|
"ALKROCK",
|
|
"API",
|
|
"ALPOLADS",
|
|
"ALSURFAD",
|
|
"ALSURFST",
|
|
"APIGROUP",
|
|
"AQANCONL",
|
|
"AQANNC",
|
|
"AQANTRC",
|
|
"AQUCON",
|
|
"AQUCWFAC",
|
|
"AQUFET",
|
|
"AQUFLUX",
|
|
"AQUNNC",
|
|
"AQUNUM",
|
|
"AUTOCOAR",
|
|
"AUTOREF",
|
|
"BIGMODEL",
|
|
"BOUNDARY",
|
|
"BPARA",
|
|
"BPIDIMS",
|
|
"BRANPROP",
|
|
"BRINE",
|
|
"BTOBALFA",
|
|
"BTOBALFV",
|
|
"CALTRAC",
|
|
"CARFIN",
|
|
"CART",
|
|
"CBMOPTS",
|
|
"CECON",
|
|
"COAL",
|
|
"COALADS",
|
|
"COALPP",
|
|
"COARSEN",
|
|
"COLLAPSE",
|
|
"COLUMNS",
|
|
"CBMOPTS",
|
|
"COMPDATX",
|
|
"COMPIMB",
|
|
"COMPFLSH",
|
|
"COMPINJK",
|
|
"COMPLMPL",
|
|
"COMPOFF",
|
|
"COMPRIV",
|
|
"COMPRP",
|
|
"COMPRPL",
|
|
"COMPSEGL",
|
|
"COMPSEGS",
|
|
"COMPVE",
|
|
"COMPVEL",
|
|
"CSKIN",
|
|
"CONNECTION",
|
|
"CONNECTION_PROBE",
|
|
"COORDSYS",
|
|
"COPYBOX",
|
|
"COPYREG",
|
|
"CRITPERM",
|
|
"DATE",
|
|
"DATUMR",
|
|
"DATUMRX",
|
|
"DCQDEFN",
|
|
"DELAYACT",
|
|
"DEPTHTAB",
|
|
"DIAGDISP",
|
|
"DIFF",
|
|
"DIFFC",
|
|
"DIFFCOAL",
|
|
"DIFFDP",
|
|
"DIFFMMF",
|
|
"DIFFMR",
|
|
"DIFFMTHT",
|
|
"DIFFMX",
|
|
"DIFFMY",
|
|
"DIFFMZ",
|
|
"DIFFR",
|
|
"DIFFTHT",
|
|
"DIFFUSE"
|
|
"DIFFX",
|
|
"DIFFY",
|
|
"DIFFZ",
|
|
"DIMPES",
|
|
"DIMPLICT",
|
|
"DISPDIMS",
|
|
"DISPERSE",
|
|
"DOMAINS",
|
|
"DPGRID",
|
|
"DPKRMOD",
|
|
"DPNUM",
|
|
"DRILPRI",
|
|
"DSPDEINT",
|
|
"DUALPERM",
|
|
"DUALPORO",
|
|
"DUMPCUPL",
|
|
"DYNRDIMS",
|
|
"DZMATRIX",
|
|
"DZMTRX",
|
|
"DZMTRXV",
|
|
"DZNET",
|
|
"ECLMC",
|
|
"EDITNNCR",
|
|
"EHYSTRR",
|
|
"ENDACTIO",
|
|
"ENDDYN",
|
|
"ENDFIN",
|
|
"ENDNUM",
|
|
"ENDSKIP",
|
|
"ENKSRVD",
|
|
"ENPCVD",
|
|
"ENPTVD",
|
|
"ENSPCVD",
|
|
"EPSDBGS",
|
|
"EPSDEBUG",
|
|
"EQLZCORN",
|
|
"EQUALREG",
|
|
"ESSNODE",
|
|
"EXCAVATE",
|
|
"EXCEL",
|
|
"EXTFIN",
|
|
"EXTHOST",
|
|
"EXTRAPMS",
|
|
"EXTREPGL",
|
|
"FBHPDEF",
|
|
"FHERCHBL",
|
|
"FIPNUM",
|
|
"FIPSEP",
|
|
"FLUXREG",
|
|
"FLUXTYPE",
|
|
"FMTHMD",
|
|
"FOAMDCYO",
|
|
"FOAMDCYW",
|
|
"FOAMFCN",
|
|
"FOAMFRM",
|
|
"FOAMFSO"
|
|
"FOAMFST",
|
|
"FOAMFSW",
|
|
"FOAMMOBP",
|
|
"FOAMMOBS",
|
|
"FORMFEED",
|
|
"FULLIMP",
|
|
"GASBEGIN",
|
|
"GASCONC",
|
|
"GASEND",
|
|
"GASFCOMP",
|
|
"GASFDECR",
|
|
"GASFDELC",
|
|
"GASFIELD",
|
|
"GASFTARG",
|
|
"GASMONTH",
|
|
"GASPERIO",
|
|
"GASSATC",
|
|
"GASYEAR",
|
|
"GCALECON",
|
|
"GCONCAL",
|
|
"GCONENG",
|
|
"GCONSALE",
|
|
"GCONSUMP",
|
|
"GCONTOL",
|
|
"GCUTBACK",
|
|
"GCVD",
|
|
"GDCQ",
|
|
"GDCQECON",
|
|
"GDIMS",
|
|
"GDORIENT",
|
|
"GDRILPOT",
|
|
"GECON",
|
|
"GETGLOB",
|
|
"GI",
|
|
"GIMODEL",
|
|
"GINODE",
|
|
"GLIFTLIM",
|
|
"GLIFTOPT",
|
|
"GNETDP",
|
|
"GNETINJE",
|
|
"GNETPUMP",
|
|
"GPMAINT",
|
|
"GRADGRUP",
|
|
"GRADRESV",
|
|
"GRADRFT",
|
|
"GRADWELL",
|
|
"GRAVCONS",
|
|
"GRAVDR",
|
|
"GRAVDRB",
|
|
"GRAVDRM",
|
|
"GRDREACH",
|
|
"GRIDUNIT",
|
|
"GRUPMAST",
|
|
"GRUPNET",
|
|
"GRUPRIG",
|
|
"GSATPROD",
|
|
"GUIDERAT",
|
|
"IMKRVD",
|
|
"IMPES",
|
|
"IMPTVD",
|
|
"LCUNIT",
|
|
"LGR",
|
|
"LINCOM",
|
|
"LIFTOPT",
|
|
"MAPUNITS",
|
|
"MAXVALUE",
|
|
"MINVALUE",
|
|
"MONITOR",
|
|
"MSGFILE",
|
|
"MULT_XYZ",
|
|
"NETBALAN",
|
|
"NEXTSTEP",
|
|
"NNEWTF",
|
|
"NOCASC",
|
|
"NODEPROP",
|
|
"NOGGF",
|
|
"NOINSPEC",
|
|
"NOMONITO",
|
|
"NONNC",
|
|
"NORSSPEC",
|
|
"NOWARN",
|
|
"NSTACK",
|
|
"NUMRES",
|
|
"NUPCOL",
|
|
"OILVISCT",
|
|
"OLDTRAN",
|
|
"OPERATER",
|
|
"OPTIONS",
|
|
"PARALLEL",
|
|
"PBVD",
|
|
"PCG",
|
|
"PERMR",
|
|
"PERMTHT",
|
|
"PERMXY",
|
|
"PERMYZ",
|
|
"PERMZX",
|
|
"PIMULTAB",
|
|
"PLYADSS",
|
|
"PLYDHFLF",
|
|
"PPCWMAX",
|
|
"REFINE",
|
|
"RADFIN4",
|
|
"RHO",
|
|
"RKTRMDIR",
|
|
"ROCKCOMP",
|
|
"ROCKOPTS",
|
|
"ROCKTAB",
|
|
"RPTGRID",
|
|
"RPTONLY",
|
|
"RPTONLYO",
|
|
"RPTPROS",
|
|
"PRTRST",
|
|
"RPTRUNSP",
|
|
"RPTSMRY",
|
|
"RSCONST",
|
|
"RSCONSTT",
|
|
"RTEMP",
|
|
"RTEMPA",
|
|
"RTEMPVD",
|
|
"RUNSUM",
|
|
"SATOPTS",
|
|
"SAVE",
|
|
"SEPARATE",
|
|
"SKIP",
|
|
"SKIP100",
|
|
"SKIP300",
|
|
"SKIPREST",
|
|
"SUMTHIN",
|
|
"TEMP",
|
|
"TEMPNODE",
|
|
"TEMPTVD",
|
|
"TEMPVD",
|
|
"TIGHTEN",
|
|
"TIGHTENP",
|
|
"TIME",
|
|
"TPAMEPS",
|
|
"TPAMEPSS",
|
|
"TRACERKM",
|
|
"TRACERKP",
|
|
"TRACITVD",
|
|
"TRACTVD",
|
|
"THCONR",
|
|
"TRACER",
|
|
"TRACERS",
|
|
"VAPPARS",
|
|
"UDTDIMS",
|
|
"UNCODHMD",
|
|
"UNIFOUTS",
|
|
"UNIFSAVE",
|
|
"USECUPL",
|
|
"USEFLUX",
|
|
"USENOFLO",
|
|
"VDFLOW",
|
|
"VDFLOWR",
|
|
"VE",
|
|
"VEDEBUG",
|
|
"VEFIN",
|
|
"VEFRAC",
|
|
"VEFRACP",
|
|
"VEFRACPV",
|
|
"VEFRACV",
|
|
"VFPCHK",
|
|
"VFPTABL",
|
|
"VISAGE",
|
|
"VISCD",
|
|
"VISCREF",
|
|
"VISDATES",
|
|
"VISOPTS",
|
|
"WAGHYSTR",
|
|
"WAITBAL",
|
|
"WALKALIN",
|
|
"WALQCALC",
|
|
"WAPI",
|
|
"WARN",
|
|
"WATVISCT",
|
|
"WBHGLR",
|
|
"WBOREVOL",
|
|
"WCALCVAL",
|
|
"WCONINJH",
|
|
"WCUTBACK",
|
|
"WCUTBACT",
|
|
"WCYCLE",
|
|
"WDFAC",
|
|
"WDRILPRI",
|
|
"WDRILRES",
|
|
"WECONINJ",
|
|
"WECONT",
|
|
"WELCNTL",
|
|
"WELDEBUG",
|
|
"WELDRAW",
|
|
"WELEVNT",
|
|
"WELOPENL"
|
|
"WELPI",
|
|
"WELPRI",
|
|
"WELSOMIN",
|
|
"WELSPECL",
|
|
"WFRICSEG",
|
|
"WFRICSGL",
|
|
"WFRICTN",
|
|
"WFRICTNL",
|
|
"WGASPROD",
|
|
"WGORPEN",
|
|
"WH2NUM",
|
|
"WH3NUM",
|
|
"WHEDREFD",
|
|
"WHTEMP",
|
|
"WINJMULT",
|
|
"WLIMTOL",
|
|
"WLISTARG",
|
|
"WLISTNAM",
|
|
"WLISTOPT",
|
|
"WNETCTRL",
|
|
"WNETDP",
|
|
"WORKTHP",
|
|
"WPAVE",
|
|
"WPIMULTL",
|
|
"WPITAB",
|
|
"WPLUG",
|
|
"WPOLYRED",
|
|
"WPOTCALC",
|
|
"WREGROUP",
|
|
"WSALT",
|
|
"WSCCLEAN",
|
|
"WSCCLENL",
|
|
"WSCTAB",
|
|
"WSEGAICD",
|
|
"WSEGDFIN",
|
|
"WSEGDFMD",
|
|
"WSEGDFPA",
|
|
"WSEGEXSS",
|
|
"WSEGFLIM",
|
|
"WSEGFMOD",
|
|
"WSEGINIT",
|
|
"WSEGLABY",
|
|
"WSEGLINK",
|
|
"WSEGMULT",
|
|
"WSEGPROP",
|
|
"WSEGPULL",
|
|
"WSEGSEP",
|
|
"WSEGSOLV",
|
|
"WSEGTABL",
|
|
"WTEMP",
|
|
"WTRACER",
|
|
"ZIPPY2",
|
|
"ZIPP2OFF"};
|
|
|
|
|
|
std::multimap<std::string, PartiallySupported<std::string> > string_options;
|
|
std::multimap<std::string, PartiallySupported<int> > int_options;
|
|
addSupported<ParserKeywords::COMPORD, ParserKeywords::COMPORD::ORDER_TYPE, std::string>(string_options , "INPUT");
|
|
addSupported<ParserKeywords::ENDSCALE, ParserKeywords::ENDSCALE::DIRECT, std::string>(string_options, "NODIR");
|
|
addSupported<ParserKeywords::ENDSCALE, ParserKeywords::ENDSCALE::IRREVERS, std::string>(string_options, "REVER");
|
|
addSupported<ParserKeywords::PINCH, ParserKeywords::PINCH::CONTROL_OPTION, std::string>(string_options, "GAP");
|
|
addSupported<ParserKeywords::PINCH, ParserKeywords::PINCH::PINCHOUT_OPTION, std::string>(string_options, "TOPBOT");
|
|
addSupported<ParserKeywords::EHYSTR, ParserKeywords::EHYSTR::relative_perm_hyst, int>(int_options , 0);
|
|
|
|
// check deck and keyword for flow and parser.
|
|
for (size_t idx = 0; idx < deck.size(); ++idx) {
|
|
const auto& keyword = deck.getKeyword(idx);
|
|
std::unordered_set<std::string>::const_iterator it;
|
|
it = unsupported_keywords.find(keyword.name());
|
|
if (it != unsupported_keywords.end()) {
|
|
std::string msg = "Keyword '" + keyword.name() + "' is not supported by flow.\n"
|
|
+ "In file " + keyword.getFileName() + ", line " + std::to_string(keyword.getLineNumber()) + "\n";
|
|
parseContext.handleError(ParseContext::SIMULATOR_KEYWORD_NOT_SUPPORTED, msg, errorGuard);
|
|
}
|
|
checkOptions<std::string>(keyword, string_options, parseContext, errorGuard);
|
|
checkOptions<int>(keyword, int_options, parseContext, errorGuard);
|
|
}
|
|
}
|
|
} // namespace MissingFeatures
|
|
} // namespace Opm
|