OPAL (Object Oriented Parallel Accelerator Library)  2024.1
OPAL
Astra1DMagnetoStatic_fast.h
Go to the documentation of this file.
1 #ifndef CLASSIC_AstraFIELDMAP1DMAGNETOSTATICFAST_HH
2 #define CLASSIC_AstraFIELDMAP1DMAGNETOSTATICFAST_HH
3 
4 #include "Fields/Astra1D_fast.h"
5 #include "Fields/Definitions.h"
6 
8 
9 public:
11 
12  virtual bool getFieldstrength(const Vector_t &R, Vector_t &E, Vector_t &B) const;
13  virtual void getFieldDimensions(double &zBegin, double &zEnd) const;
14  virtual void getFieldDimensions(double &xIni, double &xFinal, double &yIni, double &yFinal, double &zIni, double &zFinal) const;
15  virtual bool getFieldDerivative(const Vector_t &R, Vector_t &E, Vector_t &B, const DiffDirection &dir) const;
16  virtual void swap();
17  virtual void getInfo(Inform *);
18  virtual double getFrequency() const;
19  virtual void setFrequency(double freq);
20 
21 private:
22  _Astra1DMagnetoStatic_fast(const std::string& filename);
23 
24  static Astra1DMagnetoStatic_fast create(const std::string& filename);
25 
26  virtual void readMap();
27 
28  bool readFileHeader(std::ifstream &file);
29  int stripFileHeader(std::ifstream &file);
30 
31  friend class _Fieldmap;
32 };
33 
34 using Astra1DMagnetoStatic_fast = std::shared_ptr<_Astra1DMagnetoStatic_fast>;
35 
36 #endif
virtual void setFrequency(double freq)
DiffDirection
Definition: Fieldmap.h:55
_Astra1DMagnetoStatic_fast(const std::string &filename)
std::shared_ptr< _Astra1DMagnetoStatic_fast > Astra1DMagnetoStatic_fast
bool readFileHeader(std::ifstream &file)
virtual void getFieldDimensions(double &zBegin, double &zEnd) const
int stripFileHeader(std::ifstream &file)
Definition: Inform.h:42
static Astra1DMagnetoStatic_fast create(const std::string &filename)
virtual bool getFieldDerivative(const Vector_t &R, Vector_t &E, Vector_t &B, const DiffDirection &dir) const
virtual bool getFieldstrength(const Vector_t &R, Vector_t &E, Vector_t &B) const