OPAL (Object Oriented Parallel Accelerator Library) 2022.1
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
35namespace interpolation {
36
46class 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 nullptr;}
92 private:
93};
94
95bool VectorMap::checkPoint(const std::vector<double>& point) const {
96 return (point.size() == this->getPointDimension());
97}
98
99bool VectorMap::checkValue(const std::vector<double>& value) const {
100 return (value.size() == this->getValueDimension());
101}
102
103void 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_
Base class for meshing routines.
Definition: Mesh.h:49
virtual void getPosition(double *point) const
virtual bool checkPoint(const std::vector< double > &point) const
Definition: VectorMap.h:95
virtual unsigned int getValueDimension() const =0
virtual Mesh * getMesh() const
Definition: VectorMap.h:91
virtual VectorMap * clone() const =0
virtual unsigned int getPointDimension() const =0
virtual bool checkValue(const std::vector< double > &value) const
Definition: VectorMap.h:99
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:110