36#ifndef OPENRS_EULERUPSTREAM_HEADER
37#define OPENRS_EULERUPSTREAM_HEADER
41#include <opm/common/utility/parameters/ParameterGroup.hpp>
42#include <opm/common/utility/numeric/SparseVector.hpp>
49 template <
class Gr
idInterface,
class ReservoirProperties,
class BoundaryConditions>
60 const ReservoirProperties& resprop,
61 const BoundaryConditions& boundary);
65 void init(
const Opm::ParameterGroup& param);
69 void init(
const Opm::ParameterGroup& param,
70 const GridInterface& grid,
71 const ReservoirProperties& resprop,
72 const BoundaryConditions& boundary);
76 void initObj(
const GridInterface& grid,
77 const ReservoirProperties& resprop,
78 const BoundaryConditions& boundary);
95 template <
class PressureSolution>
99 const PressureSolution& pressure_sol,
100 const Opm::SparseVector<double>& injection_rates)
const;
103 typedef typename GridInterface::CellIterator
CIt;
104 typedef typename CIt::FaceIterator
FIt;
108 template <
class PressureSolution>
112 const PressureSolution& pressure_sol)
const;
114 template <
class PressureSolution>
118 const PressureSolution& pressure_sol,
119 const Opm::SparseVector<double>& injection_rates)
const;
Definition: EulerUpstream.hpp:51
void transportSolve(std::vector< double > &saturation, const double time, const typename GridInterface::Vector &gravity, const PressureSolution &pressure_sol, const Opm::SparseVector< double > &injection_rates) const
Solve transport equation, evolving.
void setCourantNumber(double cn)
Set the Courant number. That is dt = dt_cfl*courant_number. For this explicit method it should be < 1...
Definition: EulerUpstream_impl.hpp:144
bool use_cfl_gravity_
Definition: EulerUpstream.hpp:132
double computeCflTime(const std::vector< double > &saturation, const double time, const typename GridInterface::Vector &gravity, const PressureSolution &pressure_sol) const
FIt::Vector Vector
Definition: EulerUpstream.hpp:105
bool check_sat_
Definition: EulerUpstream.hpp:138
bool clamp_sat_
Definition: EulerUpstream.hpp:139
CIt::FaceIterator FIt
Definition: EulerUpstream.hpp:104
std::vector< double > residual_
Definition: EulerUpstream.hpp:143
void initObj(const GridInterface &grid, const ReservoirProperties &resprop, const BoundaryConditions &boundary)
Definition: EulerUpstream_impl.hpp:120
bool use_cfl_viscous_
Definition: EulerUpstream.hpp:131
EulerUpstream()
Definition: EulerUpstream_impl.hpp:60
bool use_cfl_capillary_
Definition: EulerUpstream.hpp:133
bool method_capillary_
Definition: EulerUpstream.hpp:130
int maximum_small_steps_
Definition: EulerUpstream.hpp:137
EulerUpstream(const GridInterface &grid, const ReservoirProperties &resprop, const BoundaryConditions &boundary)
double courant_number_
Definition: EulerUpstream.hpp:135
GridInterface::CellIterator CIt
Definition: EulerUpstream.hpp:103
void display()
Definition: EulerUpstream_impl.hpp:132
bool method_viscous_
Definition: EulerUpstream.hpp:128
void smallTimeStep(std::vector< double > &saturation, const double time, const typename GridInterface::Vector &gravity, const PressureSolution &pressure_sol, const Opm::SparseVector< double > &injection_rates) const
EulerUpstreamResidual< GridInterface, ReservoirProperties, BoundaryConditions > residual_computer_
Definition: EulerUpstream.hpp:126
void init(const Opm::ParameterGroup ¶m)
Definition: EulerUpstream_impl.hpp:95
std::vector< double > porevol_
Definition: EulerUpstream.hpp:140
void init(const Opm::ParameterGroup ¶m, const GridInterface &grid, const ReservoirProperties &resprop, const BoundaryConditions &boundary)
int minimum_small_steps_
Definition: EulerUpstream.hpp:136
bool method_gravity_
Definition: EulerUpstream.hpp:129
void checkAndPossiblyClampSat(std::vector< double > &s) const
Definition: EulerUpstream_impl.hpp:337
Definition: EulerUpstreamResidual.hpp:58
Dune::BlockVector< Dune::FieldVector< double, 1 > > Vector
A vector holding our RHS.
Definition: matrixops.hpp:33
Definition: ImplicitAssembly.hpp:43