OPAL (Object Oriented Parallel Accelerator Library) 2024.2
OPAL
VariableRFCavity Class Reference

Generates a field like E = a(t) * sin{2*pi * integral(f(tau),0,t) + q(t)} B = 0 where E0, B0 are user defined fields, a(t), f(t), q(t) are time dependent amplitude, frequency, phase respectively; it is assumed that these quantities vary sufficiently slowly that Maxwell is satisfied. More...

#include <VariableRFCavity.h>

Inheritance diagram for VariableRFCavity:
Inheritance graph
Collaboration diagram for VariableRFCavity:
Collaboration graph

Public Member Functions

 VariableRFCavity (const std::string &name)
 Constructor with given name. More...
 
 VariableRFCavity (const VariableRFCavity &)
 Copy Constructor; performs deepcopy on time-dependence models. More...
 
 VariableRFCavity ()
 Default constructor. More...
 
VariableRFCavityoperator= (const VariableRFCavity &)
 Assignment operator; performs deepcopy on time-dependence models. More...
 
virtual ~VariableRFCavity ()
 Destructor does nothing. More...
 
virtual void accept (BeamlineVisitor &) const override
 Apply visitor to RFCavity. More...
 
virtual ElementBaseclone () const override
 Inheritable deepcopy method. More...
 
virtual bool apply (const size_t &i, const double &t, Vector_t &E, Vector_t &B) override
 Calculate the field at the position of the i^th particle. More...
 
virtual bool apply (const Vector_t &R, const Vector_t &P, const double &t, Vector_t &E, Vector_t &B) override
 Calculate the field at a given position. More...
 
virtual bool applyToReferenceParticle (const Vector_t &R, const Vector_t &P, const double &t, Vector_t &E, Vector_t &B) override
 Calculate the field at a given position. More...
 
virtual void initialise (PartBunchBase< double, 3 > *bunch, double &startField, double &endField) override
 Initialise ready for tracking. More...
 
virtual void finalise () override
 Finalise following tracking. More...
 
virtual bool bends () const override
 
virtual void getDimensions (double &, double &) const override
 Not used (does nothing) More...
 
virtual double getAmplitude (double time) const
 Get the amplitude at a given time. More...
 
virtual double getFrequency (double time) const
 Get the frequency at a given time. More...
 
virtual double getPhase (double time) const
 Get the phase at a given time. More...
 
virtual double getHeight () const
 
virtual double getWidth () const
 
virtual double getLength () const
 
virtual void setHeight (double fullHeight)
 Set the full height of the cavity. More...
 
virtual void setWidth (double fullWidth)
 Set the full width of the cavity. More...
 
virtual void setLength (double length)
 Set the length of the cavity. More...
 
virtual std::shared_ptr< AbstractTimeDependencegetAmplitudeModel () const
 
virtual std::shared_ptr< AbstractTimeDependencegetPhaseModel () const
 
virtual std::shared_ptr< AbstractTimeDependencegetFrequencyModel () const
 
virtual void setAmplitudeModel (std::shared_ptr< AbstractTimeDependence > time_dep)
 Set the amplitude (field gradient) time dependence. More...
 
virtual void setPhaseModel (std::shared_ptr< AbstractTimeDependence > time_dep)
 Set the phase time dependence. More...
 
virtual void setFrequencyModel (std::shared_ptr< AbstractTimeDependence > time_dep)
 Set the frequency time dependence. More...
 
virtual void setAmplitudeName (const std::string &amplitude)
 Set the amplitude time dependence name. More...
 
virtual void setPhaseName (const std::string &phase)
 Set the phase time dependence name. More...
 
virtual void setFrequencyName (const std::string &frequency)
 Set the frequency time dependence name. More...
 
virtual StraightGeometrygetGeometry () override
 Set the cavity geometry. More...
 
virtual const StraightGeometrygetGeometry () const override
 
void initialise () const
 Lookup the time dependencies and update. More...
 
virtual EMFieldgetField () override
 Not implemented. More...
 
virtual const EMFieldgetField () const override
 Not implemented. More...
 
EVector Efield (const Point3D &P) const
 Return the field in a point. More...
 
EVector Efield (const Point3D &P, double t) const
 Return the field in a point. More...
 
BVector Bfield (const Point3D &P) const
 Return the field in a point. More...
 
BVector Bfield (const Point3D &P, double t) const
 Return the field in a point. More...
 
EBVectors EBfield (const Point3D &P) const
 Return the field in a point. More...
 
EBVectors EBfield (const Point3D &P, double t) const
 Return the field in a point. More...
 
virtual bool getPotential (const Vector_t &, const double &, Vector_t &, double &)
 Calculate the four-potential at some position relative to the component. More...
 
virtual double getDesignEnergy () const
 
virtual void setDesignEnergy (const double &energy, bool changeable=true)
 
virtual void goOnline (const double &kineticEnergy)
 
virtual void goOffline ()
 
virtual bool Online ()
 
virtual ElementType getType () const override
 Get element type std::string. More...
 
virtual const ElementBasegetDesign () const
 Return design element. More...
 
virtual void trackBunch (PartBunchBase< double, 3 > *bunch, const PartData &, bool revBeam, bool revTrack) const
 Track particle bunch. More...
 
virtual void trackMap (FVps< double, 6 > &map, const PartData &, bool revBeam, bool revTrack) const
 Track a map. More...
 
void setExitFaceSlope (const double &)
 
virtual const std::string & getName () const
 Get element name. More...
 
virtual void setName (const std::string &name)
 Set element name. More...
 
std::string getTypeString () const
 
virtual double getArcLength () const
 Get arc length. More...
 
virtual double getElementLength () const
 Get design length. More...
 
virtual void setElementLength (double length)
 Set design length. More...
 
virtual void getElementDimensions (double &begin, double &end) const
 
virtual double getOrigin () const
 Get origin position. More...
 
virtual double getEntrance () const
 Get entrance position. More...
 
virtual double getExit () const
 Get exit position. More...
 
virtual Euclid3D getTransform (double fromS, double toS) const
 Get transform. More...
 
virtual Euclid3D getTransform (double s) const
 Get transform. More...
 
virtual Euclid3D getTotalTransform () const
 Get transform. More...
 
virtual Euclid3D getEntranceFrame () const
 Get transform. More...
 
virtual Euclid3D getExitFrame () const
 Get transform. More...
 
virtual Euclid3D getEntrancePatch () const
 Get patch. More...
 
virtual Euclid3D getExitPatch () const
 Get patch. More...
 
virtual double getAttribute (const std::string &aKey) const
 Get attribute value. More...
 
virtual bool hasAttribute (const std::string &aKey) const
 Test for existence of an attribute. More...
 
virtual void removeAttribute (const std::string &aKey)
 Remove an existing attribute. More...
 
virtual void setAttribute (const std::string &aKey, double val)
 Set value of an attribute. More...
 
virtual ChannelgetChannel (const std::string &aKey, bool create=false)
 Construct a read/write channel. More...
 
virtual const ConstChannelgetConstChannel (const std::string &aKey) const
 Construct a read-only channel. More...
 
virtual ElementBasecopyStructure ()
 Make a structural copy. More...
 
bool isSharable () const
 Test if the element can be shared. More...
 
virtual void makeSharable ()
 Set sharable flag. More...
 
bool update (const AttributeSet &)
 Update element. More...
 
virtual void setBoundaryGeometry (BoundaryGeometry *geo)
 attach a boundary geometry field to the element More...
 
virtual BoundaryGeometrygetBoundaryGeometry () const
 return the attached boundary geometrt object if there is any More...
 
virtual bool hasBoundaryGeometry () const
 
virtual void setWake (WakeFunction *wf)
 attach a wake field to the element More...
 
virtual WakeFunctiongetWake () const
 return the attached wake object if there is any More...
 
virtual bool hasWake () const
 
virtual void setParticleMatterInteraction (ParticleMatterInteractionHandler *spys)
 
virtual ParticleMatterInteractionHandlergetParticleMatterInteraction () const
 
virtual bool hasParticleMatterInteraction () const
 
void setCSTrafoGlobal2Local (const CoordinateSystemTrafo &ori)
 
CoordinateSystemTrafo getCSTrafoGlobal2Local () const
 
void releasePosition ()
 
void fixPosition ()
 
bool isPositioned () const
 
virtual CoordinateSystemTrafo getEdgeToBegin () const
 
virtual CoordinateSystemTrafo getEdgeToEnd () const
 
void setAperture (const ApertureType &type, const std::vector< double > &args)
 
std::pair< ApertureType, std::vector< double > > getAperture () const
 
virtual bool isInside (const Vector_t &r) const
 
void setMisalignment (const CoordinateSystemTrafo &cst)
 
void getMisalignment (double &x, double &y, double &s) const
 
CoordinateSystemTrafo getMisalignment () const
 
void setActionRange (const std::queue< std::pair< double, double > > &range)
 
void setCurrentSCoordinate (double s)
 
void setRotationAboutZ (double rotation)
 Set rotation about z axis in bend frame. More...
 
double getRotationAboutZ () const
 
virtual BoundingBox getBoundingBoxInLabCoords () const
 
virtual int getRequiredNumberOfTimeSteps () const
 
void setOutputFN (std::string fn)
 Set output filename. More...
 
std::string getOutputFN () const
 Get output filename. More...
 
void setFlagDeleteOnTransverseExit (bool=true)
 
bool getFlagDeleteOnTransverseExit () const
 
int addReference () const
 Increment reference count. More...
 
int removeReference () const
 Decrement the reference count. More...
 
bool isShared () const
 Test for sharing. More...
 
void setElementPosition (double elemedge)
 Access to ELEMEDGE attribute. More...
 
double getElementPosition () const
 
bool isElementPositionSet () const
 

Static Public Member Functions

static std::string getTypeString (ElementType type)
 

Protected Member Functions

void initNull ()
 
bool isInsideTransverse (const Vector_t &r) const
 

Protected Attributes

std::shared_ptr< AbstractTimeDependencephaseTD_m
 
std::shared_ptr< AbstractTimeDependenceamplitudeTD_m
 
std::shared_ptr< AbstractTimeDependencefrequencyTD_m
 
std::string phaseName_m
 
std::string amplitudeName_m
 
std::string frequencyName_m
 
double halfWidth_m
 
double halfHeight_m
 
double length_m
 
TimeDependenceCache frequencyCache_m
 
StraightGeometry geometry
 The cavity's geometry. More...
 
double exit_face_slope_m
 
PartBunchBase< double, 3 > * RefPartBunch_m
 
bool online_m
 
bool shareFlag
 
CoordinateSystemTrafo csTrafoGlobal2Local_m
 
CoordinateSystemTrafo misalignment_m
 
std::pair< ApertureType, std::vector< double > > aperture_m
 
double elementEdge_m
 
double rotationZAxis_m
 

Static Protected Attributes

static const std::vector< double > defaultAperture_m
 

Private Attributes

std::string elementID
 
AttributeSet userAttribs
 
WakeFunctionwake_m
 
BoundaryGeometrybgeometry_m
 
ParticleMatterInteractionHandlerparmatint_m
 
bool positionIsFixed
 
std::queue< std::pair< double, double > > actionRange_m
 
std::string outputfn_m
 The name of the outputfile. More...
 
bool deleteOnTransverseExit_m = true
 
int refCount
 
double elementPosition_m
 ELEMEDGE attribute. More...
 
bool elemedgeSet_m
 

Static Private Attributes

static const std::map< ElementType, std::string > elementTypeToString_s
 

Detailed Description

Generates a field like E = a(t) * sin{2*pi * integral(f(tau),0,t) + q(t)} B = 0 where E0, B0 are user defined fields, a(t), f(t), q(t) are time dependent amplitude, frequency, phase respectively; it is assumed that these quantities vary sufficiently slowly that Maxwell is satisfied.

The time dependent quantities are

Definition at line 40 of file VariableRFCavity.h.

Constructor & Destructor Documentation

◆ VariableRFCavity() [1/3]

VariableRFCavity::VariableRFCavity ( const std::string &  name)
explicit

Constructor with given name.

Definition at line 30 of file VariableRFCavity.cpp.

References initNull().

Here is the call graph for this function:

◆ VariableRFCavity() [2/3]

VariableRFCavity::VariableRFCavity ( const VariableRFCavity var)

Copy Constructor; performs deepcopy on time-dependence models.

Definition at line 38 of file VariableRFCavity.cpp.

References initNull().

Here is the call graph for this function:

◆ VariableRFCavity() [3/3]

VariableRFCavity::VariableRFCavity ( )

Default constructor.

Definition at line 34 of file VariableRFCavity.cpp.

References initNull().

Referenced by clone().

Here is the call graph for this function:

◆ ~VariableRFCavity()

VariableRFCavity::~VariableRFCavity ( )
virtual

Destructor does nothing.

The shared_ptrs will self-destruct when reference count goes to 0

Definition at line 69 of file VariableRFCavity.cpp.

Member Function Documentation

◆ accept()

void VariableRFCavity::accept ( BeamlineVisitor visitor) const
overridevirtual

Apply visitor to RFCavity.

The RF cavity finds the "time dependence" models by doing a string lookup against a list held by AbstractTimeDependence at accept time.

Implements ElementBase.

Reimplemented in VariableRFCavityFringeField.

Definition at line 171 of file VariableRFCavity.cpp.

References initialise(), and BeamlineVisitor::visitVariableRFCavity().

Here is the call graph for this function:

◆ addReference()

int RCObject::addReference ( ) const
inlineinherited

Increment reference count.

Definition at line 83 of file RCObject.h.

References RCObject::refCount.

Referenced by Pointer< Object >::operator=(), and Pointer< Object >::unique().

◆ apply() [1/2]

bool VariableRFCavity::apply ( const size_t &  i,
const double &  t,
Vector_t E,
Vector_t B 
)
overridevirtual

Calculate the field at the position of the i^th particle.

Parameters
iindexes the particle whose field we need
tthe time at which the field is calculated
Ereturn value with electric field strength
Breturn value with magnetic field strength
Returns
True if particle is outside the boundaries; else False

Reimplemented from Component.

Reimplemented in VariableRFCavityFringeField.

Definition at line 127 of file VariableRFCavity.cpp.

References apply(), PartBunchBase< T, Dim >::P, PartBunchBase< T, Dim >::R, and Component::RefPartBunch_m.

Referenced by apply(), and applyToReferenceParticle().

Here is the call graph for this function:

◆ apply() [2/2]

bool VariableRFCavity::apply ( const Vector_t R,
const Vector_t P,
const double &  t,
Vector_t E,
Vector_t B 
)
overridevirtual

Calculate the field at a given position.

Parameters
Rthe position at which the field is calculated
Pthe momentum (not used)
tthe time at which the field is calculated
Ereturn value; filled with electric field strength
Breturn value; filled with magnetic field strength
Returns
True if particle is outside the boundaries; else False

Reimplemented from Component.

Reimplemented in VariableRFCavityFringeField.

Definition at line 138 of file VariableRFCavity.cpp.

References abs(), amplitudeTD_m, frequencyCache_m, TimeDependenceCache::getIntegral(), halfHeight_m, halfWidth_m, length_m, Units::MHz2Hz, phaseTD_m, Attrib::Distribution::R, sin(), and Physics::two_pi.

Here is the call graph for this function:

◆ applyToReferenceParticle()

bool VariableRFCavity::applyToReferenceParticle ( const Vector_t R,
const Vector_t P,
const double &  t,
Vector_t E,
Vector_t B 
)
overridevirtual

Calculate the field at a given position.

This is identical to "apply".

Parameters
Rthe position at which the field is calculated
Pthe momentum (not used)
tthe time at which the field is calculated
Ereturn value; filled with electric field strength
Breturn value; filled with magnetic field strength
Returns
True if particle is outside the boundaries; else False

Reimplemented from Component.

Reimplemented in VariableRFCavityFringeField.

Definition at line 153 of file VariableRFCavity.cpp.

References apply(), and Attrib::Distribution::R.

Here is the call graph for this function:

◆ bends()

virtual bool VariableRFCavity::bends ( ) const
inlineoverridevirtual
Returns
false (cavity does not bend the trajectory)

Implements Component.

Definition at line 119 of file VariableRFCavity.h.

◆ Bfield() [1/2]

BVector Component::Bfield ( const Point3D P) const
inlineinherited

Return the field in a point.

Definition at line 202 of file Component.h.

References EMField::Bfield(), and Component::getField().

Here is the call graph for this function:

◆ Bfield() [2/2]

BVector Component::Bfield ( const Point3D P,
double  t 
) const
inlineinherited

Return the field in a point.

Definition at line 208 of file Component.h.

References EMField::Bfield(), and Component::getField().

Here is the call graph for this function:

◆ clone()

ElementBase * VariableRFCavity::clone ( ) const
overridevirtual

Inheritable deepcopy method.

Implements ElementBase.

Reimplemented in VariableRFCavityFringeField.

Definition at line 167 of file VariableRFCavity.cpp.

References VariableRFCavity().

Here is the call graph for this function:

◆ copyStructure()

ElementBase * ElementBase::copyStructure ( )
virtualinherited

Make a structural copy.

Reimplemented in TBeamline< T >.

Definition at line 244 of file ElementBase.cpp.

References ElementBase::clone(), and ElementBase::isSharable().

Referenced by Sequence::copy(), Line::parse(), SequenceParser::parseMember(), and Replacer::visitFlaggedElmPtr().

Here is the call graph for this function:

◆ EBfield() [1/2]

EBVectors Component::EBfield ( const Point3D P) const
inlineinherited

Return the field in a point.

Definition at line 211 of file Component.h.

References EMField::EBfield(), and Component::getField().

Here is the call graph for this function:

◆ EBfield() [2/2]

EBVectors Component::EBfield ( const Point3D P,
double  t 
) const
inlineinherited

Return the field in a point.

Definition at line 214 of file Component.h.

References EMField::EBfield(), and Component::getField().

Here is the call graph for this function:

◆ Efield() [1/2]

EVector Component::Efield ( const Point3D P) const
inlineinherited

Return the field in a point.

Definition at line 199 of file Component.h.

References EMField::Efield(), and Component::getField().

Here is the call graph for this function:

◆ Efield() [2/2]

EVector Component::Efield ( const Point3D P,
double  t 
) const
inlineinherited

Return the field in a point.

Definition at line 205 of file Component.h.

References EMField::Efield(), and Component::getField().

Here is the call graph for this function:

◆ finalise()

void VariableRFCavity::finalise ( )
overridevirtual

Finalise following tracking.

Just sets RefPartBunch_m to nullptr

Implements Component.

Definition at line 163 of file VariableRFCavity.cpp.

References Component::RefPartBunch_m.

◆ fixPosition()

void ElementBase::fixPosition ( )
inlineinherited

◆ getAmplitude()

double VariableRFCavity::getAmplitude ( double  time) const
inlinevirtual

Get the amplitude at a given time.

Parameters
timethe time at which the amplitude is calculated
Returns
the RF field gradient.

Definition at line 229 of file VariableRFCavity.h.

References amplitudeTD_m.

◆ getAmplitudeModel()

std::shared_ptr< AbstractTimeDependence > VariableRFCavity::getAmplitudeModel ( ) const
virtual
Returns
shared_ptr to the amplitude (field gradient) time dependence

Definition at line 83 of file VariableRFCavity.cpp.

References amplitudeTD_m.

◆ getAperture()

std::pair< ApertureType, std::vector< double > > ElementBase::getAperture ( ) const
inlineinherited

Definition at line 525 of file ElementBase.h.

References ElementBase::aperture_m.

Referenced by MeshGenerator::add(), and Offset::operator=().

◆ getArcLength()

double ElementBase::getArcLength ( ) const
inlinevirtualinherited

Get arc length.

Reimplemented in MarkerRep, and TBeamline< T >.

Definition at line 411 of file ElementBase.h.

References BGeometryBase::getArcLength(), and ElementBase::getGeometry().

Referenced by BeamlineGeometry::getArcLength(), and TBeamline< T >::getTransform().

Here is the call graph for this function:

◆ getAttribute()

double ElementBase::getAttribute ( const std::string &  aKey) const
virtualinherited

Get attribute value.

Definition at line 187 of file ElementBase.cpp.

References ElementBase::getConstChannel().

Here is the call graph for this function:

◆ getBoundaryGeometry()

BoundaryGeometry * ElementBase::getBoundaryGeometry ( ) const
inlinevirtualinherited

return the attached boundary geometrt object if there is any

Definition at line 475 of file ElementBase.h.

References ElementBase::bgeometry_m.

◆ getBoundingBoxInLabCoords()

BoundingBox ElementBase::getBoundingBoxInLabCoords ( ) const
virtualinherited

◆ getChannel()

◆ getConstChannel()

const ConstChannel * ElementBase::getConstChannel ( const std::string &  aKey) const
virtualinherited

Construct a read-only channel.

Definition at line 233 of file ElementBase.cpp.

References ElementBase::getChannel().

Referenced by ElementBase::getAttribute(), and ElementBase::hasAttribute().

Here is the call graph for this function:

◆ getCSTrafoGlobal2Local()

◆ getDesign()

const ElementBase & Component::getDesign ( ) const
virtualinherited

Return design element.

Definition at line 67 of file Component.cpp.

◆ getDesignEnergy()

double Component::getDesignEnergy ( ) const
inlinevirtualinherited

Reimplemented in BendBase, and RFCavity.

Definition at line 231 of file Component.h.

◆ getDimensions()

virtual void VariableRFCavity::getDimensions ( double &  ,
double &   
) const
inlineoverridevirtual

Not used (does nothing)

Implements Component.

Definition at line 122 of file VariableRFCavity.h.

◆ getEdgeToBegin()

CoordinateSystemTrafo ElementBase::getEdgeToBegin ( ) const
inlinevirtualinherited

◆ getEdgeToEnd()

CoordinateSystemTrafo ElementBase::getEdgeToEnd ( ) const
inlinevirtualinherited

Reimplemented in Bend2D, RFCavity, Solenoid, and TravelingWave.

Definition at line 511 of file ElementBase.h.

References ElementBase::getElementLength().

Referenced by ElementBase::getBoundingBoxInLabCoords().

Here is the call graph for this function:

◆ getElementDimensions()

virtual void ElementBase::getElementDimensions ( double &  begin,
double &  end 
) const
inlinevirtualinherited

Reimplemented in RFCavity, TravelingWave, and Solenoid.

Definition at line 174 of file ElementBase.h.

References begin(), end(), and ElementBase::getElementLength().

Referenced by MeshGenerator::add().

Here is the call graph for this function:

◆ getElementLength()

double ElementBase::getElementLength ( ) const
inlinevirtualinherited

Get design length.

Reimplemented in MarkerRep, TBeamline< T >, and RFCavity.

Definition at line 415 of file ElementBase.h.

References BGeometryBase::getElementLength(), and ElementBase::getGeometry().

Referenced by ScatteringPhysics::addBackToBunch(), Undulator::apply(), Multipole::apply(), Component::apply(), Corrector::apply(), Solenoid::apply(), Component::applyToReferenceParticle(), Multipole::applyToReferenceParticle(), Solenoid::applyToReferenceParticle(), Vacuum::checkPoint(), ScatteringPhysics::copyFromBunch(), RBend::findChordLength(), SBend::findChordLength(), Corrector::getDimensions(), CCollimator::getDimensions(), Degrader::getDimensions(), Drift::getDimensions(), FlexibleCollimator::getDimensions(), Multipole::getDimensions(), RBend3D::getDimensions(), Solenoid::getDimensions(), Vacuum::getDimensions(), ElementBase::getEdgeToEnd(), Solenoid::getEdgeToEnd(), ElementBase::getElementDimensions(), Solenoid::getElementDimensions(), BeamlineGeometry::getElementLength(), RFCavity::getElementLength(), Corrector::initialise(), Degrader::initialise(), Drift::initialise(), FlexibleCollimator::initialise(), Multipole::initialise(), RBend3D::initialise(), Solenoid::initialise(), Source::initialise(), Vacuum::initialise(), ElementBase::isInside(), Degrader::isInside(), Monitor::isInside(), Multipole::isInside(), ElementBase::isInsideTransverse(), FlexibleCollimator::isStopped(), ScatteringPhysics::setTimeStepForLeavingParticles(), Bend2D::setupDefaultFieldMap(), ParallelCyclotronTracker::visitCorrector(), ParallelCyclotronTracker::visitDrift(), ThickTracker::visitDrift(), ParallelCyclotronTracker::visitMultipole(), ThickTracker::visitMultipole(), ParallelCyclotronTracker::visitRBend(), ParallelCyclotronTracker::visitSBend(), and ThickTracker::visitSBend().

Here is the call graph for this function:

◆ getElementPosition()

double ElementBase::getElementPosition ( ) const
inlineinherited

Definition at line 589 of file ElementBase.h.

References ElementBase::elemedgeSet_m, ElementBase::elementPosition_m, and ElementBase::getName().

Here is the call graph for this function:

◆ getEntrance()

double ElementBase::getEntrance ( ) const
inlinevirtualinherited

Get entrance position.

Reimplemented in TBeamline< T >.

Definition at line 427 of file ElementBase.h.

References BGeometryBase::getEntrance(), and ElementBase::getGeometry().

Referenced by BeamlineGeometry::getEntrance().

Here is the call graph for this function:

◆ getEntranceFrame()

Euclid3D ElementBase::getEntranceFrame ( ) const
inlinevirtualinherited

Get transform.

Reimplemented in TBeamline< T >.

Definition at line 447 of file ElementBase.h.

References BGeometryBase::getEntranceFrame(), and ElementBase::getGeometry().

Referenced by BeamlineGeometry::getEntranceFrame().

Here is the call graph for this function:

◆ getEntrancePatch()

Euclid3D ElementBase::getEntrancePatch ( ) const
inlinevirtualinherited

Get patch.

Definition at line 455 of file ElementBase.h.

References BGeometryBase::getEntrancePatch(), and ElementBase::getGeometry().

Here is the call graph for this function:

◆ getExit()

double ElementBase::getExit ( ) const
inlinevirtualinherited

Get exit position.

Reimplemented in TBeamline< T >.

Definition at line 431 of file ElementBase.h.

References BGeometryBase::getExit(), and ElementBase::getGeometry().

Referenced by BeamlineGeometry::getExit().

Here is the call graph for this function:

◆ getExitFrame()

Euclid3D ElementBase::getExitFrame ( ) const
inlinevirtualinherited

Get transform.

Reimplemented in TBeamline< T >.

Definition at line 451 of file ElementBase.h.

References BGeometryBase::getExitFrame(), and ElementBase::getGeometry().

Referenced by BeamlineGeometry::getExitFrame().

Here is the call graph for this function:

◆ getExitPatch()

Euclid3D ElementBase::getExitPatch ( ) const
inlinevirtualinherited

Get patch.

Definition at line 459 of file ElementBase.h.

References BGeometryBase::getExitPatch(), and ElementBase::getGeometry().

Here is the call graph for this function:

◆ getField() [1/2]

const EMField & VariableRFCavity::getField ( ) const
overridevirtual

Not implemented.

Implements Component.

Definition at line 121 of file VariableRFCavity.cpp.

◆ getField() [2/2]

EMField & VariableRFCavity::getField ( )
overridevirtual

Not implemented.

Implements Component.

Definition at line 116 of file VariableRFCavity.cpp.

◆ getFlagDeleteOnTransverseExit()

bool ElementBase::getFlagDeleteOnTransverseExit ( ) const
inlineinherited

◆ getFrequency()

double VariableRFCavity::getFrequency ( double  time) const
inlinevirtual

Get the frequency at a given time.

Parameters
timethe time at which the frequency is calculated
Returns
the RF cavity frequency.

Definition at line 237 of file VariableRFCavity.h.

References frequencyTD_m.

◆ getFrequencyModel()

std::shared_ptr< AbstractTimeDependence > VariableRFCavity::getFrequencyModel ( ) const
virtual
Returns
shared_ptr to the frequency

Definition at line 91 of file VariableRFCavity.cpp.

References frequencyTD_m.

◆ getGeometry() [1/2]

const StraightGeometry & VariableRFCavity::getGeometry ( ) const
overridevirtual
Returns
the cavity geometry

Implements ElementBase.

Definition at line 112 of file VariableRFCavity.cpp.

References geometry.

◆ getGeometry() [2/2]

StraightGeometry & VariableRFCavity::getGeometry ( )
overridevirtual

Set the cavity geometry.

Implements ElementBase.

Definition at line 108 of file VariableRFCavity.cpp.

References geometry.

◆ getHeight()

double VariableRFCavity::getHeight ( ) const
inlinevirtual
Returns
the full height of the cavity

Definition at line 241 of file VariableRFCavity.h.

References halfHeight_m.

◆ getLength()

double VariableRFCavity::getLength ( ) const
inlinevirtual
Returns
the length of the cavity

Definition at line 249 of file VariableRFCavity.h.

References length_m.

◆ getMisalignment() [1/2]

CoordinateSystemTrafo ElementBase::getMisalignment ( ) const
inlineinherited

Definition at line 541 of file ElementBase.h.

References ElementBase::misalignment_m.

◆ getMisalignment() [2/2]

void ElementBase::getMisalignment ( double &  x,
double &  y,
double &  s 
) const
inherited

◆ getName()

const std::string & ElementBase::getName ( ) const
virtualinherited

Get element name.

Definition at line 162 of file ElementBase.cpp.

References ElementBase::elementID.

Referenced by Ring::appendElement(), Cyclotron::apply(), Ring::apply(), Bend2D::calculateRefTrajectory(), OutputPlane::checkOne(), Vacuum::checkPressure(), Stripper::doCheck(), CCollimator::doFinalise(), Stripper::doFinalise(), OutputPlane::doGoOffline(), Probe::doGoOffline(), OutputPlane::doInitialise(), PlaceRep::enter(), Cyclotron::finalise(), Degrader::finalise(), FlexibleCollimator::finalise(), Vacuum::finalise(), PyOpal::Field::getElementName(), ElementBase::getElementPosition(), RFCavity::getMomentaKick(), BeamStrippingPhysics::getName(), ScatteringPhysics::getName(), Bend2D::getOutline(), ElementBase::getOutputFN(), CavityAutophaser::getPhaseAtMaxEnergy(), Selector::handleElement(), Ring::initialise(), Bend2D::initialise(), RBend3D::initialise(), RFCavity::initialise(), Solenoid::initialise(), CSRIGFWakeFunction::initialize(), CSRWakeFunction::initialize(), OpalWake::initWakefunction(), PlaceRep::leave(), operator<<(), Offset::operator=(), operator=(), operator==(), Line::parse(), Vacuum::print(), BeamStrippingPhysics::print(), ScatteringPhysics::print(), Sequence::print(), ParticleMatterInteraction::print(), Bend2D::readFieldMap(), PyOpal::PyLine_< C >::registerObject(), Component::trackBunch(), Component::trackMap(), RBend3D::trackRefParticleThrough(), OpalRBend::update(), OpalRBend3D::update(), OpalSBend::update(), Sequence::updateList(), ParallelTTracker::updateRFElement(), ParallelCyclotronTracker::visitCCollimator(), Replacer::visitFlaggedElmPtr(), ParallelCyclotronTracker::visitProbe(), ParallelCyclotronTracker::visitRFCavity(), ParallelCyclotronTracker::visitSeptum(), ParallelCyclotronTracker::visitStripper(), and ParallelTTracker::writePhaseSpace().

◆ getOrigin()

double ElementBase::getOrigin ( ) const
inlinevirtualinherited

Get origin position.

Reimplemented in TBeamline< T >.

Definition at line 423 of file ElementBase.h.

References ElementBase::getGeometry(), and BGeometryBase::getOrigin().

Referenced by BeamlineGeometry::getOrigin().

Here is the call graph for this function:

◆ getOutputFN()

std::string ElementBase::getOutputFN ( ) const
inherited

Get output filename.

Definition at line 177 of file ElementBase.cpp.

References ElementBase::getName(), and ElementBase::outputfn_m.

Referenced by Probe::doInitialise(), PluginElement::initialise(), Cyclotron::initialise(), FlexibleCollimator::initialise(), Monitor::initialise(), and Source::initialise().

Here is the call graph for this function:

◆ getParticleMatterInteraction()

ParticleMatterInteractionHandler * ElementBase::getParticleMatterInteraction ( ) const
inlinevirtualinherited

◆ getPhase()

double VariableRFCavity::getPhase ( double  time) const
inlinevirtual

Get the phase at a given time.

Parameters
phasethe time at which the phase is calculated
Returns
the RF cavity phase.

Definition at line 233 of file VariableRFCavity.h.

References phaseTD_m.

◆ getPhaseModel()

std::shared_ptr< AbstractTimeDependence > VariableRFCavity::getPhaseModel ( ) const
virtual
Returns
shared_ptr to the phase time dependence

Definition at line 87 of file VariableRFCavity.cpp.

References phaseTD_m.

◆ getPotential()

virtual bool Component::getPotential ( const Vector_t ,
const double &  ,
Vector_t ,
double &   
)
inlinevirtualinherited

Calculate the four-potential at some position relative to the component.

Parameters
Rposition in the local coordinate system of the component
ttime
Afilled with the calculated magnetic vector potential
phifilled with the calculated electric potential Note that any existing values in A and phi may be overwritten by this method.
Returns
true if particle is outside the field map, else false Default for component is to return false and make no change to A and phi

Definition at line 130 of file Component.h.

◆ getRequiredNumberOfTimeSteps()

int ElementBase::getRequiredNumberOfTimeSteps ( ) const
inlinevirtualinherited

Reimplemented in Drift, Marker, Monitor, Source, and Stripper.

Definition at line 603 of file ElementBase.h.

◆ getRotationAboutZ()

double ElementBase::getRotationAboutZ ( ) const
inlineinherited

◆ getTotalTransform()

Euclid3D ElementBase::getTotalTransform ( ) const
inlinevirtualinherited

Get transform.

Reimplemented in TBeamline< T >.

Definition at line 439 of file ElementBase.h.

References ElementBase::getGeometry(), and BGeometryBase::getTotalTransform().

Referenced by BeamlineGeometry::getTotalTransform().

Here is the call graph for this function:

◆ getTransform() [1/2]

Euclid3D ElementBase::getTransform ( double  fromS,
double  toS 
) const
inlinevirtualinherited

Get transform.

Reimplemented in TBeamline< T >.

Definition at line 435 of file ElementBase.h.

References ElementBase::getGeometry(), and BGeometryBase::getTransform().

Referenced by BeamlineGeometry::getTransform(), and TBeamline< T >::getTransform().

Here is the call graph for this function:

◆ getTransform() [2/2]

Euclid3D ElementBase::getTransform ( double  s) const
inlinevirtualinherited

Get transform.

Reimplemented in TBeamline< T >.

Definition at line 443 of file ElementBase.h.

References ElementBase::getGeometry(), and BGeometryBase::getTransform().

Here is the call graph for this function:

◆ getType()

ElementType Component::getType ( ) const
overridevirtualinherited

Get element type std::string.

Implements ElementBase.

Reimplemented in Corrector, Cyclotron, Undulator, CCollimator, Degrader, Drift, FlexibleCollimator, Marker, Monitor, Multipole, OutputPlane, Probe, RBend, RBend3D, RFCavity, SBend, Septum, Solenoid, Source, Stripper, TravelingWave, Vacuum, and Bend2D.

Definition at line 95 of file Component.cpp.

References ANY.

◆ getTypeString() [1/2]

std::string ElementBase::getTypeString ( ) const
inlineinherited

Definition at line 579 of file ElementBase.h.

References ElementBase::getType(), and ElementBase::getTypeString().

Referenced by ParallelCyclotronTracker::execute(), ElementBase::getTypeString(), Vacuum::print(), and OpalBeamline::visit().

Here is the call graph for this function:

◆ getTypeString() [2/2]

std::string ElementBase::getTypeString ( ElementType  type)
staticinherited

Definition at line 240 of file ElementBase.cpp.

References ElementBase::elementTypeToString_s.

◆ getWake()

WakeFunction * ElementBase::getWake ( ) const
inlinevirtualinherited

return the attached wake object if there is any

Definition at line 467 of file ElementBase.h.

References ElementBase::wake_m.

◆ getWidth()

double VariableRFCavity::getWidth ( ) const
inlinevirtual
Returns
the full width of the cavity

Definition at line 245 of file VariableRFCavity.h.

References halfWidth_m.

◆ goOffline()

void Component::goOffline ( )
virtualinherited

◆ goOnline()

void Component::goOnline ( const double &  kineticEnergy)
virtualinherited

◆ hasAttribute()

bool ElementBase::hasAttribute ( const std::string &  aKey) const
virtualinherited

Test for existence of an attribute.

Definition at line 200 of file ElementBase.cpp.

References ElementBase::getConstChannel().

Referenced by ParallelCyclotronTracker::visitSolenoid().

Here is the call graph for this function:

◆ hasBoundaryGeometry()

bool ElementBase::hasBoundaryGeometry ( ) const
inlinevirtualinherited

Definition at line 479 of file ElementBase.h.

References ElementBase::bgeometry_m.

◆ hasParticleMatterInteraction()

bool ElementBase::hasParticleMatterInteraction ( ) const
inlinevirtualinherited

Definition at line 487 of file ElementBase.h.

References ElementBase::parmatint_m.

◆ hasWake()

bool ElementBase::hasWake ( ) const
inlinevirtualinherited

Definition at line 471 of file ElementBase.h.

References ElementBase::wake_m.

◆ initialise() [1/2]

void VariableRFCavity::initialise ( ) const

Lookup the time dependencies and update.

Throws if the named time dependencies can't be found. Also throws if the width or height is < 1 nm

Definition at line 176 of file VariableRFCavity.cpp.

References amplitudeName_m, Physics::e, frequencyName_m, AbstractTimeDependence::getTimeDependence(), halfHeight_m, halfWidth_m, phaseName_m, setAmplitudeModel(), setFrequencyModel(), and setPhaseModel().

Referenced by accept(), and VariableRFCavityFringeField::initialise().

Here is the call graph for this function:

◆ initialise() [2/2]

void VariableRFCavity::initialise ( PartBunchBase< double, 3 > *  bunch,
double &  startField,
double &  endField 
)
overridevirtual

Initialise ready for tracking.

Just sets RefPartBunch_m

Implements Component.

Reimplemented in VariableRFCavityFringeField.

Definition at line 158 of file VariableRFCavity.cpp.

References Component::RefPartBunch_m.

Referenced by PyOpal::PyOpalObjectNS::PyOpalObject< C >::doSetup().

◆ initNull()

void VariableRFCavity::initNull ( )
protected

◆ isElementPositionSet()

bool ElementBase::isElementPositionSet ( ) const
inlineinherited

Definition at line 598 of file ElementBase.h.

References ElementBase::elemedgeSet_m.

◆ isInside()

bool ElementBase::isInside ( const Vector_t r) const
inlinevirtualinherited

Reimplemented in Bend2D, Degrader, Monitor, Multipole, RBend3D, RFCavity, Solenoid, and TravelingWave.

Definition at line 530 of file ElementBase.h.

References ElementBase::getElementLength(), and ElementBase::isInsideTransverse().

Here is the call graph for this function:

◆ isInsideTransverse()

◆ isPositioned()

bool ElementBase::isPositioned ( ) const
inlineinherited

◆ isSharable()

bool ElementBase::isSharable ( ) const
inlineinherited

Test if the element can be shared.

Definition at line 463 of file ElementBase.h.

References ElementBase::shareFlag.

Referenced by ElementBase::copyStructure(), and Sequence::updateList().

◆ isShared()

bool RCObject::isShared ( ) const
inlineinherited

Test for sharing.

Definition at line 93 of file RCObject.h.

References RCObject::refCount.

◆ makeSharable()

void ElementBase::makeSharable ( )
virtualinherited

Set sharable flag.

Reimplemented in TBeamline< T >.

Definition at line 253 of file ElementBase.cpp.

References ElementBase::shareFlag.

Referenced by OpalMarker::OpalMarker(), and Element::setShared().

◆ Online()

bool Component::Online ( )
virtualinherited

Definition at line 91 of file Component.cpp.

References Component::online_m.

◆ operator=()

VariableRFCavity & VariableRFCavity::operator= ( const VariableRFCavity rhs)

Assignment operator; performs deepcopy on time-dependence models.

Definition at line 43 of file VariableRFCavity.cpp.

References amplitudeName_m, amplitudeTD_m, frequencyName_m, frequencyTD_m, ElementBase::getName(), halfHeight_m, halfWidth_m, length_m, phaseName_m, phaseTD_m, setAmplitudeModel(), setFrequencyModel(), setLength(), ElementBase::setName(), and setPhaseModel().

Referenced by VariableRFCavityFringeField::operator=().

Here is the call graph for this function:

◆ releasePosition()

void ElementBase::releasePosition ( )
inlineinherited

◆ removeAttribute()

void ElementBase::removeAttribute ( const std::string &  aKey)
virtualinherited

Remove an existing attribute.

Definition at line 212 of file ElementBase.cpp.

References AttributeSet::removeAttribute(), and ElementBase::userAttribs.

Here is the call graph for this function:

◆ removeReference()

int RCObject::removeReference ( ) const
inlineinherited

Decrement the reference count.

Definition at line 88 of file RCObject.h.

References RCObject::refCount.

◆ setActionRange()

void ElementBase::setActionRange ( const std::queue< std::pair< double, double > > &  range)
inlineinherited

Definition at line 561 of file ElementBase.h.

References ElementBase::actionRange_m, and ElementBase::elementEdge_m.

◆ setAmplitudeModel()

void VariableRFCavity::setAmplitudeModel ( std::shared_ptr< AbstractTimeDependence time_dep)
virtual

Set the amplitude (field gradient) time dependence.

Definition at line 95 of file VariableRFCavity.cpp.

References amplitudeTD_m.

Referenced by initialise(), and operator=().

◆ setAmplitudeName()

virtual void VariableRFCavity::setAmplitudeName ( const std::string &  amplitude)
inlinevirtual

Set the amplitude time dependence name.

The name is used to find the amplitude model at accept time

Definition at line 179 of file VariableRFCavity.h.

References amplitudeName_m.

Referenced by OpalVariableRFCavity::update(), and OpalVariableRFCavityFringeField::update().

◆ setAperture()

void ElementBase::setAperture ( const ApertureType type,
const std::vector< double > &  args 
)
inlineinherited

◆ setAttribute()

void ElementBase::setAttribute ( const std::string &  aKey,
double  val 
)
virtualinherited

Set value of an attribute.

Definition at line 217 of file ElementBase.cpp.

References endl(), ElementBase::getChannel(), and Channel::isSettable().

Referenced by ElementBase::update(), and OpalElement::updateUnknown().

Here is the call graph for this function:

◆ setBoundaryGeometry()

void ElementBase::setBoundaryGeometry ( BoundaryGeometry geo)
virtualinherited

attach a boundary geometry field to the element

Definition at line 270 of file ElementBase.cpp.

References ElementBase::bgeometry_m.

Referenced by OpalCavity::update(), OpalCyclotron::update(), and OpalDrift::update().

◆ setCSTrafoGlobal2Local()

void ElementBase::setCSTrafoGlobal2Local ( const CoordinateSystemTrafo ori)
inlineinherited

◆ setCurrentSCoordinate()

void ElementBase::setCurrentSCoordinate ( double  s)
inherited

Definition at line 278 of file ElementBase.cpp.

References ElementBase::actionRange_m, and ElementBase::elementEdge_m.

◆ setDesignEnergy()

void Component::setDesignEnergy ( const double &  energy,
bool  changeable = true 
)
inlinevirtualinherited

Reimplemented in Corrector, RFCavity, and BendBase.

Definition at line 228 of file Component.h.

◆ setElementLength()

◆ setElementPosition()

void ElementBase::setElementPosition ( double  elemedge)
inlineinherited

Access to ELEMEDGE attribute.

Definition at line 583 of file ElementBase.h.

References ElementBase::elemedgeSet_m, and ElementBase::elementPosition_m.

Referenced by OpalElement::update().

◆ setExitFaceSlope()

void Component::setExitFaceSlope ( const double &  m)
inlineinherited

Definition at line 225 of file Component.h.

References Component::exit_face_slope_m.

◆ setFlagDeleteOnTransverseExit()

void ElementBase::setFlagDeleteOnTransverseExit ( bool  flag = true)
inlineinherited

Definition at line 608 of file ElementBase.h.

References ElementBase::deleteOnTransverseExit_m.

Referenced by OpalElement::update().

◆ setFrequencyModel()

void VariableRFCavity::setFrequencyModel ( std::shared_ptr< AbstractTimeDependence time_dep)
virtual

Set the frequency time dependence.

Definition at line 103 of file VariableRFCavity.cpp.

References frequencyCache_m, frequencyTD_m, and TimeDependenceCache::setTimeDependence().

Referenced by initialise(), and operator=().

Here is the call graph for this function:

◆ setFrequencyName()

virtual void VariableRFCavity::setFrequencyName ( const std::string &  frequency)
inlinevirtual

Set the frequency time dependence name.

The name is used to find the frequency model at accept time

Definition at line 191 of file VariableRFCavity.h.

References frequencyName_m.

Referenced by OpalVariableRFCavity::update(), and OpalVariableRFCavityFringeField::update().

◆ setHeight()

void VariableRFCavity::setHeight ( double  fullHeight)
inlinevirtual

Set the full height of the cavity.

Definition at line 253 of file VariableRFCavity.h.

References halfHeight_m.

Referenced by OpalVariableRFCavity::update(), and OpalVariableRFCavityFringeField::update().

◆ setLength()

void VariableRFCavity::setLength ( double  length)
virtual

Set the length of the cavity.

Definition at line 193 of file VariableRFCavity.cpp.

References geometry, length_m, and StraightGeometry::setElementLength().

Referenced by operator=(), OpalVariableRFCavity::update(), and OpalVariableRFCavityFringeField::update().

Here is the call graph for this function:

◆ setMisalignment()

void ElementBase::setMisalignment ( const CoordinateSystemTrafo cst)
inlineinherited

Definition at line 536 of file ElementBase.h.

References ElementBase::misalignment_m.

Referenced by OpalElement::update().

◆ setName()

void ElementBase::setName ( const std::string &  name)
virtualinherited

Set element name.

Definition at line 167 of file ElementBase.cpp.

References ElementBase::elementID, and name.

Referenced by Sequence::insertDrifts(), Offset::operator=(), and operator=().

◆ setOutputFN()

◆ setParticleMatterInteraction()

◆ setPhaseModel()

void VariableRFCavity::setPhaseModel ( std::shared_ptr< AbstractTimeDependence time_dep)
virtual

Set the phase time dependence.

Definition at line 99 of file VariableRFCavity.cpp.

References phaseTD_m.

Referenced by initialise(), and operator=().

◆ setPhaseName()

virtual void VariableRFCavity::setPhaseName ( const std::string &  phase)
inlinevirtual

Set the phase time dependence name.

The name is used to find the phase model at accept time

Definition at line 185 of file VariableRFCavity.h.

References phaseName_m.

Referenced by OpalVariableRFCavity::update(), and OpalVariableRFCavityFringeField::update().

◆ setRotationAboutZ()

void ElementBase::setRotationAboutZ ( double  rotation)
inlineinherited

Set rotation about z axis in bend frame.

Definition at line 569 of file ElementBase.h.

References ElementBase::rotationZAxis_m.

Referenced by OpalElement::update().

◆ setWake()

void ElementBase::setWake ( WakeFunction wf)
virtualinherited

◆ setWidth()

void VariableRFCavity::setWidth ( double  fullWidth)
inlinevirtual

Set the full width of the cavity.

Definition at line 257 of file VariableRFCavity.h.

References halfWidth_m.

Referenced by OpalVariableRFCavity::update(), and OpalVariableRFCavityFringeField::update().

◆ trackBunch()

void Component::trackBunch ( PartBunchBase< double, 3 > *  bunch,
const PartData ,
bool  revBeam,
bool  revTrack 
) const
virtualinherited

Track particle bunch.

Definition at line 71 of file Component.cpp.

References ElementBase::getName().

Referenced by Tracker::visitComponent().

Here is the call graph for this function:

◆ trackMap()

void Component::trackMap ( FVps< double, 6 > &  map,
const PartData ,
bool  revBeam,
bool  revTrack 
) const
virtualinherited

Track a map.

Definition at line 77 of file Component.cpp.

References ElementBase::getName().

Here is the call graph for this function:

◆ update()

bool ElementBase::update ( const AttributeSet set)
inherited

Update element.

Definition at line 258 of file ElementBase.cpp.

References AttributeSet::begin(), AttributeSet::end(), and ElementBase::setAttribute().

Referenced by Monitor::driftToCorrectPositionAndSave().

Here is the call graph for this function:

Member Data Documentation

◆ actionRange_m

std::queue<std::pair<double, double> > ElementBase::actionRange_m
privateinherited

◆ amplitudeName_m

std::string VariableRFCavity::amplitudeName_m
protected

Definition at line 216 of file VariableRFCavity.h.

Referenced by initialise(), initNull(), operator=(), and setAmplitudeName().

◆ amplitudeTD_m

std::shared_ptr<AbstractTimeDependence> VariableRFCavity::amplitudeTD_m
protected

◆ aperture_m

◆ bgeometry_m

◆ csTrafoGlobal2Local_m

◆ defaultAperture_m

const std::vector< double > Component::defaultAperture_m
staticprotectedinherited
Initial value:
=
std::vector<double>({1e6, 1e6, 1.0})

Definition at line 187 of file Component.h.

Referenced by Component::Component().

◆ deleteOnTransverseExit_m

bool ElementBase::deleteOnTransverseExit_m = true
privateinherited

◆ elemedgeSet_m

bool ElementBase::elemedgeSet_m
privateinherited

◆ elementEdge_m

double ElementBase::elementEdge_m
protectedinherited

◆ elementID

std::string ElementBase::elementID
privateinherited

Definition at line 381 of file ElementBase.h.

Referenced by ElementBase::getName(), and ElementBase::setName().

◆ elementPosition_m

double ElementBase::elementPosition_m
privateinherited

ELEMEDGE attribute.

Definition at line 396 of file ElementBase.h.

Referenced by ElementBase::getElementPosition(), and ElementBase::setElementPosition().

◆ elementTypeToString_s

const std::map< ElementType, std::string > ElementBase::elementTypeToString_s
staticprivateinherited

Definition at line 383 of file ElementBase.h.

Referenced by ElementBase::getTypeString().

◆ exit_face_slope_m

double Component::exit_face_slope_m
protectedinherited

Definition at line 189 of file Component.h.

Referenced by Component::setExitFaceSlope().

◆ frequencyCache_m

TimeDependenceCache VariableRFCavity::frequencyCache_m
protected

Definition at line 221 of file VariableRFCavity.h.

Referenced by apply(), and setFrequencyModel().

◆ frequencyName_m

std::string VariableRFCavity::frequencyName_m
protected

Definition at line 217 of file VariableRFCavity.h.

Referenced by initialise(), initNull(), operator=(), and setFrequencyName().

◆ frequencyTD_m

std::shared_ptr<AbstractTimeDependence> VariableRFCavity::frequencyTD_m
protected

◆ geometry

StraightGeometry VariableRFCavity::geometry
protected

The cavity's geometry.

Definition at line 224 of file VariableRFCavity.h.

Referenced by getGeometry(), and setLength().

◆ halfHeight_m

double VariableRFCavity::halfHeight_m
protected

◆ halfWidth_m

double VariableRFCavity::halfWidth_m
protected

◆ length_m

double VariableRFCavity::length_m
protected

◆ misalignment_m

CoordinateSystemTrafo ElementBase::misalignment_m
protectedinherited

Definition at line 367 of file ElementBase.h.

Referenced by ElementBase::getMisalignment(), and ElementBase::setMisalignment().

◆ online_m

◆ outputfn_m

std::string ElementBase::outputfn_m
privateinherited

The name of the outputfile.

Definition at line 401 of file ElementBase.h.

Referenced by ElementBase::getOutputFN(), and ElementBase::setOutputFN().

◆ parmatint_m

◆ phaseName_m

std::string VariableRFCavity::phaseName_m
protected

Definition at line 215 of file VariableRFCavity.h.

Referenced by initialise(), initNull(), operator=(), and setPhaseName().

◆ phaseTD_m

std::shared_ptr<AbstractTimeDependence> VariableRFCavity::phaseTD_m
protected

◆ positionIsFixed

bool ElementBase::positionIsFixed
privateinherited

◆ refCount

int RCObject::refCount
mutableprivateinherited

◆ RefPartBunch_m

PartBunchBase<double, 3>* Component::RefPartBunch_m
protectedinherited

Definition at line 191 of file Component.h.

Referenced by Corrector::apply(), Undulator::apply(), VerticalFFAMagnet::apply(), Bend2D::apply(), Degrader::apply(), FlexibleCollimator::apply(), Monitor::apply(), Multipole::apply(), MultipoleT::apply(), RBend3D::apply(), RFCavity::apply(), SBend3D::apply(), ScalingFFAMagnet::apply(), Solenoid::apply(), Source::apply(), TravelingWave::apply(), apply(), VariableRFCavityFringeField::apply(), Cyclotron::apply(), Degrader::applyToReferenceParticle(), Monitor::applyToReferenceParticle(), BendBase::calcDesignRadius(), BendBase::calcFieldAmplitude(), BendBase::calcGamma(), Bend2D::calculateBendAngle(), Bend2D::calculateRefTrajectory(), Monitor::driftToCorrectPositionAndSave(), VerticalFFAMagnet::finalise(), MultipoleT::finalise(), Offset::finalise(), SBend3D::finalise(), ScalingFFAMagnet::finalise(), finalise(), RBend::findChordLength(), Bend2D::findIdealBendParameters(), Corrector::goOnline(), Degrader::goOnline(), Degrader::initialise(), PluginElement::initialise(), Vacuum::initialise(), Corrector::initialise(), Cyclotron::initialise(), Undulator::initialise(), VerticalFFAMagnet::initialise(), Drift::initialise(), FlexibleCollimator::initialise(), Marker::initialise(), Monitor::initialise(), Multipole::initialise(), MultipoleT::initialise(), Offset::initialise(), RBend3D::initialise(), RFCavity::initialise(), SBend3D::initialise(), ScalingFFAMagnet::initialise(), Solenoid::initialise(), Source::initialise(), TravelingWave::initialise(), initialise(), initNull(), Multipole::isFocusing(), MultipoleT::MultipoleT(), CCollimator::print(), FlexibleCollimator::print(), SBend3D::SBend3D(), ScalingFFAMagnet::ScalingFFAMagnet(), Corrector::setDesignEnergy(), Ring::setRefPartBunch(), Bend2D::setupPusher(), RFCavity::trackOnAxisParticle(), RBend3D::trackRefParticleThrough(), Vacuum::updateParticleAttributes(), and VerticalFFAMagnet::VerticalFFAMagnet().

◆ rotationZAxis_m

double ElementBase::rotationZAxis_m
protectedinherited

◆ shareFlag

bool ElementBase::shareFlag
mutableprotectedinherited

◆ userAttribs

AttributeSet ElementBase::userAttribs
privateinherited

Definition at line 386 of file ElementBase.h.

Referenced by ElementBase::getChannel(), and ElementBase::removeAttribute().

◆ wake_m

WakeFunction* ElementBase::wake_m
privateinherited

Definition at line 388 of file ElementBase.h.

Referenced by ElementBase::getWake(), ElementBase::hasWake(), and ElementBase::setWake().


The documentation for this class was generated from the following files: