20 #ifndef OPM_AUTODIFF_VFPPROPERTIES_HPP_ 21 #define OPM_AUTODIFF_VFPPROPERTIES_HPP_ 23 #include <opm/simulators/wells/VFPInjProperties.hpp> 24 #include <opm/simulators/wells/VFPProdProperties.hpp> 25 #include <opm/simulators/wells/WellState.hpp> 26 #include <opm/simulators/wells/VFPHelpers.hpp> 39 template<
typename Scalar,
typename IndexTraits>
50 VFPProperties(
const std::vector<std::reference_wrapper<const VFPInjTable>>& inj_tables,
51 const std::vector<std::reference_wrapper<const VFPProdTable>>& prod_tables,
53 : well_state_(well_state)
55 for (
const auto& vfpinj : inj_tables)
56 this->m_inj.addTable( vfpinj );
58 for (
const auto& vfpprod : prod_tables)
59 this->m_prod.addTable( vfpprod );
78 Scalar getExplicitWFR(
const int table_id,
const std::size_t well_index)
const 80 const auto& pu = well_state_.phaseUsageInfo();
81 const bool has_water = pu.phaseIsActive(IndexTraits::waterPhaseIdx);
82 const bool has_oil = pu.phaseIsActive(IndexTraits::oilPhaseIdx);
83 const bool has_gas = pu.phaseIsActive(IndexTraits::gasPhaseIdx);
84 const auto& rates = well_state_.well(well_index).prev_surface_rates;
85 const auto& aqua = has_water ? rates[pu.canonicalToActivePhaseIdx(IndexTraits::waterPhaseIdx)] : 0.0;
86 const auto& liquid = has_oil ? rates[pu.canonicalToActivePhaseIdx(IndexTraits::oilPhaseIdx)] : 0.0;
87 const auto& vapour = has_gas ? rates[pu.canonicalToActivePhaseIdx(IndexTraits::gasPhaseIdx)] : 0.0;
88 const VFPProdTable& table = this->m_prod.getTable(table_id);
89 return detail::getWFR(table, aqua, liquid, vapour);
92 Scalar getExplicitGFR(
const int table_id,
const std::size_t well_index)
const 94 const auto& pu = well_state_.phaseUsageInfo();
95 const auto& rates = well_state_.well(well_index).prev_surface_rates;
96 const bool has_water = pu.phaseIsActive(IndexTraits::waterPhaseIdx);
97 const bool has_oil = pu.phaseIsActive(IndexTraits::oilPhaseIdx);
98 const bool has_gas = pu.phaseIsActive(IndexTraits::gasPhaseIdx);
99 const auto& aqua = has_water ? rates[pu.canonicalToActivePhaseIdx(IndexTraits::waterPhaseIdx)] : 0.0;
100 const auto& liquid = has_oil ? rates[pu.canonicalToActivePhaseIdx(IndexTraits::oilPhaseIdx)] : 0.0;
101 const auto& vapour = has_gas ? rates[pu.canonicalToActivePhaseIdx(IndexTraits::gasPhaseIdx)] : 0.0;
102 const VFPProdTable& table = this->m_prod.getTable(table_id);
103 return detail::getGFR(table, aqua, liquid, vapour);
107 VFPInjProperties<Scalar> m_inj;
108 VFPProdProperties<Scalar> m_prod;
109 const WellState<Scalar, IndexTraits>& well_state_;
Class which linearly interpolates BHP as a function of rate, tubing head pressure, water fraction, gas fraction, and artificial lift for production VFP tables, and similarly the BHP as a function of the rate and tubing head pressure.
Definition: BlackoilWellModelNetworkGeneric.hpp:42
Definition: VFPInjProperties.hpp:34
const VFPProdProperties< Scalar > * getProd() const
Returns the VFP properties for production wells.
Definition: VFPProperties.hpp:73
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
VFPProperties(const std::vector< std::reference_wrapper< const VFPInjTable >> &inj_tables, const std::vector< std::reference_wrapper< const VFPProdTable >> &prod_tables, const WellState< Scalar, IndexTraits > &well_state)
Constructor Takes no ownership of data.
Definition: VFPProperties.hpp:50
const VFPInjProperties< Scalar > * getInj() const
Returns the VFP properties for injection wells.
Definition: VFPProperties.hpp:65
The state of a set of wells, tailored for use by the fully implicit blackoil simulator.
Definition: TemperatureModel.hpp:61