34 "The \"CYCLOTRON\" defines an cyclotron"),
37 (
"CYHARMON",
"the harmonic number of the cyclotron");
40 (
"SYMMETRY",
"defines how the field is stored");
43 (
"RINIT",
"Initial radius of the reference particle [mm]");
46 (
"PRINIT",
"Initial radial momentum of the reference particle, pr = beta_r * gamma");
49 (
"PHIINIT",
"Initial azimuth of the reference particle [deg]");
52 (
"ZINIT",
"Initial z-coordinate of the reference particle [mm]. Default = 0 mm", 0.0);
55 (
"PZINIT",
"Initial vertical momentum of the reference particle pz = beta_z * gamma. Default = 0", 0.0);
58 (
"FMAPFN",
"Filename for the B fieldmap");
61 (
"BSCALE",
"Scale factor for the B-field", 1.0);
64 (
"RFFREQ",
"RF Frequency(ies) [MHz]");
67 (
"ESCALE",
"Scale factor for the RF field(s)");
70 (
"SUPERPOSE",
"If TRUE, all of the electric field maps are superposed, only used when TYPE = BANDRF");
73 (
"RFMAPFN",
"Filename(s) for the RF fieldmap(s)");
76 (
"RFFCFN",
"Filename(s) for the RF Frequency Coefficients");
79 (
"RFVCFN",
"Filename(s) for the RF Voltage Coefficients");
82 (
"RFPHI",
"Initial phase(s) of the electric field map(s) [deg]");
85 (
"MINZ",
"Minimal vertical extent of the machine [mm]",-10000.0);
88 (
"MAXZ",
"Maximal vertical extent of the machine [mm]",10000.0);
91 (
"MINR",
"Minimal radial extent of the machine [mm]", 0.0);
94 (
"MAXR",
"Maximal radial extent of the machine [mm]", 10000.0);
97 (
"GEOMETRY",
"Boundary Geometry for the Cyclotron");
100 (
"FMLOWE",
"Minimal Energy [GeV] the fieldmap can accept. Used in GAUSSMATCHED", -1.0);
103 (
"FMHIGHE",
"Maximal Energy [GeV] the fieldmap can accept. Used in GAUSSMATCHED", -1.0);
106 (
"SPIRAL",
"Flag whether or not this is a spiral inflector simulation",
false);
109 (
"TRIMCOILTHRESHOLD",
"Minimum magnetic field [T] for which trim coils are applied", 0.0);
112 (
"TRIMCOIL",
"List of trim coils");
199 if ( !trimcoil.empty() ) {
201 std::vector<TrimCoil* > trimcoils;
203 for (std::vector<std::string>::const_iterator tit = trimcoil.begin();
204 tit != trimcoil.end(); ++tit)
Attribute makeBool(const std::string &name, const std::string &help)
Make logical attribute.
double getReal(const Attribute &attr)
Return real value.
Attribute makeStringArray(const std::string &name, const std::string &help)
Create a string array attribute.
Attribute makeReal(const std::string &name, const std::string &help)
Make real attribute.
std::vector< bool > getBoolArray(const Attribute &attr)
Get logical array value.
bool getBool(const Attribute &attr)
Return logical value.
Attribute makeRealArray(const std::string &name, const std::string &help)
Create real array attribute.
std::vector< double > getRealArray(const Attribute &attr)
Get array value.
std::vector< std::string > getStringArray(const Attribute &attr)
Get string array value.
std::string getString(const Attribute &attr)
Get string value.
Attribute makeBoolArray(const std::string &name, const std::string &help)
Create a logical array attribute.
Attribute makeString(const std::string &name, const std::string &help)
Make string attribute.
boost::function< boost::tuple< double, bool >arguments_t)> type
ElementBase * getElement() const
Return the embedded CLASSIC element.
void setElement(ElementBase *)
Assign new CLASSIC element.
std::vector< Attribute > itsAttr
The object attributes.
void setTrimCoilThreshold(double)
void setZinit(double zinit)
void setSpiralFlag(bool spiral_flag)
void setSuperpose(std::vector< bool > flag)
void setCyclotronType(std::string t)
void setRfPhi(std::vector< double > f)
void setRFVCoeffFN(std::vector< std::string > rfv_coeff_fn)
void setPZinit(double zinit)
void setEScale(std::vector< double > bs)
void setSymmetry(double symmetry)
void setTrimCoils(const std::vector< TrimCoil * > &trimcoils)
void setCyclHarm(double h)
void setPHIinit(double phiinit)
void setRfFrequ(std::vector< double > f)
void setPRinit(double prinit)
void setRfFieldMapFN(std::vector< std::string > rffmapfn)
void setFMHighE(double e)
void setRinit(double rinit)
void setFieldMapFN(std::string fmapfn)
void setRFFCoeffFN(std::vector< std::string > rff_coeff_fn)
void setBScale(double bs)
virtual void setBoundaryGeometry(BoundaryGeometry *geo)
void setOutputFN(std::string fn)
Set output filename.
static OpalTrimCoil * find(const std::string &name)
Find named trim coil.
std::unique_ptr< TrimCoil > trimcoil_m
Actual implementation.
void initOpalTrimCoil()
Initialise implementation.
virtual void update()
Update the embedded CLASSIC cavity.
BoundaryGeometry * obgeo_m
virtual OpalCyclotron * clone(const std::string &name)
Make clone.
virtual void updateUnknown(ElementBase *)
Transmit the `‘unknown’' (not known to OPAL) attributes to CLASSIC.
void registerOwnership() const
static BoundaryGeometry * find(const std::string &name)