opm-simulators
VFPProperties.hpp
1 /*
2  Copyright 2015 SINTEF ICT, Applied Mathematics.
3 
4  This file is part of the Open Porous Media project (OPM).
5 
6  OPM is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  OPM is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with OPM. If not, see <http://www.gnu.org/licenses/>.
18 */
19 
20 #ifndef OPM_AUTODIFF_VFPPROPERTIES_HPP_
21 #define OPM_AUTODIFF_VFPPROPERTIES_HPP_
22 
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>
27 
28 #include <cstddef>
29 
30 namespace Opm {
31 
32 class VFPInjTable;
33 class VFPProdTable;
34 
39 template<typename Scalar, typename IndexTraits>
40 class VFPProperties {
41 public:
50  VFPProperties(const std::vector<std::reference_wrapper<const VFPInjTable>>& inj_tables,
51  const std::vector<std::reference_wrapper<const VFPProdTable>>& prod_tables,
52  const WellState<Scalar, IndexTraits>& well_state)
53  : well_state_(well_state)
54  {
55  for (const auto& vfpinj : inj_tables)
56  this->m_inj.addTable( vfpinj );
57 
58  for (const auto& vfpprod : prod_tables)
59  this->m_prod.addTable( vfpprod );
60  };
61 
66  {
67  return &m_inj;
68  }
69 
74  {
75  return &m_prod;
76  }
77 
78  Scalar getExplicitWFR(const int table_id, const std::size_t well_index) const
79  {
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);
90  }
91 
92  Scalar getExplicitGFR(const int table_id, const std::size_t well_index) const
93  {
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);
104  }
105 
106 private:
107  VFPInjProperties<Scalar> m_inj;
108  VFPProdProperties<Scalar> m_prod;
109  const WellState<Scalar, IndexTraits>& well_state_;
110 };
111 
112 } // namespace Opm
113 
114 #endif /* OPM_AUTODIFF_VFPPROPERTIES_HPP_ */
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