16 #ifndef dealii__mapping_q_generic_h 17 #define dealii__mapping_q_generic_h 20 #include <deal.II/base/derivative_form.h> 21 #include <deal.II/base/config.h> 22 #include <deal.II/base/table.h> 23 #include <deal.II/base/quadrature_lib.h> 24 #include <deal.II/base/qprojector.h> 25 #include <deal.II/grid/tria_iterator.h> 26 #include <deal.II/dofs/dof_accessor.h> 27 #include <deal.II/fe/mapping.h> 28 #include <deal.II/fe/fe_q.h> 32 DEAL_II_NAMESPACE_OPEN
87 template <
int dim,
int spacedim=dim>
227 const unsigned int n_original_q_points);
237 const unsigned int n_original_q_points);
261 const double &
shape (
const unsigned int qpoint,
262 const unsigned int shape_nr)
const;
267 double &
shape (
const unsigned int qpoint,
268 const unsigned int shape_nr);
274 const unsigned int shape_nr)
const;
280 const unsigned int shape_nr);
286 const unsigned int shape_nr)
const;
292 const unsigned int shape_nr);
298 const unsigned int shape_nr)
const;
304 const unsigned int shape_nr);
310 const unsigned int shape_nr)
const;
316 const unsigned int shape_nr);
402 mutable std::vector<DerivativeForm<1,dim, spacedim > >
covariant;
416 mutable std::vector<std::vector<Tensor<1,spacedim> > >
aux;
462 CellSimilarity::Similarity
464 const CellSimilarity::Similarity cell_similarity,
472 const unsigned int face_no,
480 const unsigned int face_no,
481 const unsigned int subface_no,
514 const std_cxx11::unique_ptr<FE_Q<dim> >
fe_q;
570 std::vector<Point<spacedim> >
635 template<
int dim,
int spacedim>
639 const unsigned int shape_nr)
const 649 template<
int dim,
int spacedim>
653 const unsigned int shape_nr)
662 template<
int dim,
int spacedim>
666 const unsigned int shape_nr)
const 676 template<
int dim,
int spacedim>
680 const unsigned int shape_nr)
689 template <
int dim,
int spacedim>
693 const unsigned int shape_nr)
const 702 template <
int dim,
int spacedim>
706 const unsigned int shape_nr)
714 template <
int dim,
int spacedim>
718 const unsigned int shape_nr)
const 727 template <
int dim,
int spacedim>
731 const unsigned int shape_nr)
740 template <
int dim,
int spacedim>
744 const unsigned int shape_nr)
const 753 template <
int dim,
int spacedim>
757 const unsigned int shape_nr)
767 template <
int dim,
int spacedim>
780 DEAL_II_NAMESPACE_CLOSE
std::vector< DerivativeForm< 1, dim, spacedim > > covariant
const std_cxx11::unique_ptr< FE_Q< dim > > fe_q
Table< 2, double > support_point_weights_on_hex
std::vector< Tensor< 2, dim > > shape_second_derivatives
const unsigned int polynomial_degree
virtual CellSimilarity::Similarity fill_fe_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const CellSimilarity::Similarity cell_similarity, const Quadrature< dim > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, ::internal::FEValues::MappingRelatedData< dim, spacedim > &output_data) const
virtual void fill_fe_face_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const Quadrature< dim-1 > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, ::internal::FEValues::MappingRelatedData< dim, spacedim > &output_data) const
virtual InternalData * get_subface_data(const UpdateFlags flags, const Quadrature< dim-1 > &quadrature) const
virtual InternalData * get_data(const UpdateFlags, const Quadrature< dim > &quadrature) const
std::vector< Tensor< 4, dim > > shape_fourth_derivatives
virtual Mapping< dim, spacedim > * clone() const
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const
Triangulation< dim, spacedim >::cell_iterator cell_of_current_support_points
const Tensor< 3, dim > & third_derivative(const unsigned int qpoint, const unsigned int shape_nr) const
MappingQGeneric(const unsigned int polynomial_degree)
const Tensor< 4, dim > & fourth_derivative(const unsigned int qpoint, const unsigned int shape_nr) const
InternalData(const unsigned int polynomial_degree)
std::vector< Tensor< 1, dim > > shape_derivatives
virtual void add_quad_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell, std::vector< Point< spacedim > > &a) const
void compute_shape_function_values(const std::vector< Point< dim > > &unit_points)
#define Assert(cond, exc)
Abstract base class for mapping classes.
virtual void transform(const ArrayView< const Tensor< 1, dim > > &input, const MappingType type, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 1, spacedim > > &output) const
std::vector< Point< spacedim > > mapping_support_points
std::vector< DerivativeForm< 1, dim, spacedim > > contravariant
std::vector< std::vector< Tensor< 1, spacedim > > > aux
void initialize(const UpdateFlags update_flags, const Quadrature< dim > &quadrature, const unsigned int n_original_q_points)
std::vector< double > volume_elements
const unsigned int n_shape_functions
Point< dim > transform_real_to_unit_cell_internal(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p, const Point< dim > &initial_p_unit) const
virtual std::size_t memory_consumption() const
unsigned int get_degree() const
const double & shape(const unsigned int qpoint, const unsigned int shape_nr) const
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const
unsigned int polynomial_degree
Table< 2, double > support_point_weights_on_quad
virtual void fill_fe_subface_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int subface_no, const Quadrature< dim-1 > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, ::internal::FEValues::MappingRelatedData< dim, spacedim > &output_data) const
virtual std::vector< Point< spacedim > > compute_mapping_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const
virtual void add_line_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell, std::vector< Point< spacedim > > &a) const
virtual InternalData * get_face_data(const UpdateFlags flags, const Quadrature< dim-1 > &quadrature) const
virtual bool preserves_vertex_locations() const
std::vector< Tensor< 3, dim > > shape_third_derivatives
const Tensor< 2, dim > & second_derivative(const unsigned int qpoint, const unsigned int shape_nr) const
const Tensor< 1, dim > & derivative(const unsigned int qpoint, const unsigned int shape_nr) const
void initialize_face(const UpdateFlags update_flags, const Quadrature< dim > &quadrature, const unsigned int n_original_q_points)
std::vector< std::vector< Tensor< 1, dim > > > unit_tangentials
std::vector< double > shape_values