2#ifndef DUNE_PDELAB_CONSTRAINTS_RAVIARTTHOMAS0_HH
3#define DUNE_PDELAB_CONSTRAINTS_RAVIARTTHOMAS0_HH
5#include<dune/typetree/typetree.hh>
8#include<dune/geometry/referenceelements.hh>
10#include<dune/pdelab/common/geometrywrapper.hh>
12#include <dune/typetree/typetree.hh>
22 enum{doBoundary=
true};
23 enum{doProcessor=
false};
24 enum{doSkeleton=
false};
35 template<
typename P,
typename IG,
typename LFS,
typename T>
36 void boundary (
const P& p,
const IG& ig,
const LFS& lfs, T& trafo)
const
38 const int face = ig.indexInInside();
40 const auto ip = face_refelem.position(0,0);
41 if (p.isNeumann(ig,ip)) {
42 typename T::RowType empty;
43 trafo[lfs.dofIndex(face)]=empty;
Neumann Constraints construction, as needed for RT0.
Definition: raviartthomas0.hh:20
void boundary(const P &p, const IG &ig, const LFS &lfs, T &trafo) const
boundary constraints
Definition: raviartthomas0.hh:36
Base class for leaf nodes in a dune-typetree.
Definition: leafnode.hh:26
A few common exception classes.
unspecified value type referenceElement(T &&... t)
Returns a reference element for the objects t....
Dune namespace.
Definition: alignedallocator.hh:13
A unique label for each type of element that can occur in a grid.