Reference documentation for deal.II version 9.1.0-pre
fe_dgp_nonparametric.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2002 - 2018 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.md at
12 // the top level directory of deal.II.
13 //
14 // ---------------------------------------------------------------------
15 
16 #ifndef dealii_fe_dgp_nonparametric_h
17 #define dealii_fe_dgp_nonparametric_h
18 
19 #include <deal.II/base/config.h>
20 
21 #include <deal.II/base/polynomial.h>
22 #include <deal.II/base/polynomial_space.h>
23 
24 #include <deal.II/fe/fe.h>
25 #include <deal.II/fe/mapping.h>
26 
27 DEAL_II_NAMESPACE_OPEN
28 
31 
270 template <int dim, int spacedim = dim>
271 class FE_DGPNonparametric : public FiniteElement<dim, spacedim>
272 {
273 public:
277  FE_DGPNonparametric(const unsigned int k);
278 
284  virtual std::string
285  get_name() const override;
286 
287  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
288  clone() const override;
289 
290  // for documentation, see the FiniteElement base class
291  virtual UpdateFlags
292  requires_update_flags(const UpdateFlags update_flags) const override;
293 
304  virtual double
305  shape_value(const unsigned int i, const Point<dim> &p) const override;
306 
317  virtual double
318  shape_value_component(const unsigned int i,
319  const Point<dim> & p,
320  const unsigned int component) const override;
321 
332  virtual Tensor<1, dim>
333  shape_grad(const unsigned int i, const Point<dim> &p) const override;
334 
345  virtual Tensor<1, dim>
346  shape_grad_component(const unsigned int i,
347  const Point<dim> & p,
348  const unsigned int component) const override;
349 
360  virtual Tensor<2, dim>
361  shape_grad_grad(const unsigned int i, const Point<dim> &p) const override;
362 
373  virtual Tensor<2, dim>
374  shape_grad_grad_component(const unsigned int i,
375  const Point<dim> & p,
376  const unsigned int component) const override;
377 
382  unsigned int
383  get_degree() const;
384 
396  virtual void
398  FullMatrix<double> &matrix) const override;
399 
411  virtual void
413  const unsigned int subface,
414  FullMatrix<double> &matrix) const override;
415 
439  virtual std::vector<std::pair<unsigned int, unsigned int>>
441  const FiniteElement<dim, spacedim> &fe_other) const override;
442 
450  virtual std::vector<std::pair<unsigned int, unsigned int>>
452  const FiniteElement<dim, spacedim> &fe_other) const override;
453 
461  virtual std::vector<std::pair<unsigned int, unsigned int>>
463  const FiniteElement<dim, spacedim> &fe_other) const override;
464 
473  virtual bool
474  hp_constraints_are_implemented() const override;
475 
487  const FiniteElement<dim, spacedim> &fe_other) const override;
488 
497  virtual bool
498  has_support_on_face(const unsigned int shape_index,
499  const unsigned int face_index) const override;
500 
509  virtual std::size_t
510  memory_consumption() const override;
511 
512 protected:
517  virtual std::unique_ptr<
519  get_data(
520  const UpdateFlags update_flags,
521  const Mapping<dim, spacedim> &mapping,
522  const Quadrature<dim> & quadrature,
524  spacedim>
525  &output_data) const override;
526 
527  virtual void
528  fill_fe_values(
529  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
530  const CellSimilarity::Similarity cell_similarity,
531  const Quadrature<dim> & quadrature,
532  const Mapping<dim, spacedim> & mapping,
533  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
534  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
535  spacedim>
536  & mapping_data,
537  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
539  spacedim>
540  &output_data) const override;
541 
542  virtual void
543  fill_fe_face_values(
544  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
545  const unsigned int face_no,
546  const Quadrature<dim - 1> & quadrature,
547  const Mapping<dim, spacedim> & mapping,
548  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
549  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
550  spacedim>
551  & mapping_data,
552  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
554  spacedim>
555  &output_data) const override;
556 
557  virtual void
558  fill_fe_subface_values(
559  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
560  const unsigned int face_no,
561  const unsigned int sub_no,
562  const Quadrature<dim - 1> & quadrature,
563  const Mapping<dim, spacedim> & mapping,
564  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
565  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
566  spacedim>
567  & mapping_data,
568  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
570  spacedim>
571  &output_data) const override;
572 
573 private:
580  static std::vector<unsigned int>
581  get_dpo_vector(const unsigned int degree);
582 
587 
591  template <int, int>
592  friend class FE_DGPNonparametric;
593 };
594 
597 DEAL_II_NAMESPACE_CLOSE
598 
599 #endif
virtual Tensor< 1, dim > shape_grad(const unsigned int i, const Point< dim > &p) const override
friend class FE_DGPNonparametric
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::size_t memory_consumption() const override
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const override
virtual double shape_value(const unsigned int i, const Point< dim > &p) const override
const unsigned int degree
Definition: fe_base.h:313
virtual double shape_value_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
const PolynomialSpace< dim > polynomial_space
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
virtual bool hp_constraints_are_implemented() const override
unsigned int get_degree() const
UpdateFlags
Abstract base class for mapping classes.
Definition: dof_tools.h:57
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
virtual Tensor< 1, dim > shape_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual Tensor< 2, dim > shape_grad_grad(const unsigned int i, const Point< dim > &p) const override
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
virtual std::string get_name() const override
virtual Tensor< 2, dim > shape_grad_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const override
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override