/usr/include/dune/pdelab/finiteelementmap/monomfem.hh is in libdune-pdelab-dev 2.4.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | // -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
// vi: set et ts=4 sw=2 sts=2:
#ifndef DUNE_PDELAB_MONOMFEM_HH
#define DUNE_PDELAB_MONOMFEM_HH
#include <cstddef>
#include <dune/geometry/type.hh>
#include<dune/localfunctions/monomial.hh>
#include"finiteelementmap.hh"
#include <dune/pdelab/finiteelementmap/global.hh>
namespace Dune {
namespace PDELab {
//! wrap up element from local functions
//! \ingroup FiniteElementMap
template<class D, class R, int d, int p>
class MonomLocalFiniteElementMap
: public SimpleLocalFiniteElementMap< Dune::MonomialLocalFiniteElement<D,R,d,p> >
{
public:
MonomLocalFiniteElementMap (const Dune::GeometryType& type)
: SimpleLocalFiniteElementMap< Dune::MonomialLocalFiniteElement<D,R,d,p> >(Dune::MonomialLocalFiniteElement<D,R,d,p>(type)), _gt(type)
{
}
bool fixedSize() const
{
return true;
}
bool hasDOFs(int codim) const
{
return codim == 0;
}
std::size_t size(GeometryType gt) const
{
return gt == _gt ? Dune::MonomImp::Size<d,p>::val : 0;
}
std::size_t maxLocalSize() const
{
return MonomImp::Size<d,p>::val;
}
private:
const GeometryType _gt;
};
//! Global-valued finite element map for Monom elements
/**
* \ingroup FiniteElementMap
*
* \tparam Geometry Type of the geometry od the elements.
* \tparam RF Range field type.
* \tparam p Maximum polynomial order of the elements.
*/
template<class Geometry, class RF, std::size_t p>
class MonomFiniteElementMap
: public GeometryFiniteElementMap<
MonomialFiniteElementFactory<Geometry, RF, p>
>
{
typedef MonomialFiniteElementFactory<Geometry, RF, p> FEFactory;
typedef GeometryFiniteElementMap<FEFactory> Base;
static FEFactory feFactory;
public:
MonomFiniteElementMap() : Base(feFactory) { }
};
template<class GV, class RF, std::size_t p>
typename MonomFiniteElementMap<GV, RF, p>::FEFactory
MonomFiniteElementMap<GV, RF, p>::feFactory;
}
}
#endif //DUNE_PDELAB_MONOMFEM_HH
|