18 #include <deal.II/base/quadrature.h> 19 #include <deal.II/base/quadrature_lib.h> 20 #include <deal.II/base/qprojector.h> 21 #include <deal.II/fe/fe_nothing.h> 22 #include <deal.II/fe/fe_q.h> 23 #include <deal.II/fe/fe_tools.h> 24 #include <deal.II/fe/fe_bernstein.h> 25 #include <deal.II/base/polynomials_bernstein.h> 30 DEAL_II_NAMESPACE_OPEN
34 template <
int dim,
int spacedim>
38 this->renumber_bases(degree),
42 std::vector<bool> (1, false))
46 template <
int dim,
int spacedim>
52 Assert (dim > 1, ExcImpossibleInDim(1));
54 interpolation_matrix);
58 template <
int dim,
int spacedim>
62 const unsigned int subface,
66 ExcDimensionMismatch (interpolation_matrix.
m(),
76 ExcDimensionMismatch (interpolation_matrix.
n(),
86 ExcInterpolationNotImplemented ()));
94 double eps = 2e-13 * std::max(this->
degree, source_fe->degree) * (dim-1);
108 for (
unsigned int i=0; i<source_fe->dofs_per_face; ++i)
110 const Point<dim> &p = subface_quadrature.point (i);
118 if (std::fabs (matrix_entry - 1.0) < eps)
120 if (std::fabs (matrix_entry) < eps)
123 interpolation_matrix(i,j) = matrix_entry;
129 for (
unsigned int j=0; j<source_fe->dofs_per_face; ++j)
134 sum += interpolation_matrix(j,i);
136 Assert (std::fabs(sum-1) < eps, ExcInternalError());
145 ExcInterpolationNotImplemented()));
150 template <
int dim,
int spacedim>
158 template <
int dim,
int spacedim>
159 std::vector<std::pair<unsigned int, unsigned int> >
169 std::vector<std::pair<unsigned int, unsigned int> >
170 (1, std::make_pair (0U, 0U));
176 return std::vector<std::pair<unsigned int, unsigned int> > ();
187 return std::vector<std::pair<unsigned int, unsigned int> > ();
191 Assert (
false, ExcNotImplemented());
192 return std::vector<std::pair<unsigned int, unsigned int> > ();
197 template <
int dim,
int spacedim>
198 std::vector<std::pair<unsigned int, unsigned int> >
207 return std::vector<std::pair<unsigned int, unsigned int> > ();
211 template <
int dim,
int spacedim>
212 std::vector<std::pair<unsigned int, unsigned int> >
221 return std::vector<std::pair<unsigned int, unsigned int> > ();
225 template <
int dim,
int spacedim>
232 if (this->degree < fe_b_other->
degree)
233 return FiniteElementDomination::this_element_dominates;
234 else if (this->degree == fe_b_other->degree)
235 return FiniteElementDomination::either_element_can_dominate;
237 return FiniteElementDomination::other_element_dominates;
241 if (fe_nothing->is_dominating())
243 return FiniteElementDomination::other_element_dominates;
249 return FiniteElementDomination::no_requirements;
253 Assert (
false, ExcNotImplemented());
254 return FiniteElementDomination::neither_element_dominates;
258 template <
int dim,
int spacedim>
266 std::ostringstream namebuf;
267 namebuf <<
"FE_Bernstein<" << dim <<
">(" << this->
degree <<
")";
268 return namebuf.str();
272 template <
int dim,
int spacedim>
283 template <
int dim,
int spacedim>
284 std::vector<unsigned int>
288 std::vector<unsigned int> dpo(dim+1, 1U);
289 for (
unsigned int i=1; i<dpo.size(); ++i)
290 dpo[i]=dpo[i-1]*(deg-1);
295 template <
int dim,
int spacedim>
300 std::vector<unsigned int> renumber(Utilities::fixed_power<dim>(deg+1));
310 #include "fe_bernstein.inst" 312 DEAL_II_NAMESPACE_CLOSE
static const unsigned int invalid_unsigned_int
FE_Bernstein(const unsigned int p)
const std::vector< Point< dim-1 > > & get_unit_face_support_points() const
virtual std::string get_name() const
::ExceptionBase & ExcMessage(std::string arg1)
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
const unsigned int degree
void set_numbering(const std::vector< unsigned int > &renumber)
#define AssertThrow(cond, exc)
virtual bool hp_constraints_are_implemented() const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
#define Assert(cond, exc)
static void project_to_subface(const SubQuadrature &quadrature, const unsigned int face_no, const unsigned int subface_no, std::vector< Point< dim > > &q_points, const RefinementCase< dim-1 > &ref_case=RefinementCase< dim-1 >::isotropic_refinement)
virtual unsigned int face_to_cell_index(const unsigned int face_dof_index, const unsigned int face, const bool face_orientation=true, const bool face_flip=false, const bool face_rotation=false) const
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const
TensorProductPolynomials< dim > renumber_bases(const unsigned int degree)
virtual FiniteElement< dim, spacedim > * clone() const
virtual double shape_value(const unsigned int i, const Point< dim > &p) const
static void project_to_face(const SubQuadrature &quadrature, const unsigned int face_no, std::vector< Point< dim > > &q_points)
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
const unsigned int dofs_per_face