Dune Core Modules (2.6.0)

p23dlocalinterpolation.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_P2_3DLOCALINTERPOLATION_HH
4#define DUNE_P2_3DLOCALINTERPOLATION_HH
5
6#include <vector>
7
8namespace Dune
9{
10 template<class LB>
11 class P23DLocalInterpolation
12 {
13 public:
14
16 template<typename F, typename C>
17 void interpolate (const F& f, std::vector<C>& out) const
18 {
19 typename LB::Traits::RangeType y;
20
21 out.resize(10);
22 typename LB::Traits::DomainType x;
23
24 x[0] = 0.0; x[1] = 0.0; x[2] = 0.0;
25 f.evaluate(x,y); out[0] = y;
26
27 x[0] = 1.0; x[1] = 0.0; x[2] = 0.0;
28 f.evaluate(x,y); out[1] = y;
29
30 x[0] = 0.0; x[1] = 1.0; x[2] = 0.0;
31 f.evaluate(x,y); out[2] = y;
32
33 x[0] = 0.0; x[1] = 0.0; x[2] = 1.0;
34 f.evaluate(x,y); out[3] = y;
35
36 x[0] = 0.5; x[1] = 0.0; x[2] = 0.0;
37 f.evaluate(x,y); out[4] = y;
38
39 x[0] = 0.5; x[1] = 0.5; x[2] = 0.0;
40 f.evaluate(x,y); out[5] = y;
41
42 x[0] = 0.0; x[1] = 0.5; x[2] = 0.0;
43 f.evaluate(x,y); out[6] = y;
44
45 x[0] = 0.0; x[1] = 0.0; x[2] = 0.5;
46 f.evaluate(x,y); out[7] = y;
47
48 x[0] = 0.5; x[1] = 0.0; x[2] = 0.5;
49 f.evaluate(x,y); out[8] = y;
50
51 x[0] = 0.0; x[1] = 0.5; x[2] = 0.5;
52 f.evaluate(x,y); out[9] = y;
53 }
54 };
55}
56
57#endif
Dune namespace.
Definition: alignedallocator.hh:10
Creative Commons License   |  Legal Statements / Impressum  |  Hosted by TU Dresden  |  generated with Hugo v0.111.3 (Dec 27, 23:30, 2024)