Autorun
This page is a reproduction of the content found at http://cmms.triumf.ca/howto/op/autobnmr.html. Though this is mainly to test the formatting of the markdown to html convension, I have made minor changes thoughout the text to improve readability.
Table of contents
Introduction
The automatic run control operates as a separate process, distinct from other data acquisition front- and back-ends, including the run-control user-interface. It should be started automatically, but if it is not, then one can execute:
The autorun server is controlled by a few parameters in the ODB, under /autorun
, but it is mostly controlled by the autorun plan file, which it monitors continuously for changes.
(The ODB is the MIDAS data acquisition system’s central storage of experiment parameters. It can be explored and edited using the odbedit
program or a web browser.)
Control Panel
The custom MIDAS web page for β-NMR and β-NQR experiments includes an area for controlling autorun parameters. (If there are problems setting parameters from the main control page, you may try to set them by navigating the ODB tree.)
Edit the plan file in your preferred text editor. Every time it is saved, the autorun program re-reads it.
If there are problems with the syntax of a plan file, the autorun processor usually only reports the first error it encounters. Check the MIDAS message log for error messages. There is also a stand-alone command, checkplan
or
(used as “checkplan filename [first_run]”) that performs checks on a plan file, useful for verifying a hand-edited plan. Nevertheless, the autorun processor may encounter some errors that the preliminary scan does not detect, so these checks will not completely replace a good proofread.
Control Parameters
There are a few parameters to set on the autorun control panel. Most of these are passed to the autorun processor through the MIDAS ODB (in the area /autorun
).
Autoruns Operation Enabled
ODB: /autorun/enable
, boolean (1/0)
Set this to control whether the autorun process operates at all. It does not actually shut down when disabled, but it checks only this parameter, waiting to be enabled again.
Autorun State
Autoruns status read-back.
ODB: /autorun/state
, int
The values are interpreted as:
Value | Status | Description |
---|---|---|
0 | disabled | Operation is not enabled |
1 | idle | Waiting for a plan |
2 | acquiring | Run is in progress and active |
3 | paused | Run is paused |
4 | ending | Ending a run |
5 | stopped | Run has ended |
6 | setting | Setting Camp variables |
7 | changing | Waiting for "requirements" |
8 | starting | Starting a new run |
9 | reload | Trigger reload of plan file |
Most state values are set by the autorun server, strictly for monitoring its progress, but a value of “reload” (9) may be set by other clients to force the autorun server to re-read the plan file, and perhaps resume processing after being “idle” (1); the Reload&Start button will trigger reloading this way. (The other way to force a reload is to modify the plan file itself, perhaps like touch plan.dat
.)
Plan file
Full file specification for the run plan.
ODB: /autorun/plan file
, string
The autorun processor watches this file for changes, and if any occur, it re-reads the run plan.
Pausing Runs
Enable/Disable run pausing.
ODB: /autorun/enable pausing
, boolean-int (1/0)
Tells the autoruns processor whether to keep checking requirements after starting a run, and to pause the run while requirements are not satisfied. See below for “Requirements” in an autorun plan. (A CAMP alarm with a hardware veto gives better response.)
Refresh Period
Cycle time of autorun processor.
ODB: /autorun/refresh seconds
, int
Tells how often the autorun processor checks status and looks for a new plan. Sensible values range from 5 to 30 seconds.
Target Cycles
Desired total cycles for TD/Type-2 runs.
ODB: /autorun/target cycles
, int
Tells how many frontend cycles to run for Type-2 modes. (This parameter applies to any runs, not just automatic runs.)
Target Counts
Desired total counts for TD/Type-2 runs.
ODB: /autorun/target counts
, int
Tells how many events to accumulate in histograms before ending the run. This number is reset for every run, according to the run plan setting (if that run has a Counts
setting in the plan), but it can be changed during the run to take more or less data.
Count Histogram
What “Target Counts” applies to.
ODB: /autorun/count histogram
, int
The “Target Counts” may be compared with the counts in any particular histogram or with the total of all histograms, as indicated by the “Count Histogram” setting. The first histogram is number 1. Enter zero or negative to use the total of all histograms.
Time Limit (minutes)
Maximum time before ending a run.
ODB: /autorun/time limit (minutes)
, float
You may enter the time limit in various formats, but the value will be displayed and saved as a number of minutes. Use a very high value or zero if there is to be no time limit. Between runs, this value may be reset by any specifications in the run plan. It can be manually changed during a run without editing the plan.
Reload & Start
Apply the settings.
If autoruns are enabled, but idle, then force reloading the plan, even if the plan file hasn’t changed.
Run plan file: commands and syntax
The run plan consists of a series of commands, in plain text, grouped by run number - all commands in a group apply to a particular run. Each command consists of a keyword, optionally followed by a colon (:
), and white space before any values. Besides the trailing colon, embeded underscore characters (_
) are ignored, as is capitalization of the command. Although they are ignored, capitalization, underscores, or colons can make a plan file more readable, especially when there are continued lines. In this documentation, the optional capitalization is usually used, and the colon used occasionally.
Commands may be broken across multiple lines by ending the partial line(s) with \
.
Lines that begin with certain characters (!#%;
) are comments, and are ignored, as are blank lines.
In the command syntax below, bold indicates a literal keyword, italics indicate some sort of value, “|” separates multiple possibilities, and “[ ]” brackets indicate some optional parameter. The |
, [
, and ]
characters should not be typed into a run plan!
One command, Run, is absolutely required, and it comes first:
Run number
Run next
Next run
The Run
command begins the commands for that particular run; all ensuing commands apply to that run, until the next Run
command. The specified run number must be consecutive with the previous. You can use the next
keyword instead of a number, but the first run must be explicitly numbered. (The reason the numbering must be defined is so that the plan can be edited and reloaded in the middle, without having to remove all the runs that have already been performed.)
If there are settings to be made after the last run has completed, use
Finally
to separate those settings from the preceding run; it is like a Run
command, but no run will be performed.
The remaining commands can be in any order.
In the case of TI (type-1) runs, there is the required sweep range:
SweepRange from delim to delim step
The delimiter delim signifies white-space and/or punctuation characters or even any of the letters in toby
(e.g., 10,100:2
, 5000 7000 500
, or 1 to 10 by 1
). People might try to use 200-300:10
for a range, but -
is not a legal delimiter since the dangers of misinterpreting a minus sign are too great. All the values (from, to, step) are integers.
Other commands (all the commands listed below) are strictly optional, and, if omitted, they retain the previous settings. That is, the values will not be actively set to any values, but will be retained by the respective MIDAS or CAMP systems.
There are four possible commands to control when the run should be ended:
Counts number [ M ] [ hist_number ] | ( for TD ) |
Time_limit elapsed_time | ( for TD or I ) |
Sweeps number_of_sweeps | ( for I ) |
Cycles number_of_cycles | ( for TD ) |
Typically, one should use Counts
to tell the total number of events to accumulate in a TD/Type-2 run; it can be given in “real” number form, and with an optional M
suffix to indicate “millions” (e.g., 3200000
, 32e5
, and 3.2M
are all the same). This parameter will replace the value in the ODB at the beginning of a run, but a user may manually change it in the ODB while the run is in progress, which is the best way to extend an automatic run in progress. If no Counts
command is given for a run, the existing value of /autorun/total counts
from the ODB is kept. If the optional hist_number is specified, then the counts are checked for that histogram only, rather than the total of all histograms.
The Time_limit setting (with alias Elapsed
) tells the longest time that may be spent on a run. The elapsed_time can be in many formats, and a simple number is interpreted as minutes; all of the following are equal: 1:30
, 5400 s
, 90 min
, 1.5hr
, 01:30:00
, 90
. Units are any strings that begin with s
, m
, or h
. Notice that 1:30
means 1.5 hours, not 1.5 minutes! For 1.5 minutes you would need 0:01:30
(or 1.5 min
or 90s
). You can specify both counts and time limits, in which case the run ends when either is satisfied. Note that using an elapsed-time limit may result in runs with no data if the beam is off for a long time.
The Sweeps
command is for TI runs only, and tells how many sweeps to make. It updates the corresponding parameter in the ODB: /Equipment/MUSR_I_acq/settings/input/num sweeps
, which applies to any run, not only autoruns.
The Cycles
command is for TD runs only, and tells how many cycles to perform. It applies to all runs, even when autoruns are disabled or idle.
Arrange to have autorun error and warning messages forwarded by email with
Email addr [ , addr ...
]
providing a list of email addresses, separated by commas. When there are problems, the corresponding messages will be emailed to these addresses. If you have an address that gets forwarded to a cell phone or pager, that would be good to use.
Several commands apply to the run headers, corresponding to the MIDAS “edit on start” variables.
Sample ...
Orientation ...
Operator ...
Experiment number
Temperature temperature | Camp_var
Field field | Camp_var
Note that temperature and field may be entered as numbers (with implicit units of Kelvin and Gauss), as numbers with units (provided the conversion to Kelvin or Gauss is known to the program), or as a the full CAMP path for a temperature or field variable.
Title: ...
The run title allows automatic insertion of other header fields using the tags <Sample>
, <Operator>
, <Experiment>
, <Temperature>
, <Field>
, and <Orientation>
. (Yes, you type the “angle brackets” <
and >
around the tag name). For example:
The autorun system will replace these tags with the appropriate header values, both at the beginning of the run and at intervals throughout the run; this ensures that automatic Temperature and Field headers, as well as any manual settings, are propagated to the run title. The system will STOP updating the title if the user manually sets it to something different.
For time-integral runs, there is also the percentage tolerance for the beam normalization:
Tolerance number [ % ]
(The percent sign is optional, and does not affect the interpretation of the number.)
Any ODB parameter can be set using the SetOdb
command:
SetOdb odb_variable value
where odb_variable is the full ODB path to the variable, enclosed in quotes if the name contains any spaces. The value should also be quoted if it contains spaces (use double-quotes, not apostrophes).
You can control some portions of the beamline or platform:
SetEpics: Epics_var value
The SetEpics
command (with spelling variants) sets a particular beam element to a value. EPICS variables are always in upper case, and contain colons (:
) as separators; they usually begin with the beamline or system name. To find the Epics_var, go to the beamline EPICS control window and click the middle mouse button on the entry field (blue text) where you would type the value. The Epics_var will be displayed in a small pop-up window (the text is “selected”, so you can immediately “paste” it into the plan file). The full Epics_var may be abbreviated for some elements commonly adjusted in autoruns, especially for turning elements on or off. When switching an element on or off, the value should be “on” or “off” for clarity; thus the examples
(short for β-NQR’s ILE2:BIAS15:VOL
).
Make CAMP settings using either or both of:
SetCamp Camp_var value
Camp_cmd Camp_command
(SetCamp
has aliases set_camp
, camp_set
and CampSet
, because we all forget.)
The Camp_var argument is a complete CAMP variable path, including all slashes, such as /Helios/mag_field
.
The value argument should be numeric or a text string, as appropriate for the particular Camp_var. Numeric values may be given as arithmetic expressions. For selection variables, one must use the exact same string as used by CAMP, including capitalization, or an integer index, counting from zero. As a special shortcut, abbreviations of the form «i>Camp_var</i>> (with explicit angle-brackets) may be used as (or in) the value argument, indicating that the value of another CAMP variable should be substituted.
The Camp_command is any command (or inline Tcl
script) as documented in Appendix B of the CAMP Software Manual
Examples are:
The autorun controller will perform all those CAMP and EPICS commands at once, as soon as the preceding run has ended. This doesn’t meet the full needs for setting CAMP devices, particularly in cases such as the field control example above, where one would like to reference the /Hall/field
value after the magnet has stabilized. One way to handle this is to schedule some settings after a fixed time delay:
After elapsed_time : SetCamp … | camp_cmd … | SetEpics … | AutoTune … |
where the forms of elapsed_time is similar to the run time-limit, except that a bare number is interpreted as seconds (six minutes could be given by any of 6m
, 0:06
, 0.1h
, 360s
, 360
). This is the first of two composite commands, where a required colon (:
) must separate the After
declaration from the ensuing, delayed, command. Note that only some commands can be deferred with After
; any others give a syntax error (because they aren’t allowed).
Before a run can begin, we must know that the experimental conditions have responded to the device settings, so we specify “requirements”
blank | |||||||||
stable | at number | <font size=+2>[</font> within error <font size=+2>]</font> | <font size=+2>[</font> for elapsed_time <font size=+2>]</font> | ||||||
equal Variable | |||||||||
Require | Variable | ||||||||
above | number | <font size=+2>[</font> for elapsed_time <font size=+2>]</font> | |||||||
below | number | ||||||||
is | string |
The run will not begin until every requirement is satisfied simultaneously, and there are no CAMP alarms active. (Thus, you can enforce many typical constraints by setting alarms in CAMP, rather than giving requirement commands.)
Each Variable is the full path specification of a CAMP variable, such as /Sample/sample_read
, or an EPICS variable, such as M20:S1:HVNEG:VOL
(distinguished by the presense of /
or :
).
For numeric variables, one should usually use the “stable” form of the command. The autorun system will collect values of the primary Variable, retaining those over the latest elapsed_time. To satisfy the requirement, all retained values must be within error of either: the latest value (blank comparison fields), or the given number (at
), or the current value of the comparison variable (equal
). (Notice that Require /foo/bar stable
is the same as Require /foo/bar stable equal /foo/bar
.)
The default elapsed_time, if none was specified, is 1 second (almost immediately). The default units, if a bare number was given, is seconds.
Numeric variables can also be tested to be “above” or “below” some value.
For string or selection variables, use the “is” form for the requirement. If the string contains spaces, then it should be quoted.
Examples:
Note that the last example specifies “Persistent”; “persistent” would not work because the actual value in CAMP is capitalized. Make sure the requirement string exactly matches what CAMP displays!
Here is another example, part of a temperature scan, where the desired temperature is specified just
The run will begin when the sample temperature levels off (within 0.5 K) for 2 minutes, and within 3 K of the diffuser setpoint (i.e., between 19 and 25 K). Whatever the average sample temperature is, over the course of the run, it will be recorded in the temperature field of the run header, and thence the run title of the data file. Note that, in this example as always, the Setcamp
command is performed before ever checking requirements; entering the Setcamp
declaration after the requirements does not imply that the settings are performed after requirements are satisfied. For that feature, see the When
command.
Max_wait elapsed_time
In case of conflicting requirements, or some other problem where the requirements are never satisfied, there is a Max_wait
command. After waiting for elapsed_time, the autorun sequencer will start the next run even if the requirements are not satisfied. The various formats for elapsed_time are that same as on the Time_limit
command, with default units of minutes (see above).
For greater control over the timing of CAMP settings than is provided by the After
command, one can schedule them the same way as specifying a requirement:
When requirement_specification : SetCamp ...
| camp_cmd ...
| SetEpics ...
| AutoTune ...
| After ...
| blank
The requirement_specification is any valid parameter list for the Require
command (above), and is followed by a mandatory colon separator. Only the device setting commands for CAMP and EPICS (SetCamp
, SetEpics
, camp_cmd
, and their aliases) and the After
command may be scheduled this way. You can also specify a null action with no scheduled command, which behaves like a simple Require
command except…
Conditions specified by When
must all be satisfied at some point before a run can begin, but they need not remain satisfied until the run begins. This makes a When
command with a null action subtly different from the same Require
command: all Require
conditions must be simultaneously satisfied when the run begins, whereas all When
actions (or null actions) must have been performed sometime before the run begins.
If a CAMP setting must be delayed until after the run begins, then you must use an After
command, either alone or scheduled by a When
command, like:
A typical use is to start controlling a variable after a previous setting is complete:
(Note the use of \
to join multiple lines when commands get too long, and the substitution for the current value of the field readback.) This example turns on (feedback) field control when the magnet current reaches its setpoint, and turns on needle-valve control three minutes after the cryostat diffuser temperature gets close to its setpoint. Notably, it also specifies the same requirements for beginning the run; thus, presuming the (diffuser) temperature is the last to stabilize, the needle-valve control will begin about three minutes after the run begins.
In the example (and in practice) note the use of multiple When
commands having the same requirement, but different actions. To save typing and computer processing, these can be written as a block
When requirement_specification do
…
enddo
or
When requirement_specification {
…
}
where multiple CAMP or EPICS setting commands are surrounded by “do...
enddo”, or their equivalents, curly braces “{...
}”, and controlled by a single When
command. For example,
Note which commands go on separate lines in this example. You cannot combine those multiple lines onto one.