41 template <
int dim,
int spacedim>
43 : use_mapping_q1_on_current_cell(false)
48 template <
int dim,
int spacedim>
61 template <
int dim,
int spacedim>
72 use_mapping_q_on_all_cells(degree == 1 || use_mapping_q_on_all_cells ||
89 template <
int dim,
int spacedim>
96 std::shared_ptr<const Mapping<dim, spacedim>> other_q1_map =
110 std::shared_ptr<const Mapping<dim, spacedim>> other_qp_map =
121 template <
int dim,
int spacedim>
130 template <
int dim,
int spacedim>
139 template <
int dim,
int spacedim>
143 return (
q1_mapping->requires_update_flags(in) |
149 template <
int dim,
int spacedim>
150 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
154 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase> data_ptr =
155 std_cxx14::make_unique<InternalData>();
160 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>>
169 std::move(
q1_mapping->get_data(update_flags, quadrature)));
173 typename MappingQGeneric<dim, spacedim>::InternalData>(
174 std::move(do_get_data.return_value()));
180 template <
int dim,
int spacedim>
181 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
186 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase> data_ptr =
187 std_cxx14::make_unique<InternalData>();
192 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>>
202 std::move(
q1_mapping->get_face_data(update_flags, quadrature)));
206 typename MappingQGeneric<dim, spacedim>::InternalData>(
207 std::move(do_get_data.return_value()));
213 template <
int dim,
int spacedim>
214 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
219 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase> data_ptr =
220 std_cxx14::make_unique<InternalData>();
225 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>>
235 std::move(
q1_mapping->get_subface_data(update_flags, quadrature)));
239 typename MappingQGeneric<dim, spacedim>::InternalData>(
240 std::move(do_get_data.return_value()));
247 template <
int dim,
int spacedim>
259 Assert(dynamic_cast<const InternalData *>(&internal_data) !=
nullptr,
285 updated_cell_similarity,
291 updated_cell_similarity,
296 return updated_cell_similarity;
301 template <
int dim,
int spacedim>
305 const unsigned int face_no,
313 Assert(dynamic_cast<const InternalData *>(&internal_data) !=
nullptr,
337 template <
int dim,
int spacedim>
341 const unsigned int face_no,
342 const unsigned int subface_no,
350 Assert(dynamic_cast<const InternalData *>(&internal_data) !=
nullptr,
383 template <
int dim,
int spacedim>
397 if (data->use_mapping_q1_on_current_cell)
398 q1_mapping->transform(input, mapping_kind, *data->mapping_q1_data, output);
401 qp_mapping->transform(input, mapping_kind, *data->mapping_qp_data, output);
406 template <
int dim,
int spacedim>
416 &mapping_data) !=
nullptr),
430 template <
int dim,
int spacedim>
440 &mapping_data) !=
nullptr),
454 template <
int dim,
int spacedim>
464 &mapping_data) !=
nullptr),
478 template <
int dim,
int spacedim>
488 &mapping_data) !=
nullptr),
502 template <
int dim,
int spacedim>
512 return qp_mapping->transform_unit_to_real_cell(cell, p);
514 return q1_mapping->transform_unit_to_real_cell(cell, p);
519 template <
int dim,
int spacedim>
527 return qp_mapping->transform_real_to_unit_cell(cell, p);
529 return q1_mapping->transform_real_to_unit_cell(cell, p);
534 template <
int dim,
int spacedim>
535 std::unique_ptr<Mapping<dim, spacedim>>
538 return std_cxx14::make_unique<MappingQ<dim, spacedim>>(
545 #include "mapping_q.inst" unsigned int get_degree() const
virtual std::size_t memory_consumption() const override
#define AssertDimension(dim1, dim2)
std::shared_ptr< const MappingQGeneric< dim, spacedim > > qp_mapping
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags, const Quadrature< dim > &quadrature) const override
Task< RT > new_task(const std::function< RT()> &function)
bool use_mapping_q1_on_current_cell
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags flags, const Quadrature< dim - 1 > &quadrature) const override
virtual void transform(const ArrayView< const Tensor< 1, dim >> &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 1, spacedim >> &output) const override
const bool use_mapping_q_on_all_cells
std::unique_ptr< To > dynamic_unique_cast(std::unique_ptr< From > &&p)
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::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
#define Assert(cond, exc)
Abstract base class for mapping classes.
#define DEAL_II_NAMESPACE_CLOSE
const unsigned int polynomial_degree
std::unique_ptr< typename MappingQGeneric< dim, spacedim >::InternalData > mapping_qp_data
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags flags, const Quadrature< dim - 1 > &quadrature) const override
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const override
#define DEAL_II_NAMESPACE_OPEN
virtual bool preserves_vertex_locations() const override
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() 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
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::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const override
std::unique_ptr< typename MappingQGeneric< dim, spacedim >::InternalData > mapping_q1_data
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
MappingQ(const unsigned int polynomial_degree, const bool use_mapping_q_on_all_cells=false)
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const override
std::enable_if< std::is_fundamental< T >::value, std::size_t >::type memory_consumption(const T &t)
static ::ExceptionBase & ExcInternalError()
std::shared_ptr< const MappingQGeneric< dim, spacedim > > q1_mapping