BEM++  2.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Groups Pages
default_test_kernel_trial_integral.hpp
1 // Copyright (C) 2011-2012 by the BEM++ Authors
2 //
3 // Permission is hereby granted, free of charge, to any person obtaining a copy
4 // of this software and associated documentation files (the "Software"), to deal
5 // in the Software without restriction, including without limitation the rights
6 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7 // copies of the Software, and to permit persons to whom the Software is
8 // furnished to do so, subject to the following conditions:
9 //
10 // The above copyright notice and this permission notice shall be included in
11 // all copies or substantial portions of the Software.
12 //
13 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19 // THE SOFTWARE.
20 
21 #ifndef fiber_default_test_kernel_trial_integral_hpp
22 #define fiber_default_test_kernel_trial_integral_hpp
23 
24 #include "test_kernel_trial_integral.hpp"
25 
26 namespace Fiber
27 {
28 
97 template <typename IntegrandFunctor>
98 class DefaultTestKernelTrialIntegral :
99  public TestKernelTrialIntegral<
100  typename IntegrandFunctor::BasisFunctionType,
101  typename IntegrandFunctor::KernelType,
102  typename IntegrandFunctor::ResultType>
103 {
104  typedef TestKernelTrialIntegral<
105  typename IntegrandFunctor::BasisFunctionType,
106  typename IntegrandFunctor::KernelType,
107  typename IntegrandFunctor::ResultType>
108  Base;
109 public:
110  typedef typename Base::CoordinateType CoordinateType;
111  typedef typename Base::BasisFunctionType BasisFunctionType;
112  typedef typename Base::KernelType KernelType;
113  typedef typename Base::ResultType ResultType;
114 
115  explicit DefaultTestKernelTrialIntegral(const IntegrandFunctor& functor) :
116  m_functor(functor)
117  {}
118 
119  virtual void addGeometricalDependencies(
120  size_t& testGeomDeps, size_t& trialGeomDeps) const;
121 
122  virtual void evaluateWithTensorQuadratureRule(
123  const GeometricalData<CoordinateType>& testGeomData,
124  const GeometricalData<CoordinateType>& trialGeomData,
125  const CollectionOf3dArrays<BasisFunctionType>& testValues,
126  const CollectionOf3dArrays<BasisFunctionType>& trialValues,
127  const CollectionOf4dArrays<KernelType>& kernelValues,
128  const std::vector<CoordinateType>& testQuadWeights,
129  const std::vector<CoordinateType>& trialQuadWeights,
130  arma::Mat<ResultType>& result) const;
131 
132  virtual void evaluateWithNontensorQuadratureRule(
133  const GeometricalData<CoordinateType>& testGeomData,
134  const GeometricalData<CoordinateType>& trialGeomData,
135  const CollectionOf3dArrays<BasisFunctionType>& testValues,
136  const CollectionOf3dArrays<BasisFunctionType>& trialValues,
137  const CollectionOf3dArrays<KernelType>& kernelValues,
138  const std::vector<CoordinateType>& quadWeights,
139  arma::Mat<ResultType>& result) const;
140 
141 private:
142  IntegrandFunctor m_functor;
143 };
144 
145 } // namespace Fiber
146 
147 #include "default_test_kernel_trial_integral_imp.hpp"
148 
149 #endif