mirror of
https://github.com/OPM/opm-simulators.git
synced 2024-12-29 10:40:59 -06:00
bd9b9a7118
This commit adds logic to communicate more dynamic aquifer values between the simulation and I/O layers. In particular, we ensure that we allocate the 'aquFet' and 'aquCT' substructures of the dynamic aquifer data as appropriate and that we collect this information on the I/O rank as part of the restart output process. We furthermore make the 'ParallelRestart' facility aware of dynamic aquifer data in preparation of loading these values from the restart file.
140 lines
3.9 KiB
C++
140 lines
3.9 KiB
C++
/*
|
|
File adapted from BlackoilWellModel.hpp
|
|
|
|
Copyright 2017 TNO - Heat Transfer & Fluid Dynamics, Modelling & Optimization of the Subsurface
|
|
Copyright 2017 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/>.
|
|
*/
|
|
|
|
|
|
#ifndef OPM_BLACKOILAQUIFERMODEL_HEADER_INCLUDED
|
|
#define OPM_BLACKOILAQUIFERMODEL_HEADER_INCLUDED
|
|
|
|
#include <ebos/eclbaseaquifermodel.hh>
|
|
|
|
#include <opm/parser/eclipse/EclipseState/Aquifer/Aquancon.hpp>
|
|
#include <opm/parser/eclipse/EclipseState/Aquifer/AquiferCT.hpp>
|
|
#include <opm/parser/eclipse/EclipseState/Aquifer/Aquifetp.hpp>
|
|
|
|
#include <opm/output/data/Aquifer.hpp>
|
|
|
|
#include <opm/simulators/aquifers/AquiferCarterTracy.hpp>
|
|
#include <opm/simulators/aquifers/AquiferFetkovich.hpp>
|
|
#include <opm/simulators/aquifers/AquiferNumerical.hpp>
|
|
|
|
#include <opm/grid/CpGrid.hpp>
|
|
#include <opm/grid/polyhedralgrid.hh>
|
|
#if HAVE_DUNE_ALUGRID
|
|
#include <dune/alugrid/grid.hh>
|
|
#endif
|
|
|
|
#include <opm/material/densead/Math.hpp>
|
|
|
|
#include <vector>
|
|
#include <type_traits>
|
|
|
|
namespace Opm
|
|
{
|
|
|
|
template<class Grid>
|
|
class SupportsFaceTag
|
|
: public std::bool_constant<false>
|
|
{};
|
|
|
|
|
|
template<>
|
|
class SupportsFaceTag<Dune::CpGrid>
|
|
: public std::bool_constant<true>
|
|
{};
|
|
|
|
|
|
template<>
|
|
class SupportsFaceTag<Dune::PolyhedralGrid<3, 3>>
|
|
: public std::bool_constant<true>
|
|
{};
|
|
|
|
#if HAVE_DUNE_ALUGRID
|
|
template<>
|
|
class SupportsFaceTag<Dune::ALUGrid<3, 3, Dune::cube, Dune::nonconforming>>
|
|
: public std::bool_constant<true>
|
|
{};
|
|
#endif
|
|
|
|
|
|
/// Class for handling the blackoil well model.
|
|
template <typename TypeTag>
|
|
class BlackoilAquiferModel
|
|
{
|
|
using Simulator = GetPropType<TypeTag, Properties::Simulator>;
|
|
using RateVector = GetPropType<TypeTag, Properties::RateVector>;
|
|
|
|
|
|
public:
|
|
explicit BlackoilAquiferModel(Simulator& simulator);
|
|
|
|
void initialSolutionApplied();
|
|
void initFromRestart(const data::Aquifers& aquiferSoln);
|
|
|
|
void beginEpisode();
|
|
void beginTimeStep();
|
|
void beginIteration();
|
|
// add the water rate due to aquifers to the source term.
|
|
template <class Context>
|
|
void addToSource(RateVector& rates, const Context& context, unsigned spaceIdx, unsigned timeIdx) const;
|
|
void endIteration();
|
|
void endTimeStep();
|
|
void endEpisode();
|
|
|
|
data::Aquifers aquiferData() const;
|
|
|
|
template <class Restarter>
|
|
void serialize(Restarter& res);
|
|
|
|
template <class Restarter>
|
|
void deserialize(Restarter& res);
|
|
|
|
protected:
|
|
// --------- Types ---------
|
|
using ElementContext = GetPropType<TypeTag, Properties::ElementContext>;
|
|
using Scalar = GetPropType<TypeTag, Properties::Scalar>;
|
|
|
|
typedef AquiferCarterTracy<TypeTag> AquiferCarterTracy_object;
|
|
typedef AquiferFetkovich<TypeTag> AquiferFetkovich_object;
|
|
|
|
Simulator& simulator_;
|
|
|
|
// TODO: probably we can use one variable to store both types of aquifers, because
|
|
// they share the base class
|
|
mutable std::vector<AquiferCarterTracy_object> aquifers_CarterTracy;
|
|
mutable std::vector<AquiferFetkovich_object> aquifers_Fetkovich;
|
|
std::vector<AquiferNumerical<TypeTag>> aquifers_numerical;
|
|
|
|
// This initialization function is used to connect the parser objects with the ones needed by AquiferCarterTracy
|
|
void init();
|
|
|
|
bool aquiferActive() const;
|
|
bool aquiferCarterTracyActive() const;
|
|
bool aquiferFetkovichActive() const;
|
|
bool aquiferNumericalActive() const;
|
|
};
|
|
|
|
|
|
} // namespace Opm
|
|
|
|
#include "BlackoilAquiferModel_impl.hpp"
|
|
#endif
|