// -*- 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::DiscreteFractureModel */ #ifndef EWOMS_DISCRETE_FRACTURE_MODEL_HH #define EWOMS_DISCRETE_FRACTURE_MODEL_HH #include #include "discretefractureproperties.hh" #include "discretefractureprimaryvariables.hh" #include "discretefractureintensivequantities.hh" #include "discretefractureextensivequantities.hh" #include "discretefracturelocalresidual.hh" #include "discretefractureproblem.hh" #include #include #include #include namespace Opm { template class DiscreteFractureModel; } namespace Opm::Properties { // Create new type tags namespace TTag { //! The generic type tag for problems using the immiscible multi-phase model struct DiscreteFractureModel { using InheritsFrom = std::tuple; }; } // end namespace TTag //! The class for the model template struct Model { using type = Opm::DiscreteFractureModel; }; //! The class for the model template struct BaseProblem { using type = Opm::DiscreteFractureProblem; }; //! Use the immiscible multi-phase local jacobian operator for the immiscible multi-phase model template struct LocalResidual { using type = Opm::DiscreteFractureLocalResidual; }; // The type of the base base class for actual problems. // TODO!? // template // struct BaseProblem { using type = DiscreteFractureBaseProblem; }; //! the PrimaryVariables property template struct PrimaryVariables { using type = Opm::DiscreteFracturePrimaryVariables; }; //! the IntensiveQuantities property template struct IntensiveQuantities { using type = Opm::DiscreteFractureIntensiveQuantities; }; //! the ExtensiveQuantities property template struct ExtensiveQuantities { using type = Opm::DiscreteFractureExtensiveQuantities; }; //! For the discrete fracture model, we need to use two-point flux approximation or it //! will converge very poorly template struct UseTwoPointGradients { static constexpr bool value = true; }; // The intensive quantity cache cannot be used by the discrete fracture model, because // the intensive quantities of a control degree of freedom are not identical to the // intensive quantities of the other intensive quantities of the same of the same degree // of freedom. This is because the fracture properties (volume, permeability, etc) are // specific for each... template struct EnableIntensiveQuantityCache { static constexpr bool value = false; }; } // namespace Opm::Properties namespace Opm { /*! * \ingroup DiscreteFractureModel * \brief A fully-implicit multi-phase flow model which assumes * immiscibility of the phases and is able to include fractures * in the domain. * * This model implements multi-phase flow of \f$M > 0\f$ immiscible * fluids \f$\alpha\f$. It also can consider edges of the * computational grid as fractures i.e. as a porous medium with * different higher permeability than the rest of the domain. * * \todo So far, the discrete fracture model only works for 2D grids * and without energy. Also only the Darcy velocity model is * supported for the fractures. * * \sa ImmiscibleModel */ template class DiscreteFractureModel : public ImmiscibleModel { using ParentType = ImmiscibleModel; using Simulator = GetPropType; public: DiscreteFractureModel(Simulator& simulator) : ParentType(simulator) { if (EWOMS_GET_PARAM(TypeTag, bool, EnableIntensiveQuantityCache)) { throw std::runtime_error("The discrete fracture model does not work in conjunction " "with intensive quantities caching"); } } /*! * \brief Register all run-time parameters for the immiscible model. */ static void registerParameters() { ParentType::registerParameters(); // register runtime parameters of the VTK output modules Opm::VtkDiscreteFractureModule::registerParameters(); } /*! * \copydoc FvBaseDiscretization::name */ static std::string name() { return "discretefracture"; } void registerOutputModules_() { ParentType::registerOutputModules_(); this->addOutputModule(new Opm::VtkDiscreteFractureModule(this->simulator_)); } }; } // namespace Opm #endif