mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-19 16:32:56 -06:00
57 lines
2.1 KiB
C++
57 lines
2.1 KiB
C++
#include <opm/parser/eclipse/Parser/Parser.hpp>
|
|
#include <opm/parser/eclipse/Parser/ParseContext.hpp>
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Schedule.hpp>
|
|
|
|
#include <opm/grid/UnstructuredGrid.h>
|
|
#include <opm/core/grid/cornerpoint_grid.h>
|
|
#include <opm/grid/GridManager.hpp>
|
|
#include <opm/autodiff/GridHelpers.hpp>
|
|
#include <opm/simulators/thresholdPressures.hpp> // Note: the GridHelpers must be included before this (to make overloads available)
|
|
|
|
|
|
static DeckPtr createDeckSimConfig() {
|
|
const std::string& inputStr = "RUNSPEC\n"
|
|
"EQLOPTS\n"
|
|
"THPRES /\n "
|
|
"DIMENS\n"
|
|
"10 3 4 /\n"
|
|
"\n"
|
|
"GRID\n"
|
|
"REGIONS\n"
|
|
"EQLNUM\n"
|
|
"10*1 10*2 100*3 /\n "
|
|
"\n"
|
|
|
|
"SOLUTION\n"
|
|
"THPRES\n"
|
|
"1 2 12.0/\n"
|
|
"1 3 5.0/\n"
|
|
"2 3 7.0/\n"
|
|
"/\n"
|
|
"\n";
|
|
|
|
|
|
ParserPtr parser(new Parser());
|
|
return parser->parseString(inputStr, ParseContext()) ;
|
|
}
|
|
|
|
/*
|
|
The main purpose of this is to get the code in
|
|
thresholdPressures.hpp to compile; it currently has no users in the
|
|
opm-core codebase.
|
|
*/
|
|
|
|
BOOST_AUTO_TEST_CASE(CreateSimulationConfig) {
|
|
ParseContext parseContext;
|
|
typedef UnstructuredGrid Grid;
|
|
DeckPtr deck = createDeckSimConfig();
|
|
EclipseState state(*deck, parseContext);
|
|
EclipseGridConstPtr eclipseGrid = state.getInputGrid();
|
|
std::vector<double> porv = eclipseState->getDoubleGridProperty("PORV")->getData();
|
|
GridManager vanguard( eclipseState->getInputGrid(), porv );
|
|
const Grid& grid = *(vanguard.c_grid());
|
|
|
|
std::vector<double> threshold_pressures = thresholdPressures(parseContext, eclipseState, grid);
|
|
BOOST_CHECK( threshold_pressures.size() > 0 );
|
|
}
|