16 #ifndef dealii_function_h 17 #define dealii_function_h 36 template <
typename number>
38 template <
int rank,
int dim,
typename Number>
150 template <
int dim,
typename RangeNumberType =
double>
152 typename numbers::NumberTraits<RangeNumberType>::real_type>,
178 Function(
const unsigned int n_components = 1,
224 virtual RangeNumberType
248 std::vector<RangeNumberType> & values,
249 const unsigned int component = 0)
const;
275 std::vector<std::vector<RangeNumberType>> &values)
const;
301 const unsigned int component = 0)
const;
333 virtual RangeNumberType
348 std::vector<RangeNumberType> & values,
349 const unsigned int component = 0)
const;
380 const unsigned int component = 0)
const;
411 template <
int dim,
typename RangeNumberType =
double>
443 virtual RangeNumberType
444 value(
const Point<dim> &p,
const unsigned int component = 0)
const override;
452 std::vector<RangeNumberType> & return_values,
453 const unsigned int component = 0)
const override;
462 const unsigned int component = 0)
const override;
472 const unsigned int component = 0)
const override;
482 const unsigned int component = 0)
const override;
484 virtual RangeNumberType
486 const unsigned int component = 0)
const override;
512 template <
int dim,
typename RangeNumberType =
double>
530 template <
int dim,
typename RangeNumberType =
double>
539 template <
int dim,
typename RangeNumberType =
double>
559 template <
int dim,
typename RangeNumberType =
double>
569 const RangeNumberType
value,
577 const unsigned int n_components);
587 const unsigned int n_components);
604 substitute_function_value_with(
726 template <
int dim,
typename RangeNumberType =
double>
736 const std::function<RangeNumberType(
const Point<dim> &)> &function_object);
742 virtual RangeNumberType
743 value(
const Point<dim> &p,
const unsigned int component = 0)
const override;
750 const std::function<RangeNumberType(const Point<dim> &)> function_object;
794 template <
int dim,
typename RangeNumberType =
double>
796 :
public Function<dim, RangeNumberType>
812 const std::function<RangeNumberType(
const Point<dim> &)> &function_object,
813 const unsigned int selected_component,
820 virtual RangeNumberType
821 value(
const Point<dim> &p,
const unsigned int component = 0)
const override;
837 const std::function<RangeNumberType(const Point<dim> &)> function_object;
884 template <
int dim,
typename RangeNumberType =
double>
897 const double initial_time = 0);
908 const std::vector<std::function<RangeNumberType(
const Point<dim> &)>>
910 const double initial_time = 0.0);
921 const std::vector<std::function<RangeNumberType(
const Point<dim> &)>>
926 const double initial_time = 0.0);
935 virtual RangeNumberType
936 value(
const Point<dim> &p,
const unsigned int component = 0)
const override;
946 const unsigned int component = 0)
const override;
955 const std::vector<std::function<RangeNumberType(
const Point<dim> &)>>
964 set_function_gradients(
973 std::vector<std::function<RangeNumberType(const Point<dim> &)>>
980 std::function<Tensor<1, dim, RangeNumberType>(
const Point<dim> &)>>
1021 template <
int dim,
typename RangeNumberType =
double>
1043 const unsigned int selected_component = 0,
1055 virtual RangeNumberType
1056 value(
const Point<dim> &p,
const unsigned int component = 0)
const override;
1102 template <
int dim,
typename RangeNumberType>
Function(const unsigned int n_components=1, const time_type initial_time=0.0)
const unsigned int n_components
virtual void vector_hessian_list(const std::vector< Point< dim >> &points, std::vector< std::vector< SymmetricTensor< 2, dim, RangeNumberType >>> &values) const
virtual void vector_gradient_list(const std::vector< Point< dim >> &points, std::vector< std::vector< Tensor< 1, dim, RangeNumberType >>> &gradients) const
static const unsigned int dimension
virtual void vector_laplacian(const Point< dim > &p, Vector< RangeNumberType > &values) const
virtual void vector_hessian(const Point< dim > &p, std::vector< SymmetricTensor< 2, dim, RangeNumberType >> &values) const
virtual void vector_gradients(const std::vector< Point< dim >> &points, std::vector< std::vector< Tensor< 1, dim, RangeNumberType >>> &gradients) const
Function & operator=(const Function &f)
typename FunctionTime< typename numbers::NumberTraits< RangeNumberType >::real_type >::time_type time_type
virtual void vector_value_list(const std::vector< Point< dim >> &points, std::vector< Vector< RangeNumberType >> &values) const
virtual void vector_values(const std::vector< Point< dim >> &points, std::vector< std::vector< RangeNumberType >> &values) const
virtual SymmetricTensor< 2, dim, RangeNumberType > hessian(const Point< dim > &p, const unsigned int component=0) const
#define DEAL_II_NAMESPACE_CLOSE
virtual void vector_value(const Point< dim > &p, Vector< RangeNumberType > &values) const
Point< spacedim > point(const gp_Pnt &p, const double tolerance=1e-10)
virtual void hessian_list(const std::vector< Point< dim >> &points, std::vector< SymmetricTensor< 2, dim, RangeNumberType >> &values, const unsigned int component=0) const
const TensorFunction< 1, dim, RangeNumberType > & tensor_function
virtual void vector_laplacian_list(const std::vector< Point< dim >> &points, std::vector< Vector< RangeNumberType >> &values) const
virtual Tensor< 1, dim, RangeNumberType > gradient(const Point< dim > &p, const unsigned int component=0) const
const std::pair< unsigned int, unsigned int > selected_components
Functions::ZeroFunction< dim, RangeNumberType > ZeroFunction
virtual RangeNumberType laplacian(const Point< dim > &p, const unsigned int component=0) const
#define DEAL_II_NAMESPACE_OPEN
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< RangeNumberType > &values, const unsigned int component=0) const
virtual ~Function() override=0
const unsigned int selected_component
Functions::ConstantFunction< dim, RangeNumberType > ConstantFunction
const unsigned int selected_component
virtual RangeNumberType value(const Point< dim > &p, const unsigned int component=0) const
std::size_t memory_consumption() const
#define DEAL_II_DEPRECATED
virtual void gradient_list(const std::vector< Point< dim >> &points, std::vector< Tensor< 1, dim, RangeNumberType >> &gradients, const unsigned int component=0) const
virtual void vector_gradient(const Point< dim > &p, std::vector< Tensor< 1, dim, RangeNumberType >> &gradients) const
std::vector< RangeNumberType > function_value_vector
virtual void laplacian_list(const std::vector< Point< dim >> &points, std::vector< RangeNumberType > &values, const unsigned int component=0) const