OPALX (Object Oriented Parallel Accelerator Library for Exascal) master (dc2a29eed580)
OPALX
Loading...
Searching...
No Matches
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 _OPALX_FIELDS_VECTORMAP_HH_
29#define _OPALX_FIELDS_VECTORMAP_HH_
30
31#include <vector>
32
34
35namespace interpolation {
36
46 class VectorMap {
47 public:
51 virtual void function(const double* point, double* value) const = 0;
52
58 inline virtual void function(const Mesh::Iterator& point, double* value) const;
59
64 inline virtual void functionAppend(
65 const std::vector<std::vector<double> >& point_vec,
66 std::vector<std::vector<double> >& value_vec) const;
67
69 inline virtual bool checkPoint(const std::vector<double>& point) const;
70
72 inline virtual bool checkValue(const std::vector<double>& value) const;
73
75 virtual unsigned int getPointDimension() const = 0;
76 // would like to make static - but can't inherit static functions
77
79 virtual unsigned int getValueDimension() const = 0;
80 // would like to make static - but can't inherit static functions
81
83 virtual VectorMap* clone() const = 0;
84
86 virtual ~VectorMap() { ; }
87
89 virtual Mesh* getMesh() const { return nullptr; }
90
91 private:
92 };
93
94 bool VectorMap::checkPoint(const std::vector<double>& point) const {
95 return (point.size() == this->getPointDimension());
96 }
97
98 bool VectorMap::checkValue(const std::vector<double>& value) const {
99 return (value.size() == this->getValueDimension());
100 }
101
102 void VectorMap::function(const Mesh::Iterator& point, double* value) const {
103 // Use standard C++ storage here; Clang warns on the VLA extension.
104 std::vector<double> pointA(this->getPointDimension());
105 point.getPosition(pointA.data());
106 function(pointA.data(), 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} // namespace interpolation
118#endif // _OPALX_FIELDS_VECTORMAP_HH_
virtual void getPosition(double *point) const
Base class for meshing routines.
Definition Mesh.h:49
virtual bool checkPoint(const std::vector< double > &point) const
Definition VectorMap.h:94
virtual unsigned int getValueDimension() const =0
virtual Mesh * getMesh() const
Definition VectorMap.h:89
virtual VectorMap * clone() const =0
virtual unsigned int getPointDimension() const =0
virtual bool checkValue(const std::vector< double > &value) const
Definition VectorMap.h:98
virtual void function(const double *point, double *value) const =0
virtual void functionAppend(const std::vector< std::vector< double > > &point_vec, std::vector< std::vector< double > > &value_vec) const
Definition VectorMap.h:109