22 #ifndef OPM_MULTISEGMENTWELL_PRIMARY_VARIABLES_HEADER_INCLUDED 23 #define OPM_MULTISEGMENTWELL_PRIMARY_VARIABLES_HEADER_INCLUDED 25 #include <opm/material/densead/Evaluation.hpp> 27 #include <opm/simulators/wells/MultisegmentWellEquations.hpp> 28 #include <opm/input/eclipse/Schedule/SummaryState.hpp> 29 #include <opm/input/eclipse/Units/Units.hpp> 39 template <
typename Scalar,
typename IndexTraits>
class MultisegmentWellGeneric;
40 template<
class Flu
idSystem,
class Indices>
class WellInterfaceIndices;
41 template<
typename Scalar,
typename IndexTraits>
class WellState;
43 template<
class Flu
idSystem,
class Indices>
44 class MultisegmentWellPrimaryVariables
60 static constexpr
bool has_wfrac_variable = Indices::waterEnabled && Indices::oilEnabled;
61 static constexpr
bool has_gfrac_variable = Indices::gasEnabled && Indices::numPhases > 1;
63 static constexpr
int WQTotal = 0;
64 static constexpr
int WFrac = has_wfrac_variable ? 1 : -1000;
65 static constexpr
int GFrac = has_gfrac_variable ? has_wfrac_variable + 1 : -1000;
66 static constexpr
int SPres = has_wfrac_variable + has_gfrac_variable + 1;
69 static constexpr
int numWellEq = Indices::numPhases + 1;
71 using Scalar =
typename FluidSystem::Scalar;
72 using IndexTraits =
typename FluidSystem::IndexTraitsType;
73 using EvalWell = DenseAd::Evaluation<Scalar, Indices::numEq + numWellEq>;
75 using Equations = MultisegmentWellEquations<Scalar,IndexTraits,numWellEq,Indices::numEq>;
76 using BVectorWell =
typename Equations::BVectorWell;
78 explicit MultisegmentWellPrimaryVariables(
const WellInterfaceIndices<FluidSystem,Indices>& well)
83 void resize(
const int numSegments);
86 void update(
const WellState<Scalar, IndexTraits>& well_state,
87 const bool stop_or_zero_rate_target);
91 const Scalar relaxation_factor,
93 const bool stop_or_zero_rate_target,
94 const Scalar max_pressure_change);
97 void copyToWellState(
const MultisegmentWellGeneric<Scalar, IndexTraits>& mswell,
99 WellState<Scalar, IndexTraits>& well_state,
100 const SummaryState& summary_state,
101 DeferredLogger& deferred_logger)
const;
106 const int compIdx)
const;
111 const int compIdx)
const;
115 const int seg_upwind,
116 const int comp_idx)
const;
126 const int comp_idx)
const;
129 EvalWell
getQs(
const int comp_idx)
const;
135 const std::array<EvalWell, numWellEq>&
eval(
const int idx)
const 136 {
return evaluation_[idx]; }
139 const std::array<Scalar, numWellEq>&
value(
const int idx)
const 140 {
return value_[idx]; }
143 void setValue(
const int idx,
const std::array<Scalar, numWellEq>& val)
144 { value_[idx] = val; }
151 void setEvaluationsFromValues();
154 void processFractions(
const int seg);
157 EvalWell volumeFraction(
const int seg,
158 const int compIdx)
const;
162 std::vector<std::array<Scalar, numWellEq>> value_;
166 std::vector<std::array<EvalWell, numWellEq>> evaluation_;
170 static constexpr
double bhp_lower_limit = 1. * unit::barsa - 1. * unit::Pascal;
171 static constexpr
double seg_pres_lower_limit = 0.;
176 #endif // OPM_MULTISEGMENTWELL_PRIMARY_VARIABLES_HEADER_INCLUDED EvalWell getSegmentRate(const int seg, const int comp_idx) const
Get rate for a component in a segment.
Definition: MultisegmentWellPrimaryVariables.cpp:662
const std::array< EvalWell, numWellEq > & eval(const int idx) const
Returns a const ref to an array of evaluations.
Definition: MultisegmentWellPrimaryVariables.hpp:135
void updateNewton(const BVectorWell &dwells, const Scalar relaxation_factor, const Scalar DFLimit, const bool stop_or_zero_rate_target, const Scalar max_pressure_change)
Update values from newton update vector.
Definition: MultisegmentWellPrimaryVariables.cpp:165
EvalWell getQs(const int comp_idx) const
Returns scaled rate for a component.
Definition: MultisegmentWellPrimaryVariables.cpp:671
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
EvalWell surfaceVolumeFraction(const int seg, const int compIdx) const
Returns surface volume fraction for a component in a segment.
Definition: MultisegmentWellPrimaryVariables.cpp:590
EvalWell volumeFractionScaled(const int seg, const int compIdx) const
Returns scaled volume fraction for a component in a segment.
Definition: MultisegmentWellPrimaryVariables.cpp:573
void update(const WellState< Scalar, IndexTraits > &well_state, const bool stop_or_zero_rate_target)
Copy values from well state.
Definition: MultisegmentWellPrimaryVariables.cpp:70
EvalWell getWQTotal() const
Get WQTotal.
Definition: MultisegmentWellPrimaryVariables.cpp:679
EvalWell getBhp() const
Get bottomhole pressure.
Definition: MultisegmentWellPrimaryVariables.cpp:654
void setValue(const int idx, const std::array< Scalar, numWellEq > &val)
Set a value array. Note that this does not also set the corresponding evaluation. ...
Definition: MultisegmentWellPrimaryVariables.hpp:143
Definition: MultisegmentWellAssemble.hpp:38
Definition: DeferredLogger.hpp:56
EvalWell getSegmentPressure(const int seg) const
Get pressure for a segment.
Definition: MultisegmentWellPrimaryVariables.cpp:646
EvalWell getSegmentRateUpwinding(const int seg, const int seg_upwind, const int comp_idx) const
Returns upwinding rate for a component in a segment.
Definition: MultisegmentWellPrimaryVariables.cpp:606
const std::array< Scalar, numWellEq > & value(const int idx) const
Returns a value array.
Definition: MultisegmentWellPrimaryVariables.hpp:139
void outputLowLimitPressureSegments(DeferredLogger &deferred_logger) const
output the segments with pressure close to lower pressure limit for debugging purpose ...
Definition: MultisegmentWellPrimaryVariables.cpp:687
void copyToWellState(const MultisegmentWellGeneric< Scalar, IndexTraits > &mswell, const Scalar rho, WellState< Scalar, IndexTraits > &well_state, const SummaryState &summary_state, DeferredLogger &deferred_logger) const
Copy values to well state.
Definition: MultisegmentWellPrimaryVariables.cpp:222
void resize(const int numSegments)
Resize values and evaluations.
Definition: MultisegmentWellPrimaryVariables.cpp:49