Dune-Functions 2.11
Loading...
Searching...
No Matches
functionspacebases/concepts.hh
Go to the documentation of this file.
1// -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2// vi: set et ts=4 sw=2 sts=2:
3
4// SPDX-FileCopyrightText: Copyright © DUNE Project contributors, see file AUTHORS.md
5// SPDX-License-Identifier: LicenseRef-GPL-2.0-only-with-DUNE-exception OR LGPL-3.0-or-later
6
7#ifndef DUNE_FUNCTIONS_FUNCTIONSPACEBASES_CONCEPTS_HH
8#define DUNE_FUNCTIONS_FUNCTIONSPACEBASES_CONCEPTS_HH
9
10#include <utility>
11#include <tuple>
12
13#include <dune/common/concept.hh>
14#include <dune/common/indices.hh>
15#include <dune/common/reservedvector.hh>
16#include <dune/common/typeutilities.hh>
17#include <dune/common/typelist.hh>
18
19#include <dune/common/typetree/nodeconcepts.hh>
20#include <dune/common/typetree/childaccess.hh>
21
23
25
26
27namespace Dune {
28namespace Functions {
29namespace ContainerDescriptors { /* forward declaration */ struct Unknown; }
30
31namespace Concept {
32
33using namespace Dune::Concept;
34
35
37{
38 template<class C>
39 auto require(C&& c) -> decltype(
40 c.resize(0)
41 );
42};
43
44
45
47{
48 template<class C>
49 auto require(C&& c) -> decltype(
50 c.size()
51 );
52};
53
54
55
57{
58 template<class C, class I>
59 auto require(C&& c, I&& i) -> decltype(
60 c[i]
61 );
62};
63
64// Concept for a container descriptor describing the structure of an index tree
66{
67private:
68 template<class CD, std::size_t... II>
69 auto expandChilds(const CD& cd, std::index_sequence<II...>) -> decltype(
70 (requireConcept<ContainerDescriptor>(cd[std::integral_constant<std::size_t,II>{}]),...)
71 );
72
73 // static size overload
74 template<class CD, std::size_t S = CD::size()>
75 auto children(const CD& cd, Dune::PriorityTag<1>) -> decltype(
76 expandChilds(cd, std::make_index_sequence<S>{})
77 );
78
79 // dynamic size overload
80 template<class CD>
81 auto children(const CD& cd, Dune::PriorityTag<0>) -> decltype(
82 requireConcept<ContainerDescriptor>(cd[0])
83 );
84
85public:
86 // specialization for the fallback type
88
89 template<class CD>
90 auto require(const CD& cd) -> decltype(
91 requireConvertible<std::size_t>(cd.size()),
92 children(cd, Dune::PriorityTag<2>{})
93 );
94};
95
96// Concept for a BasisNode in a local ansatz tree
98{
99 template<class N>
100 auto require(const N& node) -> decltype(
101 requireType<typename N::size_type>(),
102 requireConvertible<typename N::size_type>(node.size()),
103 requireConvertible<typename N::size_type>(node.localIndex(std::declval<typename N::size_type>())),
104 requireConvertible<typename N::size_type>(node.treeIndex()),
105 requireBaseOf<BasisNodeMixin, N>()
106 );
107};
108
109
110
111// Concept for a LeafBasisNode in a local ansatz tree
112template<class GridView>
113struct LeafBasisNode : Refines<BasisNode>
114{
115 template<class N>
116 auto require(const N& node) -> decltype(
117 requireType<typename N::Element>(),
118 requireType<typename N::FiniteElement>(),
119 requireConvertible<typename N::Element>(node.element()),
120 requireConvertible<const typename N::FiniteElement&>(node.finiteElement()),
121 requireSameType<typename N::Element, typename GridView::template Codim<0>::Entity>(),
122 requireBaseOf<Dune::Functions::LeafBasisNode, N>()
123 );
124};
125
126
127template<class GridView>
128struct BasisTree;
129
130// Concept for a PowerBasisNode in a local ansatz tree
131template<class GridView>
132struct PowerBasisNode : Refines<BasisNode>
133{
134 template<class N>
135 auto require(const N& node) -> decltype(
136 requireBaseOf<Dune::Functions::PowerBasisNode<Dune::TypeTree::Child<N, 0>, N::degree()>, N>(),
137 requireConcept<BasisTree<GridView>, Dune::TypeTree::Child<N, 0>>()
138 );
139};
140
141// Concept for a DynamicPowerBasisNode in a local ansatz tree
142template<class GridView>
143struct DynamicPowerBasisNode : Refines<BasisNode>
144{
145 template<class N>
146 auto require(const N& node) -> decltype(
147 requireBaseOf<Dune::Functions::DynamicPowerBasisNode<Dune::TypeTree::Child<N, 0>>, N>(),
148 requireConcept<BasisTree<GridView>, Dune::TypeTree::Child<N, 0>>()
149 );
150};
151
152// Concept for a CompositeBasisNode in a local ansatz tree
153template<class GridView>
154struct CompositeBasisNode : Refines<BasisNode>
155{
156 template<class N>
157 auto require(const N& node) -> decltype(
158 requireBaseOf<ExpandTuple<Dune::Functions::template CompositeBasisNode, Dune::TypeTree::Impl::Children<N>>, N>(),
159 requireConceptForTupleEntries<BasisTree<GridView>, Dune::TypeTree::Impl::Children<N>>()
160 );
161};
162
163
164// Concept for a full local BasisTree
165template<class GridView>
166struct BasisTree : Refines<BasisNode>
167{
168 template<class N>
169 static constexpr bool hasStaticDegree() {
170 return requires() { N::degree(); };
171 }
172
173 template<class N>
174 auto require(const N& node) -> decltype(
175 requireConcept<std::conditional_t<Dune::TypeTree::Concept::LeafTreeNode<N>, LeafBasisNode<GridView>, BasisNode>, N>(),
176 requireConcept<std::conditional_t<Dune::TypeTree::Concept::UniformInnerTreeNode<N> and hasStaticDegree<N>(), PowerBasisNode<GridView>, BasisNode>, N>(),
177 requireConcept<std::conditional_t<Dune::TypeTree::Concept::UniformInnerTreeNode<N> and not hasStaticDegree<N>(), DynamicPowerBasisNode<GridView>, BasisNode>, N>(),
178 requireConcept<std::conditional_t<Dune::TypeTree::Concept::StaticDegreeInnerTreeNode<N> and (not Dune::TypeTree::Concept::UniformInnerTreeNode<N>), CompositeBasisNode<GridView>, BasisNode>, N>()
179 );
180};
181
182
183// Concept for a PreBasis
184template<class GridView>
186{
187private:
188 template<class PB>
189 using MultiIndex = Dune::ReservedVector<typename PB::size_type, PB::multiIndexBufferSize>;
190
191public:
192 template<class PB>
193 auto require(const PB& preBasis) -> decltype(
194 requireType<typename PB::GridView>(),
195 requireType<typename PB::size_type>(),
196 requireType<typename PB::Node>(),
197 requireConvertible<decltype(PB::maxMultiIndexSize), typename PB::size_type>(),
198 requireConvertible<decltype(PB::maxMultiIndexSize), typename PB::size_type>(),
199 requireConvertible<decltype(PB::multiIndexBufferSize), typename PB::size_type>(),
200 requireTrue<PB::minMultiIndexSize <= PB::maxMultiIndexSize>(),
201 requireTrue<PB::maxMultiIndexSize <= PB::multiIndexBufferSize>(),
202 requireSameType<typename PB::GridView, GridView>(),
203 const_cast<PB&>(preBasis).initializeIndices(),
204 requireConvertible<typename PB::GridView>(preBasis.gridView()),
205 requireConvertible<typename PB::Node>(preBasis.makeNode()),
206 requireConvertible<typename PB::size_type>(preBasis.size()),
207 requireConvertible<typename PB::size_type>(preBasis.size(std::declval<MultiIndex<PB>>())),
208 requireConvertible<typename PB::size_type>(preBasis.dimension()),
209 requireConvertible<typename PB::size_type>(preBasis.maxNodeSize()),
210 requireSameType<decltype(const_cast<PB&>(preBasis).update(preBasis.gridView())),void>(),
211 requireConcept<BasisTree<typename PB::GridView>>(preBasis.makeNode()),
212 requireConvertible<typename std::vector<MultiIndex<PB>>::iterator>(
213 preBasis.indices(
214 preBasis.makeNode(),
215 std::declval<typename std::vector<MultiIndex<PB>>::iterator>()))
216 );
217};
218
219
220
221// Concept for a LocalView
222template<class GlobalBasis>
224{
225 template<class V>
226 auto require(const V& localView) -> decltype(
227 requireType<typename V::size_type>(),
228 requireType<typename V::MultiIndex>(),
229 requireType<typename V::GlobalBasis>(),
230 requireType<typename V::Tree>(),
231 requireType<typename V::GridView>(),
232 requireType<typename V::Element>(),
233 requireSameType<typename V::GlobalBasis, GlobalBasis>(),
234 requireSameType<typename V::GridView, typename GlobalBasis::GridView>(),
235 requireSameType<typename V::size_type, typename GlobalBasis::size_type>(),
236 requireSameType<typename V::Element, typename GlobalBasis::GridView::template Codim<0>::Entity>(),
237 const_cast<V&>(localView).bind(std::declval<typename V::Element>()),
238 const_cast<V&>(localView).unbind(),
239 requireConvertible<bool>(localView.bound()),
240 requireConvertible<typename V::Tree>(localView.tree()),
241 requireConvertible<typename V::size_type>(localView.size()),
242 requireConvertible<typename V::MultiIndex>(localView.index(std::declval<typename V::size_type>())),
243 requireConvertible<typename V::size_type>(localView.maxSize()),
244 requireConvertible<typename V::GlobalBasis>(localView.globalBasis()),
245 requireConcept<BasisTree<typename V::GridView>>(localView.tree()),
246 0
247 );
248};
249
250
251
252// Concept for a GlobalBasis
253template<class GridView>
255{
256 template<class B>
257 auto require(const B& basis) -> decltype(
258 requireType<typename B::GridView>(),
259 requireType<typename B::size_type>(),
260 requireType<typename B::MultiIndex>(),
261 requireType<typename B::SizePrefix>(),
262 requireType<typename B::LocalView>(),
263 requireSameType<typename B::GridView, GridView>(),
264 requireConvertible<typename B::GridView>(basis.gridView()),
265 requireConvertible<typename B::LocalView>(basis.localView()),
266 requireConvertible<typename B::size_type>(basis.size()),
267 requireConvertible<typename B::size_type>(basis.size(std::declval<typename B::SizePrefix>())),
268 requireConvertible<typename B::size_type>(basis.dimension()),
269 requireSameType<decltype(const_cast<B&>(basis).update(basis.gridView())),void>(),
270 requireConcept<LocalView<B>>(basis.localView()),
271 requireConcept<ContainerDescriptor>(basis.containerDescriptor())
272 );
273};
274
275
276
277} // namespace Dune::Functions::Concept
278} // namespace Dune::Functions
279} // namespace Dune
280
281
282#endif // DUNE_FUNCTIONS_FUNCTIONSPACEBASES_CONCEPTS_HH
Definition monomialset.hh:19
Definition monomialset.hh:19
Definition backends/concepts.hh:17
Definition containerfactory.hh:20
Definition functionspacebases/concepts.hh:37
auto require(C &&c) -> decltype(c.resize(0))
Definition functionspacebases/concepts.hh:47
auto require(C &&c) -> decltype(c.size())
Definition functionspacebases/concepts.hh:57
auto require(C &&c, I &&i) -> decltype(c[i])
Definition functionspacebases/concepts.hh:66
void require(const Dune::Functions::ContainerDescriptors::Unknown &)
auto require(const CD &cd) -> decltype(requireConvertible< std::size_t >(cd.size()), children(cd, Dune::PriorityTag< 2 >{}))
Definition functionspacebases/concepts.hh:98
auto require(const N &node) -> decltype(requireType< typename N::size_type >(), requireConvertible< typename N::size_type >(node.size()), requireConvertible< typename N::size_type >(node.localIndex(std::declval< typename N::size_type >())), requireConvertible< typename N::size_type >(node.treeIndex()), requireBaseOf< BasisNodeMixin, N >())
Definition functionspacebases/concepts.hh:114
auto require(const N &node) -> decltype(requireType< typename N::Element >(), requireType< typename N::FiniteElement >(), requireConvertible< typename N::Element >(node.element()), requireConvertible< const typename N::FiniteElement & >(node.finiteElement()), requireSameType< typename N::Element, typename GridView::template Codim< 0 >::Entity >(), requireBaseOf< Dune::Functions::LeafBasisNode, N >())
Definition functionspacebases/concepts.hh:167
static constexpr bool hasStaticDegree()
Definition functionspacebases/concepts.hh:169
auto require(const N &node) -> decltype(requireConcept< std::conditional_t< Dune::TypeTree::Concept::LeafTreeNode< N >, LeafBasisNode< GridView >, BasisNode >, N >(), requireConcept< std::conditional_t< Dune::TypeTree::Concept::UniformInnerTreeNode< N > and hasStaticDegree< N >(), PowerBasisNode< GridView >, BasisNode >, N >(), requireConcept< std::conditional_t< Dune::TypeTree::Concept::UniformInnerTreeNode< N > and not hasStaticDegree< N >(), DynamicPowerBasisNode< GridView >, BasisNode >, N >(), requireConcept< std::conditional_t< Dune::TypeTree::Concept::StaticDegreeInnerTreeNode< N > and(not Dune::TypeTree::Concept::UniformInnerTreeNode< N >), CompositeBasisNode< GridView >, BasisNode >, N >())
Definition functionspacebases/concepts.hh:133
auto require(const N &node) -> decltype(requireBaseOf< Dune::Functions::PowerBasisNode< Dune::TypeTree::Child< N, 0 >, N::degree()>, N >(), requireConcept< BasisTree< GridView >, Dune::TypeTree::Child< N, 0 > >())
Definition functionspacebases/concepts.hh:144
auto require(const N &node) -> decltype(requireBaseOf< Dune::Functions::DynamicPowerBasisNode< Dune::TypeTree::Child< N, 0 > >, N >(), requireConcept< BasisTree< GridView >, Dune::TypeTree::Child< N, 0 > >())
Definition functionspacebases/concepts.hh:155
auto require(const N &node) -> decltype(requireBaseOf< ExpandTuple< Dune::Functions::template CompositeBasisNode, Dune::TypeTree::Impl::Children< N > >, N >(), requireConceptForTupleEntries< BasisTree< GridView >, Dune::TypeTree::Impl::Children< N > >())
Definition functionspacebases/concepts.hh:186
auto require(const PB &preBasis) -> decltype(requireType< typename PB::GridView >(), requireType< typename PB::size_type >(), requireType< typename PB::Node >(), requireConvertible< decltype(PB::maxMultiIndexSize), typename PB::size_type >(), requireConvertible< decltype(PB::maxMultiIndexSize), typename PB::size_type >(), requireConvertible< decltype(PB::multiIndexBufferSize), typename PB::size_type >(), requireTrue< PB::minMultiIndexSize<=PB::maxMultiIndexSize >(), requireTrue< PB::maxMultiIndexSize<=PB::multiIndexBufferSize >(), requireSameType< typename PB::GridView, GridView >(), const_cast< PB & >(preBasis).initializeIndices(), requireConvertible< typename PB::GridView >(preBasis.gridView()), requireConvertible< typename PB::Node >(preBasis.makeNode()), requireConvertible< typename PB::size_type >(preBasis.size()), requireConvertible< typename PB::size_type >(preBasis.size(std::declval< MultiIndex< PB > >())), requireConvertible< typename PB::size_type >(preBasis.dimension()), requireConvertible< typename PB::size_type >(preBasis.maxNodeSize()), requireSameType< decltype(const_cast< PB & >(preBasis).update(preBasis.gridView())), void >(), requireConcept< BasisTree< typename PB::GridView > >(preBasis.makeNode()), requireConvertible< typename std::vector< MultiIndex< PB > >::iterator >(preBasis.indices(preBasis.makeNode(), std::declval< typename std::vector< MultiIndex< PB > >::iterator >())))
Definition functionspacebases/concepts.hh:224
auto require(const V &localView) -> decltype(requireType< typename V::size_type >(), requireType< typename V::MultiIndex >(), requireType< typename V::GlobalBasis >(), requireType< typename V::Tree >(), requireType< typename V::GridView >(), requireType< typename V::Element >(), requireSameType< typename V::GlobalBasis, GlobalBasis >(), requireSameType< typename V::GridView, typename GlobalBasis::GridView >(), requireSameType< typename V::size_type, typename GlobalBasis::size_type >(), requireSameType< typename V::Element, typename GlobalBasis::GridView::template Codim< 0 >::Entity >(), const_cast< V & >(localView).bind(std::declval< typename V::Element >()), const_cast< V & >(localView).unbind(), requireConvertible< bool >(localView.bound()), requireConvertible< typename V::Tree >(localView.tree()), requireConvertible< typename V::size_type >(localView.size()), requireConvertible< typename V::MultiIndex >(localView.index(std::declval< typename V::size_type >())), requireConvertible< typename V::size_type >(localView.maxSize()), requireConvertible< typename V::GlobalBasis >(localView.globalBasis()), requireConcept< BasisTree< typename V::GridView > >(localView.tree()), 0)
Definition functionspacebases/concepts.hh:255
auto require(const B &basis) -> decltype(requireType< typename B::GridView >(), requireType< typename B::size_type >(), requireType< typename B::MultiIndex >(), requireType< typename B::SizePrefix >(), requireType< typename B::LocalView >(), requireSameType< typename B::GridView, GridView >(), requireConvertible< typename B::GridView >(basis.gridView()), requireConvertible< typename B::LocalView >(basis.localView()), requireConvertible< typename B::size_type >(basis.size()), requireConvertible< typename B::size_type >(basis.size(std::declval< typename B::SizePrefix >())), requireConvertible< typename B::size_type >(basis.dimension()), requireSameType< decltype(const_cast< B & >(basis).update(basis.gridView())), void >(), requireConcept< LocalView< B > >(basis.localView()), requireConcept< ContainerDescriptor >(basis.containerDescriptor()))
Fallback container descriptor if nothing else fits.
Definition containerdescriptors.hh:52