Dune Core Modules (2.9.0)

differentiablefunction_imp.hh
1// -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2// vi: set et ts=4 sw=2 sts=2:
3#ifndef DUNE_FUNCTIONS_COMMON_DIFFERENTIABLE_FUNCTION_IMP_HH
4#define DUNE_FUNCTIONS_COMMON_DIFFERENTIABLE_FUNCTION_IMP_HH
5
8
9#include <dune/functions/common/type_traits.hh>
10
11
12namespace Dune {
13namespace Functions {
14namespace Imp {
15
19struct HasFreeDerivative
20{
21 template<class F>
22 auto require(F&& f) -> decltype(
23 derivative(f)
24 );
25};
26
27
28
29template<class Dummy, class F,
30 typename std::enable_if<
31 models< HasFreeDerivative, F>() , int>::type = 0>
32auto derivativeIfImplemented(const F& f) -> decltype(derivative(f))
33{
34 return derivative(f);
35}
36
37
38
39template<class Dummy, class F,
40 typename std::enable_if<
41 not(models< HasFreeDerivative, F>()) , int>::type = 0>
42Dummy derivativeIfImplemented(const F& f)
43{
44 DUNE_THROW(Dune::NotImplemented, "Derivative not implemented");
45}
46
47
48
49template<class Signature, class DerivativeInterface>
50class DifferentiableFunctionWrapperInterface
51{};
52
53// Interface of type erasure wrapper
54//
55// Notice that the basic interface of polymorphic classes (destructor, clone, ...)
56// will be added by the type erasure foundation classes.
57template<class Range, class Domain, class DerivativeInterface>
58class DifferentiableFunctionWrapperInterface<Range(Domain), DerivativeInterface>
59{
60public:
61 virtual Range operator() (const Domain& x) const = 0;
62
63 virtual DerivativeInterface derivative() const = 0;
64};
65
66
67
68template<class Signature, class DerivativeInterface, class B>
69class DifferentiableFunctionWrapperImplementation
70{};
71
72// Implementation of type erasure wrapper
73template<class Range, class Domain, class DerivativeInterface, class B>
74class DifferentiableFunctionWrapperImplementation< Range(Domain), DerivativeInterface, B> :
75 public B
76{
77public:
78
79 using B::B;
80 using Wrapped = typename B::Wrapped;
81
82 virtual Range operator() (const Domain& x) const
83 {
84 return this->get()(x);
85 }
86
87 virtual DerivativeInterface derivative() const
88 {
89 return derivativeIfImplemented<DerivativeInterface, Wrapped>(this->get());
90 }
91};
92
93
94
95}}} // namespace Dune::Functions::Imp
96
97
98
99#endif // DUNE_FUNCTIONS_COMMON_DIFFERENTIABLE_FUNCTION_IMP_HH
Default exception for dummy implementations.
Definition: exceptions.hh:263
Infrastructure for concepts.
A few common exception classes.
#define DUNE_THROW(E, m)
Definition: exceptions.hh:218
TrigonometricFunction< K, -cosFactor, sinFactor > derivative(const TrigonometricFunction< K, sinFactor, cosFactor > &f)
Obtain derivative of TrigonometricFunction function.
Definition: trigonometricfunction.hh:39
Dune namespace.
Definition: alignedallocator.hh:13
Creative Commons License   |  Legal Statements / Impressum  |  Hosted by TU Dresden  |  generated with Hugo v0.111.3 (Dec 21, 23:30, 2024)