1#ifndef CLASSIC_RBend3D_HH
2#define CLASSIC_RBend3D_HH
28template <
class T,
unsigned Dim>
78 virtual void goOnline(
const double &kineticEnergy)
override;
84 virtual void getDimensions(
double &zBegin,
double &zEnd)
const override;
double getBendAngle() const
double getEntranceAngle() const
ElementBase * clone() const override
virtual bool applyToReferenceParticle(const Vector_t &R, const Vector_t &P, const double &t, Vector_t &E, Vector_t &B) override
virtual void goOnline(const double &kineticEnergy) override
virtual void goOffline() override
BGeometryBase & getGeometry() override
virtual bool isInside(const Vector_t &r) const override
void operator=(const RBend3D &)
StraightGeometry geometry_m
virtual double getExitAngle() const override
virtual bool apply(const size_t &i, const double &t, Vector_t &E, Vector_t &B) override
double fieldAmplitudeError_m
virtual void finalise() override
BMultipoleField dummyField_m
virtual void getDimensions(double &zBegin, double &zEnd) const override
virtual void initialise(PartBunchBase< double, 3 > *bunch, double &startField, double &endField) override
virtual ElementType getType() const override
Get element type std::string.
double trackRefParticleThrough(double dt, bool print=false)
MeshData getSurfaceMesh() const
EMField & getField() override
virtual void accept(BeamlineVisitor &) const override
Apply visitor to RBend3D.
Abstract base class for accelerator geometry classes.
A geometry representing a straight line.
The magnetic field of a multipole.
Abstract base class for electromagnetic fields.