12#ifndef DUMUX_LINEAR_SOLVER_TRAITS_HH
13#define DUMUX_LINEAR_SOLVER_TRAITS_HH
17#include <dune/istl/schwarz.hh>
18#include <dune/istl/novlpschwarz.hh>
19#include <dune/istl/owneroverlapcopy.hh>
20#include <dune/istl/paamg/pinfo.hh>
21#include <dune/istl/preconditioners.hh>
22#include <dune/grid/common/capabilities.hh>
30template<
class Gr
idGeometry,
class DiscretizationMethod>
36template<
class Gr
idGeometry>
40template<
class MType,
class VType>
48 template<
class SeqPreconditioner>
54 template<
class Matrix,
class Vector>
61template <
class MType,
class VType>
67 using Comm = Dune::OwnerOverlapCopyCommunication<Dune::bigunsignedint<96>,
int>;
68 using LinearOperator = Dune::NonoverlappingSchwarzOperator<MType, VType, VType, Comm>;
69 using ScalarProduct = Dune::NonoverlappingSchwarzScalarProduct<VType, Comm>;
72 template<
class SeqPreconditioner>
73 using Preconditioner = Dune::NonoverlappingBlockPreconditioner<Comm, SeqPreconditioner>;
76template <
class MType,
class VType>
82 using Comm = Dune::OwnerOverlapCopyCommunication<Dune::bigunsignedint<96>,
int>;
83 using LinearOperator = Dune::OverlappingSchwarzOperator<MType, VType, VType, Comm>;
84 using ScalarProduct = Dune::OverlappingSchwarzScalarProduct<VType, Comm>;
87 template<
class SeqPreconditioner>
88 using Preconditioner = Dune::BlockPreconditioner<VType, VType, Comm, SeqPreconditioner>;
92template<
class Gr
idGeometry>
95 using GridView =
typename GridGeometry::GridView;
96 using Grid =
typename GridGeometry::GridView::Traits::Grid;
98 template<
class Matrix,
class Vector>
102 template<
class Matrix,
class Vector>
105 template<
class Matrix,
class Vector>
111template<
class Gr
idGeometry>
116 using Grid =
typename GridGeometry::GridView::Traits::Grid;
117 static constexpr int dofCodim = Grid::dimension;
118 static constexpr bool canCommunicate = Dune::Capabilities::canCommunicate<Grid, dofCodim>::v;
120 template<
class Gr
idView>
122 {
return gridView.overlapSize(0) == 0; }
125template<
class Gr
idGeometry>
129 using Grid =
typename GridGeometry::GridView::Traits::Grid;
132 static constexpr int dofCodim = Grid::dimension;
133 static constexpr std::bitset<Grid::dimension+1> dofCodims{ (1UL << Grid::dimension) + 1UL };
136 {
return { gg.dofMapper() }; }
139template<
class Gr
idGeometry>
144 using Grid =
typename GridGeometry::GridView::Traits::Grid;
146 static constexpr int dofCodim = Grid::dimension;
147 static constexpr std::bitset<Grid::dimension+1> dofCodims{ (1UL << Grid::dimension) + (1UL << (Grid::dimension-1)) };
149 static constexpr bool canCommunicate = Dune::Capabilities::canCommunicate<Grid, Grid::dimension>::v
150 && Dune::Capabilities::canCommunicate<
Grid, Grid::dimension-1>::v;
152 template<
class Gr
idView>
154 {
return gridView.overlapSize(0) == 0; }
157 {
return { gg.dofMapper() }; }
161template<
class Gr
idGeometry>
166 using Grid =
typename GridGeometry::GridView::Traits::Grid;
167 static constexpr int dofCodim = 0;
168 static constexpr bool canCommunicate = Dune::Capabilities::canCommunicate<Grid, dofCodim>::v;
170 template<
class Gr
idView>
176template<
class Gr
idGeometry>
183 DofMapper(
const typename GridGeometry::GridView& gridView)
184 : gridView_(gridView) {}
186 template<
class Entity>
188 {
return gridView_.indexSet().index(e); }
191 {
return gridView_.size(1); }
194 typename GridGeometry::GridView gridView_;
198 {
return { gg.gridView() }; }
200 using Grid =
typename GridGeometry::GridView::Traits::Grid;
201 static constexpr int dofCodim = 1;
203 static constexpr bool canCommunicate =
204 Dune::Capabilities::canCommunicate<Grid, dofCodim>::v;
206 template<
class Gr
idView>
209 assert(gridView.overlapSize(0) > 0);
215template<
class Gr
idGeometry>
220 using Grid =
typename GridGeometry::GridView::Traits::Grid;
221 static constexpr int dofCodim = 1;
222 static constexpr bool canCommunicate = Dune::Capabilities::canCommunicate<Grid, dofCodim>::v;
225 {
return { gg.dofMapper() }; }
227 template<
class Gr
idView>
229 {
return gridView.overlapSize(0) == 0; }
233template<
class Gr
idGeometry>
238template<
class Gr
idGeometry>
auto size() const
Definition: linearsolvertraits.hh:190
DofMapper(const typename GridGeometry::GridView &gridView)
Definition: linearsolvertraits.hh:183
auto index(const Entity &e) const
Definition: linearsolvertraits.hh:187
dune-grid capabilities compatibility layer
The available discretization methods in Dumux.
CVFE< CVFEMethods::CR_RT > FCDiamond
Definition: method.hh:105
CVFE< CVFEMethods::PQ1 > Box
Definition: method.hh:98
CVFE< CVFEMethods::PQ2 > PQ2
Definition: method.hh:118
CVFE< CVFEMethods::PQ1Bubble > PQ1Bubble
Definition: method.hh:112
Definition: linearsolvertraits.hh:94
typename GridGeometry::GridView::Traits::Grid Grid
Definition: linearsolvertraits.hh:96
typename GridGeometry::GridView GridView
Definition: linearsolvertraits.hh:95
static bool isNonOverlapping(const GridView &gridView)
Definition: linearsolvertraits.hh:121
typename GridGeometry::VertexMapper DofMapper
Definition: linearsolvertraits.hh:115
typename GridGeometry::ElementMapper DofMapper
Definition: linearsolvertraits.hh:165
static bool isNonOverlapping(const GridView &gridView)
Definition: linearsolvertraits.hh:171
typename GridGeometry::DofMapper DofMapper
Definition: linearsolvertraits.hh:219
static bool isNonOverlapping(const GridView &gridView)
Definition: linearsolvertraits.hh:228
static const DofMapper & dofMapper(const GridGeometry &gg)
Definition: linearsolvertraits.hh:224
static bool isNonOverlapping(const GridView &gridView)
Definition: linearsolvertraits.hh:207
static DofMapper dofMapper(const GridGeometry &gg)
Definition: linearsolvertraits.hh:197
static const DofMapper & dofMapper(const GridGeometry &gg)
Definition: linearsolvertraits.hh:135
static const DofMapper & dofMapper(const GridGeometry &gg)
Definition: linearsolvertraits.hh:156
typename GridGeometry::DofMapper DofMapper
Definition: linearsolvertraits.hh:143
static bool isNonOverlapping(const GridView &gridView)
Definition: linearsolvertraits.hh:153
The implementation is specialized for the different discretizations.
Definition: linearsolvertraits.hh:31
Definition: linearsolvertraits.hh:63
Dune::NonoverlappingSchwarzOperator< MType, VType, VType, Comm > LinearOperator
Definition: linearsolvertraits.hh:68
MType Matrix
Definition: linearsolvertraits.hh:65
Dune::NonoverlappingBlockPreconditioner< Comm, SeqPreconditioner > Preconditioner
Definition: linearsolvertraits.hh:73
Dune::NonoverlappingSchwarzScalarProduct< VType, Comm > ScalarProduct
Definition: linearsolvertraits.hh:69
VType Vector
Definition: linearsolvertraits.hh:66
Dune::OwnerOverlapCopyCommunication< Dune::bigunsignedint< 96 >, int > Comm
Definition: linearsolvertraits.hh:67
static constexpr bool isNonOverlapping
Definition: linearsolvertraits.hh:70
Definition: linearsolvertraits.hh:78
static constexpr bool isNonOverlapping
Definition: linearsolvertraits.hh:85
Dune::OverlappingSchwarzOperator< MType, VType, VType, Comm > LinearOperator
Definition: linearsolvertraits.hh:83
MType Matrix
Definition: linearsolvertraits.hh:80
Dune::BlockPreconditioner< VType, VType, Comm, SeqPreconditioner > Preconditioner
Definition: linearsolvertraits.hh:88
VType Vector
Definition: linearsolvertraits.hh:81
Dune::OwnerOverlapCopyCommunication< Dune::bigunsignedint< 96 >, int > Comm
Definition: linearsolvertraits.hh:82
Dune::OverlappingSchwarzScalarProduct< VType, Comm > ScalarProduct
Definition: linearsolvertraits.hh:84
Definition: linearsolvertraits.hh:53
static constexpr bool canCommunicate
Definition: linearsolvertraits.hh:57
sequential solver traits
Definition: linearsolvertraits.hh:42
MType Matrix
Definition: linearsolvertraits.hh:43
VType Vector
Definition: linearsolvertraits.hh:44
Dune::MatrixAdapter< MType, VType, VType > LinearOperator
Definition: linearsolvertraits.hh:45
SeqPreconditioner Preconditioner
Definition: linearsolvertraits.hh:49
Dune::SeqScalarProduct< VType > ScalarProduct
Definition: linearsolvertraits.hh:46