17 #include <deal.II/base/quadrature.h> 18 #include <deal.II/grid/tria.h> 19 #include <deal.II/grid/tria_iterator.h> 20 #include <deal.II/dofs/dof_accessor.h> 21 #include <deal.II/fe/fe.h> 22 #include <deal.II/fe/mapping.h> 23 #include <deal.II/fe/fe_dgp_nonparametric.h> 24 #include <deal.II/fe/fe_values.h> 28 DEAL_II_NAMESPACE_OPEN
30 template <
int dim,
int spacedim>
40 std::vector<bool>(1,true))),
42 polynomial_space (
Polynomials::Legendre::generate_complete_basis(degree))
46 ref_case<RefinementCase<dim>::isotropic_refinement+1; ++ref_case)
55 for (
unsigned int i=0; i<nc; ++i)
57 this->
prolongation[ref_case-1][i].reinit (n_dofs, n_dofs);
60 for (
unsigned int j=0; j<n_dofs; ++j)
96 template <
int dim,
int spacedim>
107 std::ostringstream namebuf;
108 namebuf <<
"FE_DGPNonparametric<" 112 return namebuf.str();
117 template <
int dim,
int spacedim>
126 template <
int dim,
int spacedim>
140 template <
int dim,
int spacedim>
144 const unsigned int component)
const 150 Assert (component == 0, ExcIndexRange (component, 0, 1));
157 template <
int dim,
int spacedim>
170 template <
int dim,
int spacedim>
174 const unsigned int component)
const 180 Assert (component == 0, ExcIndexRange (component, 0, 1));
187 template <
int dim,
int spacedim>
201 template <
int dim,
int spacedim>
205 const unsigned int component)
const 211 Assert (component == 0, ExcIndexRange (component, 0, 1));
222 template <
int dim,
int spacedim>
223 std::vector<unsigned int>
226 std::vector<unsigned int> dpo(dim+1, static_cast<unsigned int>(0));
228 for (
unsigned int i=1; i<dim; ++i)
238 template <
int dim,
int spacedim>
256 template <
int dim,
int spacedim>
281 template <
int dim,
int spacedim>
285 const CellSimilarity::Similarity ,
289 const ::internal::FEValues::MappingRelatedData<dim, spacedim> &mapping_data,
295 const unsigned int n_q_points = mapping_data.quadrature_points.size();
300 std::vector<Tensor<3,dim> > empty_vector_of_3rd_order_tensors;
301 std::vector<Tensor<4,dim> > empty_vector_of_4th_order_tensors;
304 for (
unsigned int i=0; i<n_q_points; ++i)
307 values, grads, grad_grads,
308 empty_vector_of_3rd_order_tensors,
309 empty_vector_of_4th_order_tensors);
327 template <
int dim,
int spacedim>
335 const ::internal::FEValues::MappingRelatedData<dim, spacedim> &mapping_data,
341 const unsigned int n_q_points = mapping_data.quadrature_points.size();
346 std::vector<Tensor<3,dim> > empty_vector_of_3rd_order_tensors;
347 std::vector<Tensor<4,dim> > empty_vector_of_4th_order_tensors;
350 for (
unsigned int i=0; i<n_q_points; ++i)
353 values, grads, grad_grads,
354 empty_vector_of_3rd_order_tensors,
355 empty_vector_of_4th_order_tensors);
373 template <
int dim,
int spacedim>
382 const ::internal::FEValues::MappingRelatedData<dim, spacedim> &mapping_data,
388 const unsigned int n_q_points = mapping_data.quadrature_points.size();
393 std::vector<Tensor<3,dim> > empty_vector_of_3rd_order_tensors;
394 std::vector<Tensor<4,dim> > empty_vector_of_4th_order_tensors;
397 for (
unsigned int i=0; i<n_q_points; ++i)
400 values, grads, grad_grads,
401 empty_vector_of_3rd_order_tensors,
402 empty_vector_of_4th_order_tensors);
420 template <
int dim,
int spacedim>
432 (void)interpolation_matrix;
438 ExcInterpolationNotImplemented());
440 Assert (interpolation_matrix.
m() == 0,
441 ExcDimensionMismatch (interpolation_matrix.
m(),
443 Assert (interpolation_matrix.
n() == 0,
444 ExcDimensionMismatch (interpolation_matrix.
n(),
450 template <
int dim,
int spacedim>
463 (void)interpolation_matrix;
469 ExcInterpolationNotImplemented());
471 Assert (interpolation_matrix.
m() == 0,
472 ExcDimensionMismatch (interpolation_matrix.
m(),
474 Assert (interpolation_matrix.
n() == 0,
475 ExcDimensionMismatch (interpolation_matrix.
n(),
481 template <
int dim,
int spacedim>
490 template <
int dim,
int spacedim>
491 std::vector<std::pair<unsigned int, unsigned int> >
499 std::vector<std::pair<unsigned int, unsigned int> > ();
502 Assert (
false, ExcNotImplemented());
503 return std::vector<std::pair<unsigned int, unsigned int> > ();
509 template <
int dim,
int spacedim>
510 std::vector<std::pair<unsigned int, unsigned int> >
518 std::vector<std::pair<unsigned int, unsigned int> > ();
521 Assert (
false, ExcNotImplemented());
522 return std::vector<std::pair<unsigned int, unsigned int> > ();
528 template <
int dim,
int spacedim>
529 std::vector<std::pair<unsigned int, unsigned int> >
537 std::vector<std::pair<unsigned int, unsigned int> > ();
540 Assert (
false, ExcNotImplemented());
541 return std::vector<std::pair<unsigned int, unsigned int> > ();
547 template <
int dim,
int spacedim>
556 return FiniteElementDomination::no_requirements;
558 Assert (
false, ExcNotImplemented());
559 return FiniteElementDomination::neither_element_dominates;
564 template <
int dim,
int spacedim>
567 const unsigned int)
const 574 template <
int dim,
int spacedim>
578 Assert (
false, ExcNotImplemented ());
584 template <
int dim,
int spacedim>
594 #include "fe_dgp_nonparametric.inst" 597 DEAL_II_NAMESPACE_CLOSE
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const
virtual FiniteElement< dim, spacedim >::InternalDataBase * get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature, ::internal::FEValues::FiniteElementRelatedData< dim, spacedim > &output_data) const
friend class FE_DGPNonparametric
virtual std::size_t memory_consumption() const
const PolynomialSpace< dim > polynomial_space
Transformed quadrature points.
virtual bool hp_constraints_are_implemented() const
#define AssertThrow(cond, exc)
virtual FiniteElement< dim, spacedim > * clone() const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual Tensor< 2, dim > shape_grad_grad(const unsigned int i, const Point< dim > &p) const
static unsigned int n_children(const RefinementCase< dim > &refinement_case)
virtual double shape_value_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const
unsigned int get_degree() const
std::vector< std::vector< FullMatrix< double > > > prolongation
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
#define Assert(cond, exc)
Abstract base class for mapping classes.
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
virtual std::string get_name() const =0
Second derivatives of shape functions.
std::string dim_string(const int dim, const int spacedim)
const unsigned int dofs_per_cell
Shape function gradients.
virtual Tensor< 2, dim > shape_grad_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const
virtual Tensor< 1, dim > shape_grad(const unsigned int i, const Point< dim > &p) const
virtual Tensor< 1, dim > shape_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const
virtual double shape_value(const unsigned int i, const Point< dim > &p) const
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
const unsigned int degree
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
virtual std::string get_name() const