/* Copyright 2016 SINTEF ICT, Applied Mathematics. Copyright 2016 - 2017 Statoil ASA. Copyright 2017 Dr. Blatt - HPC-Simulation-Software & Services Copyright 2016 - 2018 IRIS AS 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_BLACKOILWELLMODEL_CONSTRAINTS_HEADER_INCLUDED #define OPM_BLACKOILWELLMODEL_CONSTRAINTS_HEADER_INCLUDED #include #include #include namespace Opm { template class BlackoilWellModelGeneric; class DeferredLogger; template class GroupState; class SummaryState; template class WellState; /// Class for handling constraints for the blackoil well model. template class BlackoilWellModelConstraints { public: //! \brief Constructor initializes reference to the well model. BlackoilWellModelConstraints(const BlackoilWellModelGeneric& wellModel) : wellModel_(wellModel) {} /// Return true if any well has a THP constraint. bool hasTHPConstraints() const; //! \brief Check the constraints of a well group. bool checkGroupConstraints(const Group& group, const int reportStepIdx, DeferredLogger& deferred_logger) const; //! \brief Execute action for broken constraint for an injection well group. void actionOnBrokenConstraints(const Group& group, const Group::InjectionCMode& newControl, const Phase& controlPhase, GroupState& group_state, DeferredLogger& deferred_logger) const; //! \brief Execute action on broken constraint for a production well group. Return true if a group control is changed bool actionOnBrokenConstraints(const Group& group, const int reportStepIdx, const Group::GroupLimitAction group_limit_action, const Group::ProductionCMode& newControl, const WellState& well_state, std::optional& worst_offending_well, GroupState& group_state, DeferredLogger& deferred_logger) const; //! \brief Update the individual controls for wells in a group. Return true if a group control is changed bool updateGroupIndividualControl(const Group& group, const int reportStepIdx, std::map,std::string>& switched_inj, std::map& switched_prod, std::map>& closed_offending_wells, GroupState& group_state, WellState& well_state, DeferredLogger& deferred_logger) const; private: //! \brief Check and return value and type of constraints for an injection well group. std::pair checkGroupInjectionConstraints(const Group& group, const int reportStepIdx, const Phase& phase) const; //! \brief Check and return value and type of constraints for a production well group. std::pair checkGroupProductionConstraints(const Group& group, const int reportStepIdx, DeferredLogger& deferred_logger) const; const BlackoilWellModelGeneric& wellModel_; //!< Reference to well model }; } // namespace Opm #endif