OPAL (Object Oriented Parallel Accelerator Library)  2.2.0
OPAL
VectorMap.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2012, Chris Rogers
3  * All rights reserved.
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are met:
6  * 1. Redistributions of source code must retain the above copyright notice,
7  * this list of conditions and the following disclaimer.
8  * 2. Redistributions in binary form must reproduce the above copyright notice,
9  * this list of conditions and the following disclaimer in the documentation
10  * and/or other materials provided with the distribution.
11  * 3. Neither the name of STFC nor the names of its contributors may be used to
12  * endorse or promote products derived from this software without specific
13  * prior written permission.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
19  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25  * POSSIBILITY OF SUCH DAMAGE.
26  */
27 
28 #ifndef _CLASSIC_FIELDS_VECTORMAP_HH_
29 #define _CLASSIC_FIELDS_VECTORMAP_HH_
30 
31 #include <vector>
32 
34 
35 namespace interpolation {
36 
46 class VectorMap {
47  public:
51  virtual void function(const double* point, double* value) const = 0;
52 
58  inline virtual void function
59  (const Mesh::Iterator& point, double* value) const;
60 
65  inline virtual void functionAppend(
66  const std::vector< std::vector<double> >& point_vec,
67  std::vector< std::vector<double> >& value_vec
68  ) const;
69 
71  inline virtual bool checkPoint(const std::vector<double>& point) const;
72 
74  inline virtual bool checkValue(const std::vector<double>& value) const;
75 
77  virtual unsigned int getPointDimension() const = 0;
78  // would like to make static - but can't inherit static functions
79 
81  virtual unsigned int getValueDimension() const = 0;
82  // would like to make static - but can't inherit static functions
83 
85  virtual VectorMap* clone() const = 0;
86 
88  virtual ~VectorMap() {;}
89 
91  virtual Mesh* getMesh() const {return NULL;}
92  private:
93 };
94 
95 bool VectorMap::checkPoint(const std::vector<double>& point) const {
96  return (point.size() == this->getPointDimension());
97 }
98 
99 bool VectorMap::checkValue(const std::vector<double>& value) const {
100  return (value.size() == this->getValueDimension());
101 }
102 
103 void VectorMap::function(const Mesh::Iterator& point, double* value) const {
104  double PointA[this->getPointDimension()];
105  point.getPosition(PointA);
106  function(PointA, value);
107 }
108 
110  (const std::vector< std::vector<double> >& point_vec,
111  std::vector< std::vector<double> >& value_vec) const {
112  for (size_t i = value_vec.size(); i < point_vec.size(); i++) {
113  value_vec.push_back(std::vector<double>(getValueDimension()));
114  function(&point_vec[i][0], &value_vec[i][0]);
115  }
116 }
117 }
118 #endif // _CLASSIC_FIELDS_VECTORMAP_HH_
119 // vi: set et ts=4 sw=4 sts=4:
120 // Local Variables:
121 // mode:c
122 // c-basic-offset: 4
123 // indent-tabs-mode:nil
124 // End:
virtual VectorMap * clone() const =0
virtual void functionAppend(const std::vector< std::vector< double > > &point_vec, std::vector< std::vector< double > > &value_vec) const
Definition: VectorMap.h:110
virtual bool checkValue(const std::vector< double > &value) const
Definition: VectorMap.h:99
virtual unsigned int getPointDimension() const =0
virtual Mesh * getMesh() const
Definition: VectorMap.h:91
Base class for meshing routines.
Definition: Mesh.h:49
virtual void function(const double *point, double *value) const =0
virtual bool checkPoint(const std::vector< double > &point) const
Definition: VectorMap.h:95
virtual void getPosition(double *point) const
virtual unsigned int getValueDimension() const =0