107 template <
class InputVector,
int spacedim>
110 const InputVector &solution,
111 const unsigned int component);
137 template <
class InputVector,
int spacedim>
141 const InputVector &solution,
142 const unsigned int component)
146 std::vector<typename InputVector::value_type> values(1);
152 std::vector<Vector<typename InputVector::value_type>> values(
157 return values[0](component);
168 for (
unsigned int i = 0; i < dim; ++i)
218 template <
class InputVector,
int spacedim>
221 const InputVector &solution,
222 const unsigned int component);
252 template <
class InputVector,
int spacedim>
256 const InputVector &solution,
257 const unsigned int component)
261 std::vector<Tensor<1, dim, typename InputVector::value_type>> values(
269 std::vector<Tensor<1, dim, typename InputVector::value_type>>>
285 return std::fabs(d[0][0]);
302 const double radicand =
303 ::sqr(d[0][0] - d[1][1]) + 4 * ::sqr(d[0][1]);
305 0.5 * (d[0][0] + d[1][1] +
std::sqrt(radicand)),
306 0.5 * (d[0][0] + d[1][1] -
std::sqrt(radicand))};
426 const double am =
trace(d) / 3.;
430 for (
unsigned int i = 0; i < 3; ++i)
433 const double ss01 = s[0][1] * s[0][1], ss12 = s[1][2] * s[1][2],
434 ss02 = s[0][2] * s[0][2];
436 const double J2 = (s[0][0] * s[0][0] + s[1][1] * s[1][1] +
437 s[2][2] * s[2][2] + 2 * (ss01 + ss02 + ss12)) /
443 3. * s[1][1] * (ss01 + ss12) + 3. * s[2][2] * (ss02 + ss12) +
444 6. * s[0][1] * s[0][2] * s[1][2]) /
447 const double R =
std::sqrt(4. * J2 / 3.);
449 double EE[3] = {0, 0, 0};
456 if (R <= 1e-14 * std::fabs(am))
457 EE[0] = EE[1] = EE[2] = am;
462 const double R3 = R * R * R;
463 const double XX = 4. * J3 / R3;
464 const double YY = 1. - std::fabs(XX);
471 const double a = (XX > 0 ? -1. : 1.) * R / 2;
472 EE[0] = EE[1] = am + a;
484 return std::max({std::fabs(EE[0]), std::fabs(EE[1]), std::fabs(EE[2])});
517 for (
unsigned int i = 0; i < dim; ++i)
518 for (
unsigned int j = i + 1; j < dim; ++j)
520 const double s = (d[i][j] + d[j][i]) / 2;
521 d[i][j] = d[j][i] = s;
556 template <
class InputVector,
int spacedim>
559 const InputVector &solution,
560 const unsigned int component);
590 template <
class InputVector,
int spacedim>
594 const InputVector &solution,
595 const unsigned int component)
599 std::vector<Tensor<2, dim, typename InputVector::value_type>> values(
607 std::vector<Tensor<2, dim, typename InputVector::value_type>>>
623 return std::fabs(d[0][0][0]);
647 for (
unsigned int i = 0; i < dim; ++i)
648 for (
unsigned int j = i + 1; j < dim; ++j)
649 for (
unsigned int k = j + 1; k < dim; ++k)
651 const double s = (d[i][j][k] + d[i][k][j] + d[j][i][k] +
652 d[j][k][i] + d[k][i][j] + d[k][j][i]) /
654 d[i][j][k] = d[i][k][j] = d[j][i][k] = d[j][k][i] = d[k][i][j] =
659 for (
unsigned int i = 0; i < dim; ++i)
660 for (
unsigned int j = i + 1; j < dim; ++j)
664 const double s = (d[i][i][j] + d[i][j][i] + d[j][i][i]) / 3;
665 d[i][i][j] = d[i][j][i] = d[j][i][i] = s;
669 const double t = (d[i][j][j] + d[j][i][j] + d[j][j][i]) / 3;
670 d[i][j][j] = d[j][i][j] = d[j][j][i] = t;
675 template <
int order,
int dim>
740 template <
class DerivativeDescription,
748 const InputVector &solution,
749 const unsigned int component,
751 typename DerivativeDescription::Derivative &derivative)
781 std::vector<typename DoFHandler<dim, spacedim>::active_cell_iterator>
791 typename DerivativeDescription::Derivative projected_derivative;
794 x_fe_midpoint_value.
reinit(cell);
800 const typename DerivativeDescription::ProjectedDerivative
801 this_midpoint_value =
802 DerivativeDescription::get_projected_derivative(fe_midpoint_value,
825 cell, active_neighbors);
830 auto neighbor_ptr = active_neighbors.begin();
831 for (; neighbor_ptr != active_neighbors.end(); ++neighbor_ptr)
833 const auto &neighbor = *neighbor_ptr;
836 x_fe_midpoint_value.
reinit(neighbor);
842 const typename DerivativeDescription::ProjectedDerivative
843 neighbor_midpoint_value =
844 DerivativeDescription::get_projected_derivative(
845 neighbor_fe_midpoint_value, solution, component);
859 const double distance = y.
norm();
873 for (
unsigned int i = 0; i < dim; ++i)
874 for (
unsigned int j = 0; j < dim; ++j)
875 Y[i][j] += y[i] * y[j];
880 typename DerivativeDescription::ProjectedDerivative
881 projected_finite_difference =
882 (neighbor_midpoint_value - this_midpoint_value);
883 projected_finite_difference /= distance;
885 projected_derivative +=
outer_product(y, projected_finite_difference);
902 derivative = Y_inverse * projected_derivative;
905 DerivativeDescription::symmetrize(derivative);
915 template <
class DerivativeDescription,
926 const InputVector &solution,
927 const unsigned int component)
930 if (std::get<0>(*cell)->is_locally_owned() ==
false)
931 *std::get<1>(*cell) = 0;
934 typename DerivativeDescription::Derivative derivative;
947 *std::get<1>(*cell) =
948 DerivativeDescription::derivative_norm(derivative);
963 template <
class DerivativeDescription,
970 const InputVector &solution,
971 const unsigned int component,
982 std::tuple<typename DoFHandler<dim, spacedim>::active_cell_iterator,
994 [&
mapping, &dof_handler, &solution, component](
999 cell,
mapping, dof_handler, solution, component);
1001 std::function<void(const internal::Assembler::CopyData &)>(),
1015 template <
int dim,
class InputVector,
int spacedim>
1019 const InputVector &solution,
1021 const unsigned int component)
1028 template <
int dim,
class InputVector,
int spacedim>
1031 const InputVector &solution,
1033 const unsigned int component)
1037 const auto reference_cell =
1048 template <
int dim,
class InputVector,
int spacedim>
1052 const InputVector &solution,
1054 const unsigned int component)
1061 template <
int dim,
class InputVector,
int spacedim>
1064 const InputVector &solution,
1066 const unsigned int component)
1070 const auto reference_cell =
1081 template <
int dim,
int spacedim,
class InputVector,
int order>
1086 const InputVector &solution,
1094 const unsigned int component)
1098 mapping, dof, solution, component, cell, derivative);
1103 template <
int dim,
int spacedim,
class InputVector,
int order>
1107 const InputVector &solution,
1115 const unsigned int component)
1119 cell->reference_cell()
1130 template <
int dim,
int order>
1142#include "numerics/derivative_approximation.inst"
Gradient< dim > DerivDescr
SecondDerivative< dim > DerivDescr
ThirdDerivative< dim > DerivDescr
static ProjectedDerivative get_projected_derivative(const FEValues< dim, spacedim > &fe_values, const InputVector &solution, const unsigned int component)
static const UpdateFlags update_flags
static void symmetrize(Derivative &derivative_tensor)
static double derivative_norm(const Derivative &d)
Tensor< 0, dim > ProjectedDerivative
Tensor< 1, dim > Derivative
Tensor< 2, dim > Derivative
static const UpdateFlags update_flags
static ProjectedDerivative get_projected_derivative(const FEValues< dim, spacedim > &fe_values, const InputVector &solution, const unsigned int component)
Tensor< 1, dim > ProjectedDerivative
static double derivative_norm(const Derivative &d)
static void symmetrize(Derivative &derivative_tensor)
static ProjectedDerivative get_projected_derivative(const FEValues< dim, spacedim > &fe_values, const InputVector &solution, const unsigned int component)
static double derivative_norm(const Derivative &d)
Tensor< 3, dim > Derivative
static const UpdateFlags update_flags
Tensor< 2, dim > ProjectedDerivative
static void symmetrize(Derivative &derivative_tensor)
cell_iterator end() const
const hp::FECollection< dim, spacedim > & get_fe_collection() const
const FiniteElement< dim, spacedim > & get_fe(const types::fe_index index=0) const
const Triangulation< dim, spacedim > & get_triangulation() const
active_cell_iterator begin_active(const unsigned int level=0) const
void get_function_values(const ReadVector< Number > &fe_function, std::vector< Number > &values) const
void get_function_hessians(const ReadVector< Number > &fe_function, std::vector< Tensor< 2, spacedim, Number > > &hessians) const
const Point< spacedim > & quadrature_point(const unsigned int q_point) const
void get_function_gradients(const ReadVector< Number > &fe_function, std::vector< Tensor< 1, spacedim, Number > > &gradients) const
const FiniteElement< dim, spacedim > & get_fe() const
unsigned int n_components() const
Abstract base class for mapping classes.
numbers::NumberTraits< Number >::real_type norm() const
unsigned int n_active_cells() const
const std::vector< ReferenceCell > & get_reference_cells() const
bool is_mixed_mesh() const
const FEValuesType & get_present_fe_values() const
void reinit(const TriaIterator< DoFCellAccessor< dim, spacedim, lda > > &cell, const unsigned int q_index=numbers::invalid_unsigned_int, const unsigned int mapping_index=numbers::invalid_unsigned_int, const unsigned int fe_index=numbers::invalid_unsigned_int)
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_NOT_IMPLEMENTED()
static ::ExceptionBase & ExcInsufficientDirections()
static ::ExceptionBase & ExcNotImplemented()
#define Assert(cond, exc)
static ::ExceptionBase & ExcVectorLengthVsNActiveCells(int arg1, int arg2)
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcInternalError()
#define AssertThrow(cond, exc)
typename ActiveSelector::active_cell_iterator active_cell_iterator
@ update_hessians
Second derivatives of shape functions.
@ update_values
Shape function values.
@ update_gradients
Shape function gradients.
@ update_quadrature_points
Transformed quadrature points.
const Mapping< dim, spacedim > & get_default_linear_mapping(const Triangulation< dim, spacedim > &triangulation)
MappingQ< dim, spacedim > StaticMappingQ1< dim, spacedim >::mapping
void approximate_derivative(const Mapping< dim, spacedim > &mapping, const DoFHandler< dim, spacedim > &dof_handler, const InputVector &solution, const unsigned int component, Vector< float > &derivative_norm)
void approximate(const SynchronousIterators< std::tuple< typename DoFHandler< dim, spacedim >::active_cell_iterator, Vector< float >::iterator > > &cell, const Mapping< dim, spacedim > &mapping, const DoFHandler< dim, spacedim > &dof_handler, const InputVector &solution, const unsigned int component)
void approximate_cell(const Mapping< dim, spacedim > &mapping, const DoFHandler< dim, spacedim > &dof_handler, const InputVector &solution, const unsigned int component, const typename DoFHandler< dim, spacedim >::active_cell_iterator &cell, typename DerivativeDescription::Derivative &derivative)
void approximate_gradient(const Mapping< dim, spacedim > &mapping, const DoFHandler< dim, spacedim > &dof, const InputVector &solution, Vector< float > &derivative_norm, const unsigned int component=0)
double derivative_norm(const Tensor< order, dim > &derivative)
void approximate_derivative_tensor(const Mapping< dim, spacedim > &mapping, const DoFHandler< dim, spacedim > &dof, const InputVector &solution, const typename DoFHandler< dim, spacedim >::active_cell_iterator &cell, Tensor< order, dim > &derivative, const unsigned int component=0)
void approximate_second_derivative(const Mapping< dim, spacedim > &mapping, const DoFHandler< dim, spacedim > &dof, const InputVector &solution, Vector< float > &derivative_norm, const unsigned int component=0)
constexpr T fixed_power(const T t)
void run(const std::vector< std::vector< Iterator > > &colored_iterators, Worker worker, Copier copier, const ScratchData &sample_scratch_data, const CopyData &sample_copy_data, const unsigned int queue_length=2 *MultithreadInfo::n_threads(), const unsigned int chunk_size=8)
::VectorizedArray< Number, width > max(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > cos(const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > sqrt(const ::VectorizedArray< Number, width > &)
inline ::VectorizedArray< Number, width > acos(const ::VectorizedArray< Number, width > &x)
static constexpr unsigned int max_children_per_face
static constexpr unsigned int faces_per_cell
DEAL_II_HOST constexpr Number determinant(const SymmetricTensor< 2, dim, Number > &)
DEAL_II_HOST constexpr SymmetricTensor< 2, dim, Number > invert(const SymmetricTensor< 2, dim, Number > &)
std::array< Number, 1 > eigenvalues(const SymmetricTensor< 2, 1, Number > &T)
DEAL_II_HOST constexpr SymmetricTensor< 4, dim, Number > outer_product(const SymmetricTensor< 2, dim, Number > &t1, const SymmetricTensor< 2, dim, Number > &t2)
DEAL_II_HOST constexpr Number trace(const SymmetricTensor< 2, dim2, Number > &)