Reference documentation for deal.II version 9.1.0-pre
tensor_function.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 1999 - 2017 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 #ifndef dealii_tensor_function_h
17 #define dealii_tensor_function_h
18 
19 
20 #include <deal.II/base/config.h>
21 
22 #include <deal.II/base/exceptions.h>
23 #include <deal.II/base/function.h>
24 #include <deal.II/base/function_time.h>
25 #include <deal.II/base/point.h>
26 #include <deal.II/base/smartpointer.h>
27 #include <deal.II/base/subscriptor.h>
28 
29 #include <vector>
30 
31 DEAL_II_NAMESPACE_OPEN
32 
56 template <int rank, int dim, typename Number = double>
57 class TensorFunction : public FunctionTime<Number>, public Subscriptor
58 {
59 public:
64 
66 
71  TensorFunction(const Number initial_time = Number(0.0));
72 
78  virtual ~TensorFunction() override = default;
79 
83  virtual value_type
84  value(const Point<dim> &p) const;
85 
91  virtual void
92  value_list(const std::vector<Point<dim>> &points,
93  std::vector<value_type> & values) const;
94 
98  virtual gradient_type
99  gradient(const Point<dim> &p) const;
100 
106  virtual void
107  gradient_list(const std::vector<Point<dim>> &points,
108  std::vector<gradient_type> & gradients) const;
109 };
110 
111 
112 
120 template <int rank, int dim, typename Number = double>
121 class ConstantTensorFunction : public TensorFunction<rank, dim, Number>
122 {
123 public:
131  ConstantTensorFunction(const ::Tensor<rank, dim, Number> &value,
132  const Number initial_time = 0.0);
133 
134  virtual ~ConstantTensorFunction() override = default;
135 
136  virtual typename ::TensorFunction<rank, dim, Number>::value_type
137  value(const Point<dim> &p) const override;
138 
139  virtual void
140  value_list(
141  const std::vector<Point<dim>> &points,
142  std::vector<typename ::TensorFunction<rank, dim, Number>::value_type>
143  &values) const override;
144 
145  virtual typename ::TensorFunction<rank, dim, Number>::gradient_type
146  gradient(const Point<dim> &p) const override;
147 
148  virtual void
150  const std::vector<Point<dim>> &points,
151  std::vector<
152  typename ::TensorFunction<rank, dim, Number>::gradient_type>
153  &gradients) const override;
154 
155 private:
156  const ::Tensor<rank, dim, Number> _value;
157 };
158 
159 
160 
168 template <int rank, int dim, typename Number = double>
169 class ZeroTensorFunction : public ConstantTensorFunction<rank, dim, Number>
170 {
171 public:
178  ZeroTensorFunction(const Number initial_time = 0.0);
179 };
180 
181 
182 DEAL_II_NAMESPACE_CLOSE
183 
184 #endif
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< value_type > &values) const
TensorFunction(const Number initial_time=Number(0.0))
virtual gradient_type gradient(const Point< dim > &p) const
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
virtual ~TensorFunction() override=default
Definition: mpi.h:55