Reference documentation for deal.II version 9.1.0-pre
mapping_q1_eulerian.cc
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2001 - 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 #include <deal.II/base/std_cxx14/memory.h>
17 
18 #include <deal.II/dofs/dof_accessor.h>
19 #include <deal.II/dofs/dof_handler.h>
20 
21 #include <deal.II/fe/fe.h>
22 #include <deal.II/fe/mapping_q1_eulerian.h>
23 
24 #include <deal.II/grid/tria_iterator.h>
25 
26 #include <deal.II/lac/block_vector.h>
27 #include <deal.II/lac/la_parallel_block_vector.h>
28 #include <deal.II/lac/la_parallel_vector.h>
29 #include <deal.II/lac/la_vector.h>
30 #include <deal.II/lac/petsc_block_vector.h>
31 #include <deal.II/lac/petsc_vector.h>
32 #include <deal.II/lac/trilinos_parallel_block_vector.h>
33 #include <deal.II/lac/trilinos_vector.h>
34 #include <deal.II/lac/vector.h>
35 
36 #include <array>
37 
38 DEAL_II_NAMESPACE_OPEN
39 
40 
41 template <int dim, class VectorType, int spacedim>
43  const DoFHandler<dim, spacedim> &shiftmap_dof_handler,
44  const VectorType & euler_transform_vectors)
45  : MappingQGeneric<dim, spacedim>(1)
46  , euler_transform_vectors(&euler_transform_vectors)
47  , shiftmap_dof_handler(&shiftmap_dof_handler)
48 {}
49 
50 
51 
52 template <int dim, class VectorType, int spacedim>
53 std::array<Point<spacedim>, GeometryInfo<dim>::vertices_per_cell>
55  const typename Triangulation<dim, spacedim>::cell_iterator &cell) const
56 {
57  std::array<Point<spacedim>, GeometryInfo<dim>::vertices_per_cell> vertices;
58  // The assertions can not be in the constructor, since this would
59  // require to call dof_handler.distribute_dofs(fe) *before* the mapping
60  // object is constructed, which is not necessarily what we want.
61 
62  // TODO: Only one of these two assertions should be relevant
63  AssertDimension(spacedim, shiftmap_dof_handler->get_fe().n_dofs_per_vertex());
64  AssertDimension(shiftmap_dof_handler->get_fe(0).n_components(), spacedim);
65 
67  euler_transform_vectors->size());
68 
69  // cast the Triangulation<dim>::cell_iterator into a
70  // DoFHandler<dim>::cell_iterator which is necessary for access to
71  // DoFCellAccessor::get_dof_values()
73  *cell, shiftmap_dof_handler);
74 
75  // We require the cell to be active since we can only then get nodal
76  // values for the shifts
77  Assert(dof_cell->active() == true, ExcInactiveCell());
78 
79  // now get the values of the shift vectors at the vertices
80  Vector<double> mapping_values(shiftmap_dof_handler->get_fe().dofs_per_cell);
81  dof_cell->get_dof_values(*euler_transform_vectors, mapping_values);
82 
83  for (unsigned int i = 0; i < GeometryInfo<dim>::vertices_per_cell; ++i)
84  {
85  Point<spacedim> shift_vector;
86 
87  // pick out the value of the shift vector at the present
88  // vertex. since vertex dofs are always numbered first, we can
89  // access them easily
90  for (unsigned int j = 0; j < spacedim; ++j)
91  shift_vector[j] = mapping_values(i * spacedim + j);
92 
93  // compute new support point by old (reference) value and added
94  // shift
95  vertices[i] = cell->vertex(i) + shift_vector;
96  }
97  return vertices;
98 }
99 
100 
101 
102 template <int dim, class VectorType, int spacedim>
103 std::vector<Point<spacedim>>
105  const typename Triangulation<dim, spacedim>::cell_iterator &cell) const
106 {
107  const std::array<Point<spacedim>, GeometryInfo<dim>::vertices_per_cell>
108  vertices = this->get_vertices(cell);
109 
110  std::vector<Point<spacedim>> a(GeometryInfo<dim>::vertices_per_cell);
111  for (unsigned int i = 0; i < GeometryInfo<dim>::vertices_per_cell; ++i)
112  a[i] = vertices[i];
113 
114  return a;
115 }
116 
117 
118 
119 template <int dim, class VectorType, int spacedim>
120 std::unique_ptr<Mapping<dim, spacedim>>
122 {
123  return std_cxx14::make_unique<MappingQ1Eulerian<dim, VectorType, spacedim>>(
124  *this);
125 }
126 
127 
128 
129 template <int dim, class VectorType, int spacedim>
132  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
134  const Quadrature<dim> & quadrature,
135  const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
137  &output_data) const
138 {
139  // call the function of the base class, but ignoring
140  // any potentially detected cell similarity between
141  // the current and the previous cell
143  cell,
145  quadrature,
146  internal_data,
147  output_data);
148  // also return the updated flag since any detected
149  // similarity wasn't based on the mapped field, but
150  // the original vertices which are meaningless
152 }
153 
154 
155 
156 // explicit instantiations
157 #include "mapping_q1_eulerian.inst"
158 
159 
160 DEAL_II_NAMESPACE_CLOSE
MappingQ1Eulerian(const DoFHandler< dim, spacedim > &euler_dof_handler, const VectorType &euler_vector)
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
#define AssertDimension(dim1, dim2)
Definition: exceptions.h:1366
static::ExceptionBase & ExcInactiveCell()
virtual std::vector< Point< spacedim > > compute_mapping_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override
#define Assert(cond, exc)
Definition: exceptions.h:1227
SmartPointer< const DoFHandler< dim, spacedim >, MappingQ1Eulerian< dim, VectorType, spacedim > > shiftmap_dof_handler
SmartPointer< const VectorType, MappingQ1Eulerian< dim, VectorType, spacedim > > euler_transform_vectors
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const override
typename ActiveSelector::cell_iterator cell_iterator
Definition: dof_handler.h:268
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 std::array< Point< spacedim >, GeometryInfo< dim >::vertices_per_cell > get_vertices(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override