Base package for NICOS commands.
Decorator that marks a function as a user command.
Wrap a function as a user command.
This is not done in the “usercommand” decorator since the function should stay usable as a regular function from nicos code.
Module for data analyzing user commands.
Move the given device to the maximum of a Gaussian fit through a scan around center with the given parameters.
This supports all arguments and keyword arguments that cscan() supports, and additionally a keyword “ycol” that gives the Y column of the dataset to use for the Gaussian fit (see the help for gauss() for the meaning of this parameter).
Calculate the center of mass x-coordinate of the last scan. The data columns to use can be given by the arguments: either only the Y column, or both X and Y columns. If they are not given, then the default X column is the first, and the default Y column is the first column of type “counter”. Examples:
center_of_mass() # use first X column and first counter Y column
center_of_mass(2) # use first X column and second Y column
center_of_mass(2, 3) # use second X column and third Y column
It is also possible to give columns by name, for example:
center_of_mass('om', 'ctr1')
Readjust offset of the given device, so that the center of the given scan coincides with the center of a Gaussian fit.
This supports all arguments and keyword arguments that cscan() supports, and additionally a keyword “ycol” that gives the Y column of the dataset to use for the Gaussian fit (see the help for gauss() for the meaning of this parameter).
Calculate an estimate of full width at half maximum.
The search starts a the ‘left’ end of the data.
Returns a tuple (fwhm, xpeak, ymax, ymin):
The data columns to use can be given by the arguments: either only the Y column, or both X and Y columns. If they are not given, then the default X column is the first, and the default Y column is the first column of type “counter”. Examples:
fwhm() # use first X column and first counter Y column
fwhm(2) # use first X column and second Y column
fwhm(2, 3) # use second X column and third Y column
It is also possible to give columns by name, for example:
fwhm('om', 'ctr1')
Fit a Gaussian through the data of the last scan.
The return value is a pair of tuples:
((x0, ampl, sigma, background), (d_x0, d_ampl, d_sigma, d_back))
where the elements of the second tuple are the estimated standard errors of the fit parameters. The fit parameters are:
The data columns to use can be given by the arguments: either only the Y column, or both X and Y columns. If they are not given, then the default X column is the first, and the default Y column is the first column of type “counter”. Examples:
gauss() # use first X column and first counter Y column
gauss(2) # use first X column and second Y column
gauss(2, 3) # use second X column and third Y column
It is also possible to give columns by name, for example:
gauss('om', 'ctr1')
Fit a polynomial of degree n through the last scan.
The return value is a pair of tuples:
(coefficients, coeff_errors)
where both coefficients and coeff_errors are tuples of n+1 elements.
The data columns to use can be given by the arguments: either only the Y column, or both X and Y columns. If they are not given, then the default X column is the first, and the default Y column is the first column of type “counter”. Examples:
poly(2, ) # use first X column and first counter Y column
poly(2, 2) # use first X column and second Y column
poly(2, 2, 3) # use second X column and third Y column
It is also possible to give columns by name, for example:
poly(2, 'om', 'ctr1')
Calculate the root-mean-square of the last scan.
The data column to use can be given by an argument (by name or number); the default is the first Y column of type “counter”.
Module for basic user commands.
Load the given setups additional to the current one.
Example:
AddSetup('gaussmeter')
will load the “gaussmeter” setup in addition to the current setups.
Add a new user to the experiment.
Clear all cached information for the given device(s).
This can be used when a device has been reconfigured in the setup and all parameters should be read from the setup file on the next loading of the setup. Example:
ClearCache('om', 'phi')
NewSetup()
will clear cache information for devices “om” and “phi” and then reload the current setup.
Create all devices in the current setup that are not marked as lowlevel devices.
This is useful when a setup failed to load many devices, and another attempt should be made.
Create all given devices.
Example:
CreateDevice('stx', 'sty', 'stz')
Destroy all given devices.
Example:
DestroyDevice('stx', 'sty', 'stz')
Edit the script file given by file name. If the file name is not absolute, it is relative to the experiment script directory.
The editor is given by the EDITOR environment variable.
Finish the current experiment.
Which parameters are accepted depends on the individual instrument.
Export the given obj into the NICOS namespace under the name.
This makes the given name read-only, so that the object cannot be overwritten by accident.
Print a list of all known setups.
Attach one or more files to the electronic logbook.
The file paths must be accessible from the machine on which the electronic logbook daemon runs (i.e. on a common network share). They will be renamed using the given names, if given, otherwise the current names are used.
Examples:
LogAttach('quick fit of peak', '/tmp/peakfit.png', 'peak_100.png')
LogAttach('calibrations', ['/tmp/cal1.dat', '/tmp/cal2.dat'])
Make a free-form entry in the electronic logbook.
The entry will be processed as Creole markup.
Note: on the command line, you can also call this function by entering a Python comment. I.e., these two commands are equivalent at the command line:
>>> LogEntry('improved sample holder')
>>> # improved sample holder
Start a new experiment with the given proposal number and title.
You can also give a argument for the local contact. Users can be added with AddUser. Example:
>>> NewExperiment(5401, 'Dynamics of H2O', 'L. Ocal Contact')
>>> AddUser('F. User', 'friendlyuser@frm2.tum.de')
When configured, proposal information will be automatically filled in from the proposal database.
Start a new sample with the given sample name.
Which other parameters can be given depends on the parameters of the sample object. For example, for TAS samples, the following command is valid:
NewSample('Cr', lattice=[2.88, 2.88, 2.88], angles=[90, 90, 90])
Load the given setups instead of the current one. Without arguments, the current setups are reloaded.
Example:
NewSetup('tas', 'psd')
will clear the current setup and load the “tas” and “psd” setups at the same time.
Send a message via email and/or SMS to the receivers selected by SetMailReceivers() and SetSMSReceivers(). Usage is one of these two:
Notify('some text')
Notify('subject', 'some text')
Change the remark about instrument configuration saved to the data files.
Add a message to remember at the next experiment change using FinishExperiment or NewExperiment.
Remove the given setups from the currently loaded ones.
Example:
RemoveSetup('gaussmeter')
will re-load all current setups except for “gaussmeter”.
Run a script file given by file name. If the file name is not absolute, it is relative to the experiment script directory.
Save the whole current setup as a file usable in simulation mode.
Set a list of email addresses that will be notified on unhandled errors, and when the Notify() command is used.
Set the execution mode.
Valid modes are: master, slave, simulation, maintenance
Set a list of mobile phone numbers that will be notified on unhandled errors, and when the Notify() command is used.
Note that all those phone numbers have to be registered with the IT department before they can be used.
Run code or a script file in simulation mode. If the file name is not absolute, it is relative to the experiment script directory.
For script files, position statistics will be collected for the given list of devices:
Simulate('test', T)
will simulate the ‘test.py’ user script and print out minimum/maximum/ last value of T during the run.
Example running code:
Simulate('move(mono, 1.55); read(mtt)')
Return an object for use in “with” that adds status information. It can be used like this:
with UserInfo('Qscan around (1,1,0)'):
qscan(...)
Show all public attributes for the given object.
Show help for a command, for a device or for any other object.
For commands, the command help and usage will be shown. For devices, the device help, parameters and special commands will be shown.
List all available commands.
Sleep for a given number of seconds.
This is different from Python’s time.sleep() in that it allows breaking and stopping the sleep, and supports simulation mode.
Module for simple device-related user commands.
Adjust the offset of the device.
There are two ways to call this function:
Examples:
>>> adjust(om, 100) # om's current value is now 100
>>> adjust(om, 99, 100) # what was om = 99 before is now om = 100
“dev” must be a device that supports the “offset” parameter.
Move one or more devices to a new position. Same as move().
This can be used with multiple devices like this:
drive(dev1, pos1, dev2, pos2, ...)
Fix a device, i.e. prevent movement until release() is called.
You can give a reason that is displayed when movement is attempted. Example:
fix(phi, 'will drive into the wall')
Return the value of a parameter of the device.
Print history of a device parameter.
The optional argument key selects a parameter of the device. “value” is the main value, and “status” is the device status.
fromtime and totime are UNIX timestamps, or negative numbers giving hours in the past. The default is to list history of the last hour for “value” and “status”, or from the last day for other parameters. For example:
>>> history(mth) # show value of mth in the last hour
>>> history(mth, -48) # show value of mth in the last two days
>>> history(mtt, 'offset') # show offset of mth in the last day
Print the limits of the device(s).
List the given parameters for all existing devices that have them.
Example:
listallparams('offset')
lists the offset for all devices with an “offset” parameter.
List all currently created devices.
List user-callable methods for the device.
List all parameters of the device.
Move one or more devices to a new position and wait until motion of all devices is completed.
This can be used with multiple devices like this:
maw(dev1, pos1, dev2, pos2, ...)
Move one or more devices to a new position.
This can be used with multiple devices like this:
move(dev1, pos1, dev2, pos2, ...)
Read the position (or value) of one or more devices.
If no device is given, read all readable devices.
Reset the given device(s).
Reset the user limits for the device(s) to the absolute limits.
Set a the parameter of the device to a new value.
Read the status of one or more devices.
If no device is given, read the status of all readable devices.
Stop one or more devices.
If no device is given, stop all stoppable devices in parallel.
Move one or more devices to a new position and wait until motion of all devices is completed. Same as maw().
This can be used with multiple devices like this:
switch(dev1, pos1, dev2, pos2, ...)
List version info of the device(s).
Wait until motion of one or more devices is complete, or device is out of “busy” status. A time in seconds can also be used to wait the given number of seconds.
Example:
wait(T, 60)
waits for the T device, and then another 60 seconds.
Module for measuring user commands.
Add the specified detector device(s) to the standard detectors.
Add the specified environment device(s) to the standard environment.
List the standard detectors.
List the standard environment devices.
Select the detector device(s) to read out when calling scan() or count().
Examples:
SetDetectors(det) # to use the "det" detector
SetDetectors(det, psd) # to use both the "det" and "psd" detectors
Select the device(s) to read out as “experiment environment” at every step of a scan.
Examples:
SetEnvironment(T, B) # to read out T and B devices
SetEnvironment() # to read out no additional devices
Perform a single counting.
With preset arguments, this preset is used instead of the default preset.
With detector devices as arguments, these detectors are used instead of the default detectors set with SetDetectors().
Within a manual scan, perform the count as one step of the manual scan.
Examples:
count() # count once with the default preset and detectors
count(t=10) # count once with time preset of 10 seconds
count(psd, t=10) # count 10 seconds with the psd detector
Set a new default preset for the currently selected detectors.
The arguments that are accepted depend on the detectors.
Examples:
preset(t=10) # sets a time preset of 5 seconds
preset(m1=5000) # sets a monitor preset of 5000 counts, for detectors
# that support monitor presets
Module for output/logging user commands.
Print a debug message.
Print an error message.
Print an error message, and add info about the last exception.
Print a message.
Print a warning message.
Scan commands for NICOS.
Go on numsteps steps from the end of the last scan.
Scan a device continuously with low speed.
If the “speed” is not explicitly given, it is set to 1/5 of the normal speed of the device.
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
contscan(dev, ..., det1, det2)
Scan around center.
The general syntax is to give center, step and number of steps per side:
cscan(dev, 0, 1, 5) # scans from -5 to 5 in steps of 1.
The total number of steps is (2 * numperside) + 1.
The device can also be a list of devices that should be moved for each step. In this case, the start and stepwidth also have to be lists:
cscan([dev1, dev2], [0, 0], [0.5, 1], 10)
This also works for the second basic syntax:
cscan([dev1, dev2], [[0, 1, 2, 3], [0, 2, 4, 6]])
Presets can be given using keyword arguments:
cscan(dev, ..., t=5)
cscan(dev, ..., mon1=1000)
An info string describing the scan can be given as a string argument:
cscan(dev, ..., 'peak search', ...)
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
cscan(dev, ..., det1, det2)
Other devices that should be recorded at every point (so-called environment devices) are by default those selected by SetEnvironment(). They can also be overridden by giving them as arguments:
cscan(dev, ..., T1, T2)
Any devices can be moved to different positions before the scan starts. This is done by giving them as keyword arguments:
cscan(dev, ..., ki=1.55)
A similar syntax can be used to count multiple times per scan point, with one or more devices at different positions:
cscan(dev, ..., pol=['up', 'down'])
will measure twice at every point: once with pol moved to ‘up’, once with pol moved to ‘down’.
“Manual” scan where no devices are moved automatically.
An example usage:
with manualscan(device, otherdevice):
for i in range(10):
if otherdevice.read() < 15:
raise NicosError('cannot continue')
maw(device, i+1)
count(t=600)
This example mimicks a regular scan(), with the exception that before every point the value of another device is checked for validity.
The arguments to manualscan() can be are:
Within the with manualscan block, call count() (using the default preset) or count(presets...) whenever you want to measure a point.
Scan over device(s) and count detector(s).
The general syntax is either to give start, step and number of steps:
scan(dev, 0, 1, 11) # scans from 0 to 10 in steps of 1.
or a list of positions to scan:
scan(dev, [0, 1, 2, 3, 7, 8, 9]) # scans at the given positions.
The device can also be a list of devices that should be moved for each step. In this case, the start and stepwidth also have to be lists:
scan([dev1, dev2], [0, 0], [0.5, 1], 10)
This also works for the second basic syntax:
scan([dev1, dev2], [[0, 1, 2, 3], [0, 2, 4, 6]])
Presets can be given using keyword arguments:
scan(dev, ..., t=5)
scan(dev, ..., mon1=1000)
An info string describing the scan can be given as a string argument:
scan(dev, ..., 'peak search', ...)
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
scan(dev, ..., det1, det2)
Other devices that should be recorded at every point (so-called environment devices) are by default those selected by SetEnvironment(). They can also be overridden by giving them as arguments:
scan(dev, ..., T1, T2)
Any devices can be moved to different positions before the scan starts. This is done by giving them as keyword arguments:
scan(dev, ..., ki=1.55)
A similar syntax can be used to count multiple times per scan point, with one or more devices at different positions:
scan(dev, ..., pol=['up', 'down'])
will measure twice at every point: once with pol moved to ‘up’, once with pol moved to ‘down’.
Count a number of times without moving devices.
“numsteps” can be -1 to scan for unlimited steps (break to quit).
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
timescan(5, ..., det1, det2)
Other devices that should be recorded at every point (so-called environment devices) are by default those selected by SetEnvironment(). They can also be overridden by giving them as arguments:
timescan(5, ..., T1, T2)
Any devices can be moved to different positions before the scan starts. This is done by giving them as keyword arguments:
timescan(5, ..., ki=1.55)
A similar syntax can be used to count multiple times per scan point, with one or more devices at different positions:
timescan(5, ..., pol=['up', 'down'])
will measure twice at every point: once with pol moved to ‘up’, once with pol moved to ‘down’.
Two-dimensional scan of two devices.
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
twodscan(dev1, ..., det1, det2)
Other devices that should be recorded at every point (so-called environment devices) are by default those selected by SetEnvironment(). They can also be overridden by giving them as arguments:
twodscan(dev1, ..., T1, T2)
Any devices can be moved to different positions before the scan starts. This is done by giving them as keyword arguments:
twodscan(dev1, ..., ki=1.55)
A similar syntax can be used to count multiple times per scan point, with one or more devices at different positions:
twodscan(dev1, ..., pol=['up', 'down'])
will measure twice at every point: once with pol moved to ‘up’, once with pol moved to ‘down’.
TAS commands for NICOS.
Create a Q-E vector that can be used for calculations. Use:
To create a Q vector (1, 0, 0) with energy transfer 0 or 5:
q = Q(1)
q = Q(1, 0, 0)
q = Q(1, 0, 0, 5)
q = Q(h=1, E=5)
To create a Q vector from another Q vector, adjusting one or more entries:
q2 = Q(q, h=2, k=1)
q2 = Q(q, E=0)
You can then use the Q-E vectors in scanning commands:
qscan(q, q2, 5, t=10)
Check accidental Bragg scattering conditions for type A or type M at the given spectrometer position.
Print powder ray positions of Al.
Calculate instrument position for a given (Q, E) position.
Can be called with 3 to 5 arguments:
>>> calpos(1, 0, 0) # H, K, L
>>> calpos(1, 0, 0, -4) # H, K, L, E
>>> calpos(1, 0, 0, -4, 2.662) # H, K, L, E, scanconstant
or with a Q-E vector:
>>> calpos(Q(1, 0, 0, -4)) # Q-E vector
>>> calpos(Q(1, 0, 0, -4), 2.662) # Q-E vector and scanconstant
Print powder ray positions of Cu.
Calculation of elastic spurions due to higher order neutrons.
kf is the final wavevector to use for calculation. dEmin and dEmax are the minimum and maximum energy transfer to list.
Move the instrument to a given (Q, E) position, or without arguments to the last position calculated with calpos(). Examples:
>>> pos() # last calpos() position
>>> pos(1, 0, 0) # H, K, L
>>> pos(1, 0, 0, -4) # H, K, L, E
>>> pos(1, 0, 0, -4, 2.662) # H, K, L, E, scanconstant
>>> pos(Q(1, 0, 0, -4)) # Q-E vector
>>> pos(Q(1, 0, 0, -4), 2.662) # Q-E vector and scanconstant
Calculate powder ray positions.
Centered Q scan.
The Q and dQ arguments can be lists of 3 or 4 components, or a Q object.
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
qcscan(Q, dQ, ..., det1, det2)
Other devices that should be recorded at every point (so-called environment devices) are by default those selected by SetEnvironment(). They can also be overridden by giving them as arguments:
qcscan(Q, dQ, ..., T1, T2)
Any devices can be moved to different positions before the scan starts. This is done by giving them as keyword arguments:
qcscan(Q, dQ, ..., ki=1.55)
A similar syntax can be used to count multiple times per scan point, with one or more devices at different positions:
qcscan(Q, dQ, ..., pol=['up', 'down'])
will measure twice at every point: once with pol moved to ‘up’, once with pol moved to ‘down’.
Single-sided Q scan.
The Q and dQ arguments can be lists of 3 or 4 components, or a Q object.
By default, the detectors are those selected by SetDetectors(). They can be replaced by a custom set of detectors by giving them as arguments:
qscan(Q, dQ, ..., det1, det2)
Other devices that should be recorded at every point (so-called environment devices) are by default those selected by SetEnvironment(). They can also be overridden by giving them as arguments:
qscan(Q, dQ, ..., T1, T2)
Any devices can be moved to different positions before the scan starts. This is done by giving them as keyword arguments:
qscan(Q, dQ, ..., ki=1.55)
A similar syntax can be used to count multiple times per scan point, with one or more devices at different positions:
qscan(Q, dQ, ..., pol=['up', 'down'])
will measure twice at every point: once with pol moved to ‘up’, once with pol moved to ‘down’.
Read the current (Q, E) position.