49     "The \"MULTIPOLETCURVEDVARRADIUS\" element defines a combined function multipole.") {
 
   51                   (
"TP", 
"Transverse Profile derivatives in m^(-k)");
 
   53                   (
"LFRINGE", 
"The length of the left end field in m");
 
   55                   (
"RFRINGE", 
"The length of the right end field in m");
 
   57                   (
"HAPERT", 
"The aperture width in m");
 
   59                   (
"VAPERT", 
"The aperture height in m");
 
   61                   (
"ANGLE", 
"The azimuthal angle of the magnet in ring (rad)");
 
   63                   (
"EANGLE", 
"The entrance angle (rad)");
 
   66                    "Number of terms used in each field component");
 
   69                    "Number of terms used in polynomial expansions");
 
   72                    "Rotation angle about its axis for skew elements (rad)");
 
   75                    "Distance between centre of magnet and entrance in m");
 
  123     const std::vector<double> transProfile =
 
  125     std::size_t transSize = transProfile.size();
 
  127     if (transSize == 0) {
 
  145     for(std::size_t comp = 0; comp < transSize; comp++) {
 
Attribute makeReal(const std::string &name, const std::string &help)
Make real attribute. 
void setTransMaxOrder(const std::size_t &transMaxOrder)
item[EANGLE] Entrance edge angle(radians).\item[ROTATION] Rotation of the magnet about its central axis(radians
virtual void print(std::ostream &) const 
Print the object. 
std::vector< double > getRealArray(const Attribute &attr)
Get array value. 
Attribute makeRealArray(const std::string &name, const std::string &help)
Create real array attribute. 
virtual void setBendAngle(const double &angle) override
void setTransProfile(const std::size_t &n, const double &Bn)
void setElement(ElementBase *)
Assign new CLASSIC element. 
void setAperture(const double &vertAp, const double &horizAp)
VarRadiusGeometry & getGeometry() override
virtual void setMaxOrder(const std::size_t &maxOrder) override
void setEntranceAngle(const double &entranceAngle)
void setLength(const double &length)
ElementBase * getElement() const 
Return the embedded CLASSIC element. 
void setRotation(const double &rot)
virtual ~OpalMultipoleTCurvedVarRadius()
std::vector< Attribute > itsAttr
The object attributes. 
void setMaxXOrder(const std::size_t &maxXOrder)
OpalMultipoleTCurvedVarRadius()
double getReal(const Attribute &attr)
Return real value. 
virtual void setElementLength(double length)
Set design length. 
bool setFringeField(const double &s0, const double &lambda_left, const double &lambda_right)
void setBoundingBoxLength(const double &boundingBoxLength)
virtual void updateUnknown(ElementBase *)
Transmit the ``unknown'' (not known to OPAL) attributes to CLASSIC. 
void print(std::ostream &os) const 
Print the object. 
virtual void update()
Update the embedded CLASSIC element. 
void registerOwnership() const 
virtual OpalMultipoleTCurvedVarRadius * clone(const std::string &name)