33#include <boost/container/small_vector.hpp>
42template <
int dim,
typename VectorType,
int spacedim>
53template <
int dim,
typename VectorType,
int spacedim>
54boost::container::small_vector<Point<spacedim>,
64 boost::container::small_vector<Point<spacedim>,
105 for (
unsigned int j = 0; j < spacedim; ++j)
106 shift_vector[j] = mapping_values(i * spacedim + j);
110 vertices[i] = cell->
vertex(i) + shift_vector;
117template <
int dim,
typename VectorType,
int spacedim>
118std::vector<Point<spacedim>>
133template <
int dim,
typename VectorType,
int spacedim>
134std::unique_ptr<Mapping<dim, spacedim>>
137 return std::make_unique<MappingQ1Eulerian<dim, VectorType, spacedim>>(*this);
142template <
int dim,
typename VectorType,
int spacedim>
169#include "fe/mapping_q1_eulerian.inst"
ObserverPointer< const DoFHandler< dim, spacedim >, MappingQ1Eulerian< dim, VectorType, spacedim > > shiftmap_dof_handler
virtual std::vector< Point< spacedim > > compute_mapping_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const override
ObserverPointer< const VectorType, MappingQ1Eulerian< dim, VectorType, spacedim > > euler_transform_vectors
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::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
MappingQ1Eulerian(const DoFHandler< dim, spacedim > &euler_dof_handler, const VectorType &euler_vector)
virtual boost::container::small_vector< Point< spacedim >, ReferenceCells::max_n_vertices< dim >() > get_vertices(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override
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::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
MappingQ(const unsigned int polynomial_degree)
unsigned int n_vertices() const
Point< spacedim > & vertex(const unsigned int i) const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define Assert(cond, exc)
#define AssertDimension(dim1, dim2)
static ::ExceptionBase & ExcInactiveCell()
typename ActiveSelector::cell_iterator cell_iterator
TriaIterator< CellAccessor< dim, spacedim > > cell_iterator
constexpr unsigned int max_n_vertices()
static constexpr unsigned int vertices_per_cell
static std_cxx20::ranges::iota_view< unsigned int, unsigned int > vertex_indices()