23 #include <boost/regex.hpp>
28 "The \"ECOLLIMATOR\" element defines an elliptic collimator."),
29 parmatint_m(nullptr) {
31 (
"XSIZE",
"Horizontal half-aperture in m");
33 (
"YSIZE",
"Vertical half-aperture in m");
43 parmatint_m(nullptr) {
72 description <<
"ellipse(" << width <<
"," << height <<
")";
Attribute makeReal(const std::string &name, const std::string &help)
Make real attribute.
std::string getString(const Attribute &attr)
Get string value.
virtual void setParticleMatterInteraction(ParticleMatterInteractionHandler *spys)
static ParticleMatterInteraction * find(const std::string &name)
Find named PARTICLEMATTERINTERACTION.
virtual ~OpalECollimator()
ParticleMatterInteraction * parmatint_m
SDDS1 &description description
void setElement(ElementBase *)
Assign new CLASSIC element.
void setOutputFN(std::string fn)
Set output filename.
void initParticleMatterInteractionHandler(ElementBase &element)
ElementBase * getElement() const
Return the embedded CLASSIC element.
virtual OpalECollimator * clone(const std::string &name)
Make clone.
void setDescription(const std::string &desc)
const std::string & getOpalName() const
Return object name.
std::vector< Attribute > itsAttr
The object attributes.
double getReal(const Attribute &attr)
Return real value.
ParticleMatterInteractionHandler * handler_m
virtual ParticleMatterInteraction * clone(const std::string &name)
Make clone.
virtual void setElementLength(double length)
Set design length.
OpalECollimator()
Exemplar constructor.
virtual void updateUnknown(ElementBase *)
Transmit the ``unknown'' (not known to OPAL) attributes to CLASSIC.
virtual void update()
Update the embedded CLASSIC collimator.
virtual void update()
Update the embedded CLASSIC element.
void registerOwnership() const