// -*- 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