16 #ifndef dealii_tensor_function_h 17 #define dealii_tensor_function_h 56 template <
int rank,
int dim,
typename Number =
double>
58 :
public FunctionTime<typename numbers::NumberTraits<Number>::real_type>,
104 std::vector<value_type> & values)
const;
119 std::vector<gradient_type> & gradients)
const;
131 template <
int rank,
int dim,
typename Number =
double>
152 virtual typename ::TensorFunction<rank, dim, Number>::value_type
158 std::vector<typename ::TensorFunction<rank, dim, Number>::value_type>
159 &values)
const override;
161 virtual typename ::TensorFunction<rank, dim, Number>::gradient_type
168 typename ::TensorFunction<rank, dim, Number>::gradient_type>
169 &gradients)
const override;
172 const ::Tensor<rank, dim, Number>
_value;
184 template <
int rank,
int dim,
typename Number =
double>
virtual void gradient_list(const std::vector< Point< dim >> &points, std::vector< gradient_type > &gradients) const
virtual value_type value(const Point< dim > &p) const
typename FunctionTime< typename numbers::NumberTraits< Number >::real_type >::time_type time_type
#define DEAL_II_NAMESPACE_CLOSE
typename TensorFunction< rank, dim, Number >::time_type time_type
TensorFunction(const time_type initial_time=time_type(0.0))
virtual ~TensorFunction() override=default
virtual gradient_type gradient(const Point< dim > &p) const
numbers::NumberTraits< RangeNumberType >::real_type time_type
#define DEAL_II_NAMESPACE_OPEN
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< value_type > &values) const
const ::Tensor< rank, dim, Number > _value