mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-16 15:31:55 -06:00
946b5f5806
NOTE: this pull request depends on #2555 which should be merged first. A rewrite of the outdated PR #2543. Refactors flow_ebos_blackoil.cpp such that we can choose not to execute the whole simulation using the flowEbosBlackoilMain() function but instead only initialize by calling flowEbosBlackoilMainInit(). This is necessary to implement a Python step() method that can advance the simulator one report step at a time. Also adds a method initFlowEbosBlackoil() to Main.hpp that can be used directly from the Python interface's BlackOilSimulator object to gain access to the FlowMainEbos object before it has initialized the simulation main loop.
36 lines
1.4 KiB
C++
36 lines
1.4 KiB
C++
/*
|
|
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 FLOW_EBOS_BLACKOIL_HPP
|
|
#define FLOW_EBOS_BLACKOIL_HPP
|
|
|
|
#include <opm/parser/eclipse/Deck/Deck.hpp>
|
|
#include <opm/parser/eclipse/EclipseState/EclipseState.hpp>
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Schedule.hpp>
|
|
#include <opm/parser/eclipse/EclipseState/SummaryConfig/SummaryConfig.hpp>
|
|
#include <opm/simulators/flow/FlowMainEbos.hpp>
|
|
|
|
namespace Opm {
|
|
void flowEbosBlackoilSetDeck(double setupTime, Deck *deck, EclipseState& eclState, Schedule& schedule, SummaryConfig& summaryConfig);
|
|
|
|
int flowEbosBlackoilMain(int argc, char** argv, bool outputCout, bool outputFiles);
|
|
|
|
std::unique_ptr<Opm::FlowMainEbos<TTAG(EclFlowProblem)>>
|
|
flowEbosBlackoilMainInit(int argc, char** argv, bool outputCout, bool outputFiles);
|
|
}
|
|
|
|
#endif // FLOW_EBOS_BLACKOIL_HPP
|