OPAL (Object Oriented Parallel Accelerator Library) 2024.2
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
36namespace 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
62 virtual double getStartOffset() const = 0;
63
66 virtual double getEndLength() const = 0;
67
69 virtual EndFieldModel* clone() const = 0;
70
78 virtual void setMaximumDerivative(size_t n) = 0;
79
85 virtual void rescale(double scaleFactor) = 0;
86
94 static std::shared_ptr<EndFieldModel> getEndFieldModel(std::string name);
95
102 static void setEndFieldModel(std::string name, std::shared_ptr<EndFieldModel> efm);
103
112 static std::string getName(std::shared_ptr<EndFieldModel> efm);
113
114private:
115 static std::map<std::string, std::shared_ptr<EndFieldModel> > efm_map;
116};
117
118std::vector< std::vector<int> > CompactVector
119 (std::vector< std::vector<int> > vec);
120
122bool GreaterThan(std::vector<int> v1, std::vector<int> v2);
123
140template <class TEMP_ITER>
141bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end,
142 TEMP_ITER b_begin, TEMP_ITER b_end);
143
160template <class TEMP_ITER>
161bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end,
162 TEMP_ITER b_begin, TEMP_ITER b_end);
163
164template <class TEMP_CLASS>
165bool IterableEquality(const TEMP_CLASS& a, const TEMP_CLASS& b) {
166 return IterableEquality(a.begin(), a.end(), b.begin(), b.end());
167}
168
169template <class TEMP_ITER>
170bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end, TEMP_ITER b_begin,
171 TEMP_ITER b_end) {
172 TEMP_ITER a_it = a_begin;
173 TEMP_ITER b_it = b_begin;
174 while (a_it != a_end && b_it != b_end) {
175 if (*a_it != *b_it) return false;
176 ++a_it;
177 ++b_it;
178 }
179 if ( a_it != a_end || b_it != b_end ) return false;
180 return true;
181}
182
183}
184
185#endif
186
std::complex< double > a
const std::string name
std::vector< std::vector< int > > CompactVector(std::vector< std::vector< int > > vec)
bool IterableEquality(TEMP_ITER a_begin, TEMP_ITER a_end, TEMP_ITER b_begin, TEMP_ITER b_end)
bool GreaterThan(std::vector< int > v1, std::vector< int > v2)
CompactVector helper function, used for sorting.
static std::shared_ptr< EndFieldModel > getEndFieldModel(std::string name)
static std::string getName(std::shared_ptr< EndFieldModel > efm)
virtual double getStartOffset() const =0
virtual void rescale(double scaleFactor)=0
virtual double getCentreLength() const =0
static std::map< std::string, std::shared_ptr< EndFieldModel > > efm_map
static void setEndFieldModel(std::string name, std::shared_ptr< EndFieldModel > efm)
virtual double getEndLength() const =0
virtual void setMaximumDerivative(size_t n)=0
virtual double function(double x, int n) const =0
virtual EndFieldModel * clone() const =0
virtual std::ostream & print(std::ostream &out) const =0
Definition Vec.h:22