mirror of
https://github.com/OPM/opm-simulators.git
synced 2024-12-27 09:40:59 -06:00
f9d47b7c68
Make Opm::FlowMainEbos capture the variables argc, argv, outputCout, and outputFiles. Passing the variables to the constructor and saving them as class variables in Opm::FlowMainEbos makes the implementation of the Python interface simpler. For example, the step_init() method does not need to ask Opm::Main about the values of the variables when it needs to run execute() in FlowMainEbos. Another advantage of this refactoring could be that less variables needs to be passed around from Opm::Main, to flow_ebos_xxx.cpp, and then again to FlowMainEbos.
93 lines
3.3 KiB
C++
93 lines
3.3 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/>.
|
|
*/
|
|
#include "config.h"
|
|
|
|
// Define making clear that the simulator supports AMG
|
|
#define FLOW_SUPPORT_AMG 1
|
|
|
|
#include <flow/flow_ebos_oilwater_polymer_injectivity.hpp>
|
|
|
|
#include <opm/material/common/ResetLocale.hpp>
|
|
#include <opm/models/blackoil/blackoiltwophaseindices.hh>
|
|
|
|
#include <opm/grid/CpGrid.hpp>
|
|
#include <opm/simulators/flow/SimulatorFullyImplicitBlackoilEbos.hpp>
|
|
#include <opm/simulators/flow/FlowMainEbos.hpp>
|
|
|
|
#if HAVE_DUNE_FEM
|
|
#include <dune/fem/misc/mpimanager.hh>
|
|
#else
|
|
#include <dune/common/parallel/mpihelper.hh>
|
|
#endif
|
|
|
|
namespace Opm {
|
|
namespace Properties {
|
|
NEW_TYPE_TAG(EclFlowOilWaterPolymerInjectivityProblem, INHERITS_FROM(EclFlowProblem));
|
|
SET_BOOL_PROP(EclFlowOilWaterPolymerInjectivityProblem, EnablePolymer, true);
|
|
SET_BOOL_PROP(EclFlowOilWaterPolymerInjectivityProblem, EnablePolymerMW, true);
|
|
//! The indices required by the model
|
|
// For this case, there will be two primary variables introduced for the polymer
|
|
// polymer concentration and polymer molecular weight
|
|
SET_PROP(EclFlowOilWaterPolymerInjectivityProblem, Indices)
|
|
{
|
|
private:
|
|
// it is unfortunately not possible to simply use 'TypeTag' here because this leads
|
|
// to cyclic definitions of some properties. if this happens the compiler error
|
|
// messages unfortunately are *really* confusing and not really helpful.
|
|
typedef TTAG(EclFlowProblem) BaseTypeTag;
|
|
typedef typename GET_PROP_TYPE(BaseTypeTag, FluidSystem) FluidSystem;
|
|
|
|
public:
|
|
typedef Opm::BlackOilTwoPhaseIndices<0,
|
|
2,
|
|
0,
|
|
GET_PROP_VALUE(TypeTag, EnableFoam),
|
|
GET_PROP_VALUE(TypeTag, EnableBrine),
|
|
/*PVOffset=*/0,
|
|
/*disabledCompIdx=*/FluidSystem::gasCompIdx> type;
|
|
};
|
|
}}
|
|
|
|
namespace Opm {
|
|
/* void flowEbosOilWaterPolymerInjectivitySetDeck(Deck& deck, EclipseState& eclState)
|
|
{
|
|
typedef TTAG(EclFlowOilWaterPolymerInjectivityProblem) TypeTag;
|
|
typedef GET_PROP_TYPE(TypeTag, Vanguard) Vanguard;
|
|
|
|
Vanguard::setExternalDeck(&deck, &eclState);
|
|
} */
|
|
|
|
// ----------------- Main program -----------------
|
|
int flowEbosOilWaterPolymerInjectivityMain(int argc, char** argv, bool outputCout, bool outputFiles)
|
|
{
|
|
// we always want to use the default locale, and thus spare us the trouble
|
|
// with incorrect locale settings.
|
|
Opm::resetLocale();
|
|
|
|
#if HAVE_DUNE_FEM
|
|
Dune::Fem::MPIManager::initialize(argc, argv);
|
|
#else
|
|
Dune::MPIHelper::instance(argc, argv);
|
|
#endif
|
|
|
|
Opm::FlowMainEbos<TTAG(EclFlowOilWaterPolymerInjectivityProblem)>
|
|
mainfunc {argc, argv, outputCout, outputFiles};
|
|
return mainfunc.execute();
|
|
}
|
|
|
|
}
|