OPAL (Object Oriented Parallel Accelerator Library)  2024.1
OPAL
EndFieldModel.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2017, 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 ENDFIELDMODEL_ENDFIELDMODEL_H_
29 #define ENDFIELDMODEL_ENDFIELDMODEL_H_
30 
31 #include <iostream>
32 #include <vector>
33 #include <map>
34 #include <memory>
35 
36 namespace endfieldmodel {
37 
39  public:
41  virtual ~EndFieldModel() {;}
42 
44  virtual std::ostream& print(std::ostream& out) const = 0;
45 
51  virtual double function(double x, int n) const = 0;
52 
55  virtual double getCentreLength() const = 0;
56 
59  virtual double getEndLength() const = 0;
60 
62  virtual EndFieldModel* clone() const = 0;
63 
71  virtual void setMaximumDerivative(size_t n) = 0;
72 
78  virtual void rescale(double scaleFactor) = 0;
79 
87  static std::shared_ptr<EndFieldModel> getEndFieldModel(std::string name);
88 
95  static void setEndFieldModel(std::string name, std::shared_ptr<EndFieldModel> efm);
96 
105  static std::string getName(std::shared_ptr<EndFieldModel> efm);
106 
107 private:
108  static std::map<std::string, std::shared_ptr<EndFieldModel> > efm_map;
109 };
110 
111 std::vector< std::vector<int> > CompactVector
112  (std::vector< std::vector<int> > vec);
113 
115 bool GreaterThan(std::vector<int> v1, std::vector<int> v2);
116 
133 template <class TEMP_ITER>
134 bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end,
135  TEMP_ITER b_begin, TEMP_ITER b_end);
136 
153 template <class TEMP_ITER>
154 bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end,
155  TEMP_ITER b_begin, TEMP_ITER b_end);
156 
157 template <class TEMP_CLASS>
158 bool IterableEquality(const TEMP_CLASS& a, const TEMP_CLASS& b) {
159  return IterableEquality(a.begin(), a.end(), b.begin(), b.end());
160 }
161 
162 template <class TEMP_ITER>
163 bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end, TEMP_ITER b_begin,
164  TEMP_ITER b_end) {
165  TEMP_ITER a_it = a_begin;
166  TEMP_ITER b_it = b_begin;
167  while (a_it != a_end && b_it != b_end) {
168  if (*a_it != *b_it) return false;
169  ++a_it;
170  ++b_it;
171  }
172  if ( a_it != a_end || b_it != b_end ) return false;
173  return true;
174 }
175 
176 }
177 
178 #endif
179 
virtual void setMaximumDerivative(size_t n)=0
std::vector< std::vector< int > > CompactVector(std::vector< std::vector< int > > vec)
virtual double getEndLength() const =0
bool GreaterThan(std::vector< int > v1, std::vector< int > v2)
CompactVector helper function, used for sorting.
virtual EndFieldModel * clone() const =0
Definition: Vec.h:21
virtual void rescale(double scaleFactor)=0
virtual double getCentreLength() const =0
virtual std::ostream & print(std::ostream &out) const =0
const std::string name
static std::string getName(std::shared_ptr< EndFieldModel > efm)
static std::map< std::string, std::shared_ptr< EndFieldModel > > efm_map
static void setEndFieldModel(std::string name, std::shared_ptr< EndFieldModel > efm)
bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end, TEMP_ITER b_begin, TEMP_ITER b_end)
static std::shared_ptr< EndFieldModel > getEndFieldModel(std::string name)