// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- // vi: set et ts=4 sw=4 sts=4: /* 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 2 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 . Consult the COPYING file in the top-level source directory of this module for the precise wording of the license and the list of copyright holders. */ /*! * \file * * \copydoc Opm::ThresholdPressure */ #ifndef OPM_GENERIC_THRESHOLD_PRESSURE_HPP #define OPM_GENERIC_THRESHOLD_PRESSURE_HPP #include #include #include namespace Opm { class EclipseState; template class LookUpData; template class LookUpCartesianData; template class GenericThresholdPressure { public: using CartesianIndexMapper = Dune::CartesianIndexMapper; using LookUpData = Opm::LookUpData; using LookUpCartesianData = Opm::LookUpCartesianData; GenericThresholdPressure(const CartesianIndexMapper& cartMapper, const GridView& gridView, const ElementMapper& elementMapper, const EclipseState& eclState); /*! * \brief Returns the theshold pressure [Pa] for the intersection between two elements. * * This is tailor made for the E100 threshold pressure mechanism and it is thus quite * a hack: First of all threshold pressures in general are unphysical, and second, * they should be different for the fluid phase but are not. Anyway, this seems to be * E100's way of doing things, so we do it the same way. */ Scalar thresholdPressure(int elem1Idx, int elem2Idx) const; /*! * \brief Return the raw array with the threshold pressures * * This is used for the restart capability. */ const std::vector& data() const { return thpres_; } /*! * \brief Set the threshold pressures from a raw array * * This is used for the restart capability. */ void setFromRestart(const std::vector& values) { thpres_ = values; } //! \brief Returns a fully expanded vector for restart file writing. //! \details Returns the union of explicitly configured entries and defaulted values. std::vector getRestartVector() const; protected: /*! * \brief Actually compute the threshold pressures over a face as a pre-compute step. */ void finishInit(); // internalize the threshold pressures which where explicitly specified via the // THPRES keyword. void applyExplicitThresholdPressures_(); void configureThpresft_(); void logPressures(); const CartesianIndexMapper& cartMapper_; const GridView& gridView_; const ElementMapper& elementMapper_; const LookUpData lookUpData_; const LookUpCartesianData lookUpCartesianData_; const EclipseState& eclState_; std::vector thpresDefault_; std::vector thpres_; unsigned numEquilRegions_{}; std::vector elemEquilRegion_; // threshold pressure accross faults. EXPERIMENTAL! std::vector thpresftValues_; std::vector cartElemFaultIdx_; bool enableThresholdPressure_; }; } // namespace Opm #endif // OPM_GENERIC_THRESHOLD_PRESSURE_HPP