22#ifndef CLASSIC_Vacuum_HH
23#define CLASSIC_Vacuum_HH
28#include <boost/bimap.hpp>
82 double& startField,
double& endField)
override;
88 virtual bool bends()
const override;
90 virtual void goOnline(
const double& kineticEnergy)
override;
96 virtual void getDimensions(
double& zBegin,
double& zEnd)
const override;
123 void initR(
double rmin,
double dr,
int nrad);
Interface for a single beam element.
std::vector< double > pfld_m
std::vector< double > rarr_m
double minr_m
Flag if particles should be stripped or stopped.
double pressure_m
Type of gas for residual vacuum.
void setPScale(double ps)
double pscale_m
stores the filename of the pressure map
virtual void goOffline() override
static const boost::bimap< ResidualGas, std::string > bmResidualGasString_s
double getPressure() const
virtual bool bends() const override
std::string getPressureMapFN() const
virtual void getDimensions(double &zBegin, double &zEnd) const override
void initR(double rmin, double dr, int nrad)
void setTemperature(double temperature)
virtual void goOnline(const double &kineticEnergy) override
int idx(int irad, int ktet)
double temperature_m
a scale factor for the P-field
virtual ElementType getType() const override
Get element type std::string.
ResidualGas getResidualGas() const
void getPressureFromFile()
void setPressureMapFN(std::string pmapfn)
double checkPressure(const Vector_t &R)
virtual void finalise() override
void operator=(const Vacuum &)
virtual void initialise(PartBunchBase< double, 3 > *bunch, double &startField, double &endField) override
virtual void accept(BeamlineVisitor &) const override
Apply visitor to Vacuum.
void setPressure(double pressure)
virtual bool applyToReferenceParticle(const Vector_t &R, const Vector_t &P, const double &t, Vector_t &E, Vector_t &B) override
void updateParticleAttributes()
virtual bool checkVacuum(PartBunchBase< double, 3 > *bunch, Cyclotron *cycl)
ParticleMatterInteractionHandler * parmatint_m
mm
double getTemperature() const
void setResidualGas(std::string gas)
virtual bool apply(const size_t &i, const double &t, Vector_t &E, Vector_t &B) override
std::string getResidualGasName()
bool checkPoint(const Vector_t &R)
ResidualGas gas_m
parameters for Vacuum
void setStop(bool stopflag)