/* Copyright 2021 Equinor ASA This file is part of the Open Porous Media project (OPM). OPM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OPM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OPM. If not, see . */ #ifndef OPM_SINGLE_WELL_STATE_HEADER_INCLUDED #define OPM_SINGLE_WELL_STATE_HEADER_INCLUDED #include #include #include #include #include #include #include namespace Opm { class SingleWellState { public: SingleWellState(const ParallelWellInfo& pinfo, bool is_producer, std::size_t num_perf, std::size_t num_phases, double temp); std::reference_wrapper parallel_info; Well::Status status{Well::Status::OPEN}; bool producer; double bhp{0}; double thp{0}; double temperature{0}; double dissolved_gas_rate{0}; double vaporized_oil_rate{0}; std::vector well_potentials; std::vector productivity_index; std::vector surface_rates; std::vector reservoir_rates; PerfData perf_data; SegmentState segments; Events events; Well::InjectorCMode injection_cmode{Well::InjectorCMode::CMODE_UNDEFINED}; Well::ProducerCMode production_cmode{Well::ProducerCMode::CMODE_UNDEFINED}; void init_timestep(const SingleWellState& other); void shut(); void stop(); void open(); // The sum_xxx_rates() functions sum over all connection rates of pertinent // types. In the case of distributed wells this involves an MPI // communication. double sum_solvent_rates() const; double sum_polymer_rates() const; double sum_brine_rates() const; private: double sum_connection_rates(const std::vector& connection_rates) const; }; } #endif