Units are a set of small classes in Mantid that define a unit of measure, and the conversions between various units.
The Unit Factory is a Dynamic Factory that creates and hands out instances of Mantid Unit objects.
The following units are available in the default Mantid distribution. These units are TOF convertible.
Name | ID (as known by Unit Factory) | Unit | Relevant equation |
---|---|---|---|
Time of flight | TOF | μs | TOF |
Wavelength | Wavelength | Å | λ=hp=h×tofmN×Ltot (see below) |
Energy | Energy | meV | E=12mv2=mN2(Ltottof)2 |
Energy in wavenumber | Energy_inWavenumber | cm−1 | 8.06554465×E |
Momentum (k) | Momentum | Å−1 | k=2πλ=2π×mN×Ltoth×tof |
d-spacing | dSpacing | Å | TOF=DIFAd2+DIFCd+TZERO (see below) |
Momentum transfer (Q) | MomentumTransfer | Å−1 | Q=2ksinθ=4πsinθλ |
Momentum transfer squared (Q2) | QSquared | Å−2 | Q2 |
Energy transfer | DeltaE | meV | ΔE=Ei−12mN(L2tof−L1√mN2Ei)2 |
Energy transfer in wavenumber | DeltaE_inWavenumber | cm−1 | 8.06554465×ΔE |
Spin Echo Length | SpinEchoLength | nm | constant×λ2
The constant is supplied in eFixed
|
Spin Echo Time | SpinEchoTime | ns | constant×λ3
The constant is supplied in eFixed
|
d-spacingPerpendicular | dSpacingPerpendicular | Å | d⊥=√λ2−2logcosθ |
Where L1 and L2 are sample to the source and sample to detector distances respectively, Ltot=L1+L2 and Ei is the energy of neutrons leaving the source. θ here is the Bragg scattering angle (e.g. half of the θ-angle used in spherical coordinate system directed along Mantid z-axis)
Note on Wavelength: If the emode property in ConvertUnits is specified as inelastic Direct/Indirect (inelastic) then the conversion to wavelength will take into account the fixed initial/final energy respectively. Units conversion into elastic momentum transfer (MomentumTransfer) will throw in elastic mode (emode=0) on inelastic workspace (when energy transfer is specified along x-axis)
Note on d-spacing: The coefficients DIFA, DIFC and TZERO may be obtained via calibration of a TOF diffraction instrument. In the absence of a calibration, DIFA=TZERO=0 and the default value of DIFC is:
DIFC=10−4mNh(L1+L2)2sin(θ)
where the scaling factor adjusts for the fact that DIFC is required in units of μs per Å.
d-spacingPerpendicular is a unit invented in J. Appl. Cryst. (2015) 48, pp. 1627–1636 for 2D Rietveld refinement of angular and wavelength-dispersive neutron time-of-flight powder diffraction data. Together with the d-Spacing d, d-SpacingPerpendicular d⊥ forms a new orthogonal coordinate system.
The following units are available in the default Mantid distribution. These units cannot be converted to or from TOF.
Name | ID (as known by Unit Factory) | Unit | Description |
---|---|---|---|
Empty | No unit | An empty label | |
t | Time | s | An independent unit of time not related to energy or TOF |
Scattering angle | Degrees | degrees | Degrees is a measurement of angular position |
Temperature | Temperature | K | Temperature in Kelvin |
Units on MatrixWorkspaces are accessed via the Axis.
ws = CreateSampleWorkspace()
for i in range(ws.axes()):
axis = ws.getAxis(i)
print("Axis {0} is a {1}{2}{3}".format(i,
"Spectrum Axis" if axis.isSpectra() else "",
"Text Axis" if axis.isText() else "",
"Numeric Axis" if axis.isNumeric() else ""))
unit = axis.getUnit()
print("\t caption:{0}".format(unit.caption()))
print("\t symbol:{0}".format(unit.symbol()))
Output:
Axis 0 is a Numeric Axis
caption:Time-of-flight
symbol:microsecond
Axis 1 is a Spectrum Axis
caption:Spectrum
symbol:
ws = CreateSampleWorkspace()
axis = ws.getAxis(1)
# Create a new axis
axis.setUnit("Label").setLabel('Temperature', 'K')
unit = axis.getUnit()
print("New caption:{0}".format(unit.caption()))
print("New symbol:{0}".format(unit.symbol()))
Output:
New caption:Temperature
New symbol:K
Writing and adding a new unit is relatively straightforward. Instructions will appear here in due course. In the meantime if a unit that you require is missing, then please contact the development team and we will add it to the default Mantid library.
Category: Concepts