Class Quadrupole
java.lang.Object
org.scictrl.mp.orbitcorrect.model.optics.AbstractDataBushElement
org.scictrl.mp.orbitcorrect.model.optics.AbstractOpticalElement
org.scictrl.mp.orbitcorrect.model.optics.AbstractTransferElement
org.scictrl.mp.orbitcorrect.model.optics.AbstractMagnetElement
org.scictrl.mp.orbitcorrect.model.optics.AbstractCalibratedMagnet
org.scictrl.mp.orbitcorrect.model.optics.Quadrupole
- All Implemented Interfaces:
Cloneable
,ISimpleElement
,AbstractUpdateableElement
,IApplyableElement
Quadrupole
is magnetic element that holds mainly quadrupole strength.- Author:
- igor@scictrl.com
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
ConstantPR_QUADRUPOLE_STRENGTH=8
Fields inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractCalibratedMagnet
calc, calibrationEntry, current, dataInvalidated, PR_CALIBRATION_ENTRY
Fields inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractMagnetElement
PR_POWER_SUPPLY, psH
Fields inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractTransferElement
length, matrices, matrix, PR_LENGTH
Fields inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractOpticalElement
PR_POSITION, PR_REL_FROM, PR_REL_POSITION
Fields inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractDataBushElement
lastActionResult, owner, PR_ELEMENT_NAME, PR_VIRTUAL
-
Constructor Summary
ConstructorDescriptionQuadrupole
(String name) ConstructsQuadrupole
with specified name and default parameter's values.Quadrupole
(String name, boolean virtual, double position, double relpos, String relFrom, double length, String ps, String calibrationEntry, double quadrupoleStrength) Constructs theQuadrupole
with specified parameters. -
Method Summary
Modifier and TypeMethodDescriptionint
This method sends current toPowerSupply
clone()
Returns the clone of this element.Returns the descriptor object for this element.int
elType()
Returns the code of element's type.This method returnsIMagnetCalculatorModel
.double
This method returns maximal quadrupole strength, which can be achived.double
This method returns minimal quadrupole strength, which can be achived.double
This method returns quadrupole strength.This method return transfer matrix of drift with the same length as this element.newMatrix
(double length) This method return transfer matrix of drift with the specified length.void
setCurrent
(double value) This method sets current on this element.void
setQuadrupoleStrength
(double value) This method sets quadrupole strength.void
Sets parameters values of this element to those in parameter array.toString()
Returns the string representation of this element.int
update()
Reads value from associated element or Abean and calculates it's new values.Methods inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractCalibratedMagnet
getCalibrationEntry, getCurrent, invalidateData, isDataInvalidated, updateMatrices
Methods inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractMagnetElement
getPowerSupply, getPS
Methods inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractTransferElement
getAlpha1, getAlpha2, getBeta1, getBeta2, getDispersion1, getDispersion2, getLength, getMatrix, getQ1, getQ2, setLength
Methods inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractOpticalElement
getAlpha, getBeta, getDispersion, getIndex, getPosition, getQ, getRelFrom, getRelPosition, setPosition, setRelFrom, setRelPosition
Methods inherited from class org.scictrl.mp.orbitcorrect.model.optics.AbstractDataBushElement
equals, getLastActionResult, getName, getOwner, getVirtual, hashCode, isInitialized, isVirtual, setVirtual, throwISE
-
Field Details
-
PR_QUADRUPOLE_STRENGTH
public static final int PR_QUADRUPOLE_STRENGTHConstantPR_QUADRUPOLE_STRENGTH=8
- See Also:
-
-
Constructor Details
-
Quadrupole
ConstructsQuadrupole
with specified name and default parameter's values.- Parameters:
name
- aString
name of quadrupole
-
Quadrupole
public Quadrupole(String name, boolean virtual, double position, double relpos, String relFrom, double length, String ps, String calibrationEntry, double quadrupoleStrength) Constructs theQuadrupole
with specified parameters.
-
-
Method Details
-
applyField
This method sends current toPowerSupply
- Returns:
int
indicate if method succeded- Throws:
IllegalStateException
- if any.
-
clone
Returns the clone of this element. Returns not initialized clone of this element. All data is copied to the clone. Returns not initialized clone of this element. All data is copied to the clone.clone.
clone.
- Specified by:
clone
in interfaceISimpleElement
- Overrides:
clone
in classAbstractTransferElement
- Returns:
- a
Object
the clone of this element. - See Also:
-
descriptor
Returns the descriptor object for this element.DBElementDescriptor
helps manipulating DataBush elements dynamically.descriptor.
- Specified by:
descriptor
in classAbstractDataBushElement
- Returns:
- the descriptor object for this element.
- See Also:
-
elType
public int elType()Returns the code of element's type.elType.
- Specified by:
elType
in classAbstractDataBushElement
- Returns:
- the code of element's type.
- See Also:
-
getCalculator
This method returnsIMagnetCalculatorModel
.- Returns:
- a
IMagnetCalculatorModel
object - See Also:
-
getMaxQuadrupoleStrength
This method returns maximal quadrupole strength, which can be achived. It depends of maximal current.- Returns:
- a double
- Throws:
ControlSystemException
- if any.
-
getMinQuadrupoleStrength
This method returns minimal quadrupole strength, which can be achived. It depends of minimal current.- Returns:
- a double
- Throws:
ControlSystemException
- if any.
-
getQuadrupoleStrength
public double getQuadrupoleStrength()This method returns quadrupole strength.- Returns:
- a double
-
newMatrix
This method return transfer matrix of drift with the same length as this element. This method return transfer matrix, calculated with current length, quadrupole strength and radius.- Overrides:
newMatrix
in classAbstractTransferElement
- Returns:
- a
TransferMatrix
object - See Also:
-
newMatrix
This method return transfer matrix of drift with the specified length. This method return transfer matrix, calculated with current quadrupole strength, radius and as parameter specified length.- Overrides:
newMatrix
in classAbstractTransferElement
- Parameters:
length
- a double- Returns:
- a
TransferMatrix
object - See Also:
-
setCurrent
public void setCurrent(double value) This method sets current on this element. This method sets current.- Overrides:
setCurrent
in classAbstractCalibratedMagnet
- Parameters:
value
- a double
-
setQuadrupoleStrength
public void setQuadrupoleStrength(double value) This method sets quadrupole strength.ICalculatorModelFactory
calculate necessary current and this method sets it.- Parameters:
value
- a double
-
setWith
Sets parameters values of this element to those in parameter array. As parameter must be used such array as for dynamical construction of new instance of this class. Current values are overriden for each notnull
object in array.setWith.
setWith.
setWith.
setWith.
setWith.
- Overrides:
setWith
in classAbstractCalibratedMagnet
- Parameters:
par
- an array ofObject
objects- Throws:
IllegalStateException
- if element is initialized and inside DataBush.- See Also:
-
toString
Returns the string representation of this element. Returns string describing this element. String is formated in input-file code. Returns a String that represents the value of this object.toString.
toString.
toString.
toString.
- Specified by:
toString
in interfaceISimpleElement
- Overrides:
toString
in classAbstractCalibratedMagnet
- See Also:
-
update
Reads value from associated element or Abean and calculates it's new values. Metod reads data from other databush elements or from remote devices represented with Abean. Metod also checksisDataInvalidated()
on depending databush elements, if value has changed. Return value is identification code of error. Note! Update is performed only if virtual flag is set tofalse
. Note! All update methods are synchronized, so only one update is called at time. For update od group of elements call update on appropriate element-list or DataBush. This method reads energy fromPowerSupply
and transform it to magnetic properties of this element.- Returns:
- a int the return code indicating success
- Throws:
IllegalStateException
- thrown if status of DataBush equalsDB_EMPTY
DataBushPackedException
- contains all exception thrown or caught during updating element
-