Reference documentation for deal.II version 8.4.2
fe_q_hierarchical.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2002 - 2015 by the deal.II authors
4 //
5 // This file is part of the deal.II library.
6 //
7 // The deal.II library is free software; you can use it, redistribute
8 // it, and/or modify it under the terms of the GNU Lesser General
9 // Public License as published by the Free Software Foundation; either
10 // version 2.1 of the License, or (at your option) any later version.
11 // The full text of the license can be found in the file LICENSE at
12 // the top level of the deal.II distribution.
13 //
14 // ---------------------------------------------------------------------
15 
16 #ifndef dealii__fe_q_hierarchical_h
17 #define dealii__fe_q_hierarchical_h
18 
19 #include <deal.II/base/config.h>
20 #include <deal.II/base/tensor_product_polynomials.h>
21 #include <deal.II/fe/fe_poly.h>
22 
23 DEAL_II_NAMESPACE_OPEN
24 
25 template <int dim, int spacedim> class MappingQ;
26 
27 
30 
543 template <int dim>
544 class FE_Q_Hierarchical : public FE_Poly<TensorProductPolynomials<dim>,dim>
545 {
546 public:
550  FE_Q_Hierarchical (const unsigned int p);
551 
557  virtual std::string get_name () const;
558 
563  virtual bool has_support_on_face (const unsigned int shape_index,
564  const unsigned int face_index) const;
565 
579  virtual bool hp_constraints_are_implemented () const;
580 
585  virtual void get_interpolation_matrix(const FiniteElement< dim> &source,
586  FullMatrix< double > &matrix) const;
587 
591  virtual const
592  FullMatrix<double> &get_prolongation_matrix (const unsigned int child,
594 
610  virtual
611  std::vector<std::pair<unsigned int, unsigned int> >
612  hp_vertex_dof_identities (const FiniteElement<dim> &fe_other) const;
613 
617  virtual
618  std::vector<std::pair<unsigned int, unsigned int> >
619  hp_line_dof_identities (const FiniteElement<dim> &fe_other) const;
620 
624  virtual
625  std::vector<std::pair<unsigned int, unsigned int> >
626  hp_quad_dof_identities (const FiniteElement<dim> &fe_other) const;
627 
641  virtual void get_face_interpolation_matrix (const FiniteElement<dim> &source, FullMatrix<double> &matrix) const;
642 
654  virtual void get_subface_interpolation_matrix (const FiniteElement<dim> &source, const unsigned int subface, FullMatrix<double> &matrix) const;
655 
665  virtual
667  compare_for_face_domination (const FiniteElement<dim> &fe_other) const;
668 
677  virtual std::size_t memory_consumption () const;
678 
684  std::vector<unsigned int> get_embedding_dofs (const unsigned int sub_degree) const;
685 
691  virtual std::pair<Table<2,bool>, std::vector<unsigned int> >
692  get_constant_modes () const;
693 
697  virtual
698  void interpolate(std::vector<double> &local_dofs,
699  const std::vector<double> &values) const;
700 
704  virtual
705  void
706  interpolate(std::vector<double> &local_dofs,
707  const std::vector<Vector<double> > &values,
708  unsigned int offset = 0) const;
709 
713  virtual
714  void
715  interpolate(std::vector<double> &local_dofs,
716  const VectorSlice<const std::vector<std::vector<double> > > &values) const;
717 
718 
719 protected:
725  virtual FiniteElement<dim> *clone() const;
726 
727 private:
728 
735  static std::vector<unsigned int> get_dpo_vector(const unsigned int degree);
736 
764  static
765  std::vector<unsigned int> hierarchic_to_fe_q_hierarchical_numbering (
766  const FiniteElementData<dim> &fe);
767 
771  static
772  std::vector<unsigned int>
773  face_fe_q_hierarchical_to_hierarchic_numbering (const unsigned int degree);
774 
779  void build_dofs_cell (std::vector<FullMatrix<double> > &dofs_cell,
780  std::vector<FullMatrix<double> > &dofs_subcell) const;
781 
786  void initialize_constraints (const std::vector<FullMatrix<double> > &dofs_subcell);
787 
791  void initialize_embedding_and_restriction (const std::vector<FullMatrix<double> > &dofs_cell,
792  const std::vector<FullMatrix<double> > &dofs_subcell);
793 
799 
805 
809  const std::vector<unsigned int> face_renumber;
810 
817  template <int dim1> friend class FE_Q_Hierarchical;
818 };
819 
822 /* -------------- declaration of explicit specializations ------------- */
823 
824 template <>
826 
827 template <>
828 bool
830  const unsigned int) const;
831 
832 template <>
833 std::vector<unsigned int>
835 
836 DEAL_II_NAMESPACE_CLOSE
837 
838 #endif
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim > &fe_other) const
virtual bool hp_constraints_are_implemented() const
void initialize_embedding_and_restriction(const std::vector< FullMatrix< double > > &dofs_cell, const std::vector< FullMatrix< double > > &dofs_subcell)
const unsigned int degree
Definition: fe_base.h:299
void initialize_unit_support_points()
virtual FiniteElement< dim > * clone() const
const std::vector< unsigned int > face_renumber
virtual void get_interpolation_matrix(const FiniteElement< dim > &source, FullMatrix< double > &matrix) const
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
std::vector< unsigned int > get_embedding_dofs(const unsigned int sub_degree) const
virtual std::string get_name() const
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
static std::vector< unsigned int > face_fe_q_hierarchical_to_hierarchic_numbering(const unsigned int degree)
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const
void initialize_constraints(const std::vector< FullMatrix< double > > &dofs_subcell)
virtual void get_subface_interpolation_matrix(const FiniteElement< dim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
friend class FE_Q_Hierarchical
static std::vector< unsigned int > hierarchic_to_fe_q_hierarchical_numbering(const FiniteElementData< dim > &fe)
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim > &fe_other) const
virtual void interpolate(std::vector< double > &local_dofs, const std::vector< double > &values) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim > &fe_other) const
void initialize_unit_face_support_points()
virtual void get_face_interpolation_matrix(const FiniteElement< dim > &source, FullMatrix< double > &matrix) const
virtual std::size_t memory_consumption() const
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim > &fe_other) const
void build_dofs_cell(std::vector< FullMatrix< double > > &dofs_cell, std::vector< FullMatrix< double > > &dofs_subcell) const