28#ifndef OPM_GENERIC_TEMPERATURE_MODEL_IMPL_HPP
29#define OPM_GENERIC_TEMPERATURE_MODEL_IMPL_HPP
32#ifndef OPM_GENERIC_TEMPERATURE_MODEL_HPP
37#include <dune/istl/operators.hh>
38#include <dune/istl/solvers.hh>
39#include <dune/istl/schwarz.hh>
40#include <dune/istl/preconditioners.hh>
41#include <dune/istl/schwarz.hh>
43#include <opm/common/OpmLog/OpmLog.hpp>
45#include <opm/grid/CpGrid.hpp>
47#include <opm/input/eclipse/EclipseState/EclipseState.hpp>
48#include <opm/input/eclipse/Schedule/Well/Well.hpp>
61#include <fmt/format.h>
66template<
class M,
class V>
69 using Comm = Dune::OwnerOverlapCopyCommunication<int, int>;
74template<
class Vector,
class Gr
id,
class Matrix>
75std::tuple<std::unique_ptr<Dune::OverlappingSchwarzOperator<Matrix,Vector,Vector,
76 Dune::OwnerOverlapCopyCommunication<int,int>>>,
77 std::unique_ptr<typename EnergySolverSelector<Matrix,Vector>::type>>
80 OPM_THROW(std::logic_error,
"Grid not supported for parallel Temperatures.");
81 return {
nullptr,
nullptr};
84template<
class Vector,
class Matrix>
85std::tuple<std::unique_ptr<Dune::OverlappingSchwarzOperator<Matrix,Vector,Vector,
86 Dune::OwnerOverlapCopyCommunication<int,int>>>,
87 std::unique_ptr<typename EnergySolverSelector<Matrix,Vector>::type>>
90 using EnergyOperator = Dune::OverlappingSchwarzOperator<Matrix,Vector,Vector,
91 Dune::OwnerOverlapCopyCommunication<int,int>>;
93 const auto& cellComm = grid.cellCommunication();
94 auto op = std::make_unique<EnergyOperator>(M, cellComm);
95 auto dummyWeights = [](){
return Vector();};
96 return {std::move(op), std::make_unique<EnergySolver>(*op, cellComm, prm, dummyWeights, 0)};
100template<
class Gr
id,
class Gr
idView,
class DofMapper,
class Stencil,
class Flu
idSystem,
class Scalar>
103 const EclipseState& eclState,
105 const DofMapper& dofMapper)
106 : gridView_(gridView)
107 , eclState_(eclState)
108 , cartMapper_(cartMapper)
109 , dofMapper_(dofMapper)
113template<
class Gr
id,
class Gr
idView,
class DofMapper,
class Stencil,
class Flu
idSystem,
class Scalar>
115doInit(std::size_t numGridDof)
117 doTemp_ = eclState_.getSimulationConfig().isTemp();
119 temperature_.resize(numGridDof);
120 energyVector_.resize(numGridDof);
122 energyMatrix_ = std::make_unique<EnergyMatrix>(numGridDof, numGridDof, EnergyMatrix::random);
125 using NeighborSet = std::set<unsigned>;
126 std::vector<NeighborSet> neighbors(numGridDof);
128 Stencil stencil(gridView_, dofMapper_);
129 for (
const auto& elem : elements(gridView_)) {
130 stencil.update(elem);
132 for (
unsigned primaryDofIdx = 0; primaryDofIdx < stencil.numPrimaryDof(); ++primaryDofIdx) {
133 unsigned myIdx = stencil.globalSpaceIndex(primaryDofIdx);
135 for (
unsigned dofIdx = 0; dofIdx < stencil.numDof(); ++dofIdx) {
136 unsigned neighborIdx = stencil.globalSpaceIndex(dofIdx);
137 neighbors[myIdx].insert(neighborIdx);
143 for (
unsigned dofIdx = 0; dofIdx < numGridDof; ++ dofIdx) {
144 energyMatrix_->setrowsize(dofIdx, neighbors[dofIdx].size());
146 energyMatrix_->endrowsizes();
151 for (
unsigned dofIdx = 0; dofIdx < numGridDof; ++ dofIdx) {
152 typename NeighborSet::iterator nIt = neighbors[dofIdx].begin();
153 typename NeighborSet::iterator nEndIt = neighbors[dofIdx].end();
154 for (; nIt != nEndIt; ++nIt) {
155 energyMatrix_->addindex(dofIdx, *nIt);
158 energyMatrix_->endindices();
160 maxTempChange_ = Parameters::Get<Parameters::MaxTemperatureChange<Scalar>>();
163template<
class Gr
id,
class Gr
idView,
class DofMapper,
class Stencil,
class Flu
idSystem,
class Scalar>
168 Scalar tolerance = 1e-2;
173 prm.
put(
"maxiter", maxIter);
174 prm.
put(
"tol", tolerance);
175 prm.
put(
"verbosity", verbosity);
176 prm.
put(
"solver", std::string(
"bicgstab"));
177 prm.
put(
"preconditioner.type", std::string(
"ParOverILU0"));
180 if(gridView_.grid().comm().size() > 1)
182 auto [energyOperator, solver] =
183 createParallelFlexibleSolver<EnergyVector>(gridView_.grid(), M, prm);
184 (void) energyOperator;
187 solver->apply(x, b, result);
190 return result.converged;
195 using EnergySolver = Dune::BiCGSTABSolver<EnergyVector>;
196 using EnergyOperator = Dune::MatrixAdapter<EnergyMatrix,EnergyVector,EnergyVector>;
197 using EnergyScalarProduct = Dune::SeqScalarProduct<EnergyVector>;
198 using EnergyPreconditioner = Dune::SeqILU< EnergyMatrix,EnergyVector,EnergyVector>;
200 EnergyOperator energyOperator(M);
201 EnergyScalarProduct energyScalarProduct;
202 EnergyPreconditioner energyPreconditioner(M, 0, 1);
204 EnergySolver solver (energyOperator, energyScalarProduct,
205 energyPreconditioner, tolerance, maxIter,
209 solver.apply(x, b, result);
212 return result.converged;
Definition: CollectDataOnIORank.hpp:49
Definition: FlexibleSolver.hpp:45
GenericTemperatureModel(const GridView &gridView, const EclipseState &eclState, const CartesianIndexMapper &cartMapper, const DofMapper &dofMapper)
Definition: GenericTemperatureModel_impl.hpp:102
Dune::BCRSMatrix< Opm::MatrixBlock< Scalar, 1, 1 > > EnergyMatrix
Definition: GenericTemperatureModel.hpp:54
bool linearSolve_(const EnergyMatrix &M, EnergyVector &x, EnergyVector &b)
Definition: GenericTemperatureModel_impl.hpp:165
Dune::BlockVector< Dune::FieldVector< Scalar, 1 > > EnergyVector
Definition: GenericTemperatureModel.hpp:55
void doInit(std::size_t numGridDof)
Initialize all internal data structures needed by the temperature module.
Definition: GenericTemperatureModel_impl.hpp:115
Hierarchical collection of key/value pairs.
Definition: PropertyTree.hpp:39
void put(const std::string &key, const T &data)
Definition: blackoilbioeffectsmodules.hh:43
Dune::InverseOperatorResult InverseOperatorResult
Definition: GpuBridge.hpp:32
std::tuple< std::unique_ptr< Dune::OverlappingSchwarzOperator< Matrix, Vector, Vector, Dune::OwnerOverlapCopyCommunication< int, int > > >, std::unique_ptr< typename EnergySolverSelector< Matrix, Vector >::type > > createParallelFlexibleSolver(const Grid &, const Matrix &, const PropertyTree &)
Definition: GenericTemperatureModel_impl.hpp:78
Definition: GenericTemperatureModel_impl.hpp:68
Dune::OverlappingSchwarzOperator< M, V, V, Comm > EnergyOperator
Definition: GenericTemperatureModel_impl.hpp:70
Dune::OwnerOverlapCopyCommunication< int, int > Comm
Definition: GenericTemperatureModel_impl.hpp:69