16 #ifndef dealii__fe_poly_tensor_h 17 #define dealii__fe_poly_tensor_h 20 #include <deal.II/lac/full_matrix.h> 21 #include <deal.II/fe/fe.h> 22 #include <deal.II/base/derivative_form.h> 23 #include <deal.II/base/quadrature.h> 25 DEAL_II_NAMESPACE_OPEN
115 template <
class PolynomialType,
int dim,
int spacedim=dim>
147 const unsigned int component)
const;
161 const unsigned int component)
const;
175 const unsigned int component)
const;
196 InternalData *data =
new InternalData;
199 const unsigned int n_q_points = quadrature.
size();
202 std::vector<Tensor<1,dim> > values(0);
203 std::vector<Tensor<2,dim> > grads(0);
204 std::vector<Tensor<3,dim> > grad_grads(0);
205 std::vector<Tensor<4,dim> > third_derivatives(0);
206 std::vector<Tensor<5,dim> > fourth_derivatives(0);
219 data->transformed_shape_values.resize (n_q_points);
226 data->transformed_shape_grads.resize (n_q_points);
235 data->untransformed_shape_grads.resize(n_q_points);
241 data->shape_grad_grads.reinit (this->
dofs_per_cell, n_q_points);
242 data->transformed_shape_hessians.resize (n_q_points);
244 data->untransformed_shape_hessian_tensors.resize(n_q_points);
254 if (update_flags & (update_values | update_gradients))
255 for (
unsigned int k=0; k<n_q_points; ++k)
258 values, grads, grad_grads,
262 if (update_flags & update_values)
266 data->shape_values[i][k] = values[i];
273 data->shape_values[i][k] = add_values;
277 if (update_flags & update_gradients)
281 data->shape_grads[i][k] = grads[i];
288 data->shape_grads[i][k] = add_grads;
292 if (update_flags & update_hessians)
296 data->shape_grad_grads[i][k] = grad_grads[i];
303 data->shape_grad_grads[i][k] = add_grad_grads;
314 const CellSimilarity::Similarity cell_similarity,
318 const ::internal::FEValues::MappingRelatedData<dim, spacedim> &mapping_data,
325 const unsigned int face_no,
329 const ::internal::FEValues::MappingRelatedData<dim, spacedim> &mapping_data,
336 const unsigned int face_no,
337 const unsigned int sub_no,
341 const ::internal::FEValues::MappingRelatedData<dim, spacedim> &mapping_data,
381 mutable std::vector<Tensor<1, spacedim> > transformed_shape_values;
383 mutable std::vector<Tensor<2, spacedim > > transformed_shape_grads;
384 mutable std::vector<Tensor<2, dim > > untransformed_shape_grads;
386 mutable std::vector<Tensor<3, spacedim > > transformed_shape_hessians;
387 mutable std::vector<Tensor<3, dim > > untransformed_shape_hessian_tensors;
435 DEAL_II_NAMESPACE_CLOSE
std::vector< Tensor< 2, dim > > cached_grads
Point< dim > cached_point
virtual Tensor< 1, dim > shape_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const
virtual Tensor< 1, dim > shape_grad(const unsigned int i, const Point< dim > &p) const
const unsigned int degree
FE_PolyTensor(const unsigned int degree, const FiniteElementData< dim > &fe_data, const std::vector< bool > &restriction_is_additive_flags, const std::vector< ComponentMask > &nonzero_components)
const Point< dim > & point(const unsigned int i) const
virtual FiniteElement< dim, spacedim >::InternalDataBase * get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &, const Quadrature< dim > &quadrature, ::internal::FEValues::FiniteElementRelatedData< dim, spacedim > &) const
virtual Tensor< 2, dim > shape_grad_grad_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const
virtual double shape_value(const unsigned int i, const Point< dim > &p) const
PolynomialType poly_space
Table< 2, Tensor< 1, dim > > shape_values
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const
Abstract base class for mapping classes.
Table< 2, DerivativeForm< 2, dim, spacedim > > shape_grad_grads
std::vector< double > sign_change
Second derivatives of shape functions.
unsigned int size() const
const unsigned int dofs_per_cell
std::vector< Tensor< 1, dim > > cached_values
virtual Tensor< 2, dim > shape_grad_grad(const unsigned int i, const Point< dim > &p) const
std::vector< Tensor< 3, dim > > cached_grad_grads
Shape function gradients.
const std::vector< ComponentMask > nonzero_components
virtual double shape_value_component(const unsigned int i, const Point< dim > &p, const unsigned int component) const
FullMatrix< double > inverse_node_matrix
Table< 2, DerivativeForm< 1, dim, spacedim > > shape_grads
const std::vector< bool > restriction_is_additive_flags