mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-02 12:36:54 -06:00
75104fd310
We resort to consistently use unique_ptrs in EclBaseVanguard for the data read from ECL files or set externally. This means that during the simulation EclBaseVanguard owns this data and not Main or the ebos setup functions. This ownership transfer becomes transparent due to std::move. This came up when trying to fix the parallel runs of ebos and during that removing some code duplication.
75 lines
2.5 KiB
C++
75 lines
2.5 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"
|
|
|
|
#include <flow/flow_ebos_foam.hpp>
|
|
|
|
#include <opm/material/common/ResetLocale.hpp>
|
|
#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(EclFlowFoamProblem, INHERITS_FROM(EclFlowProblem));
|
|
SET_BOOL_PROP(EclFlowFoamProblem, EnableFoam, true);
|
|
}}
|
|
|
|
namespace Opm {
|
|
void flowEbosFoamSetDeck(double setupTime, std::unique_ptr<Deck> deck,
|
|
std::unique_ptr<EclipseState> eclState,
|
|
std::unique_ptr<Schedule> schedule,
|
|
std::unique_ptr<SummaryConfig> summaryConfig)
|
|
{
|
|
using TypeTag = Properties::TTag::EclFlowFoamProblem;
|
|
using Vanguard = GetPropType<TypeTag, Properties::Vanguard>;
|
|
|
|
Vanguard::setExternalSetupTime(setupTime);
|
|
Vanguard::setExternalDeck(std::move(deck));
|
|
Vanguard::setExternalEclState(std::move(eclState));
|
|
Vanguard::setExternalSchedule(std::move(schedule));
|
|
Vanguard::setExternalSummaryConfig(std::move(summaryConfig));
|
|
}
|
|
|
|
|
|
// ----------------- Main program -----------------
|
|
int flowEbosFoamMain(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();
|
|
|
|
// initialize MPI, finalize is done automatically on exit
|
|
#if HAVE_DUNE_FEM
|
|
Dune::Fem::MPIManager::initialize(argc, argv);
|
|
#else
|
|
Dune::MPIHelper::instance(argc, argv).rank();
|
|
#endif
|
|
|
|
Opm::FlowMainEbos<Properties::TTag::EclFlowFoamProblem>
|
|
mainfunc {argc, argv, outputCout, outputFiles};
|
|
return mainfunc.execute();
|
|
}
|
|
|
|
}
|