Run¶
What the Run object¶
A Run holds data related to the properties of the experimental run, e.g. good proton charge, total frames etc. It also holds all of the sample log files as sets of time-series data. Currently used properties within Mantid includes run_start, which specified the date the data were collected. Where an instrument has been modified over time, and multiple instrument definition files have been defined for it, this property is used to loads the IDF valid when the data were collected.
Working with Run object in Python¶
You can look at the Run API reference for a full list of properties and operations, but here are some of the key ones.
Getting the Run Object from a Workspace¶
run = ws.getRun()
Run Properties¶
from mantid.kernel import DateAndTime
run = ws.getRun()
# Set the start and end time of a run
run.setStartAndEndTime(DateAndTime("2015-01-27T11:00:00"),
DateAndTime("2015-01-27T11:57:51"))
# Get the start and end time of a run
print(run.startTime())
print(run.endTime())
# Get the total good proton charge
print(run.getProtonCharge())
Accessing Properties¶
Listing all properties¶
ws = Load("MAR11060")
run = ws.getRun()
# Get a list of the property names
print(run.keys())
# Loop over all of the Properties
for prop in run.getProperties():
print("{0} {1}".format(prop.name, prop.value))
Getting a specific property¶
ws = CreateSampleWorkspace()
run = ws.getRun()
# Check if property exists
print("Is runstart present: {0}".format(("run_start" in run.keys())))
# or
print("Is runstart present: {0}".format(run.hasProperty("run_start")))
#get the Property
runStart = run.getProperty("run_start")
print("Property name: " + runStart.name)
print("Property value: " + runStart.value)
The Goniometer¶
If the instrument contains a Goniometer it can be accessed from the run object.
wg=CreateSingleValuedWorkspace()
AddSampleLog(wg,"Motor1","45.","Number")
SetGoniometer(wg,Axis0="Motor1,0,1,0,1",Axis1="5,0,1,0,1")
print("Goniometer angles: {}".format(wg.getRun().getGoniometer().getEulerAngles('YZY')))
Multiple goniometers can be accessed from the run object by
wg=CreateSingleValuedWorkspace()
AddTimeSeriesLog(wg, Name="Motor1", Time="2010-01-01T00:00:00", Value=0)
AddTimeSeriesLog(wg, Name="Motor1", Time="2010-01-01T00:01:00", Value=45)
AddTimeSeriesLog(wg, Name="Motor1", Time="2010-01-01T00:02:00", Value=90)
SetGoniometer(wg,Axis0="Motor1,0,1,0,1",Average=False)
print("Number of goniometers =", wg.getRun().getNumGoniometers())
for i in range(wg.getRun().getNumGoniometers()):
print("Goniometer angles: {}".format(wg.getRun().getGoniometer(i).getEulerAngles('YZY')))
Listing all properties¶
What information is stored here?¶
On loading experimental data there is a default set of properties that are populated within the run. These are as follows:
ISIS (not including ISIS Muon data)¶
run_header - The complete header for this run
run_title - The run title
run_start - Start date and time. Format: YYYY-MM-DD HH:MM:SS (+)
run_end - End date and time. Format: YYYY-MM-DD HH:MM:SS (+)
nspectra - The number of spectra in the raw data file
nchannels - The number of time channels in the raw data
nperiods - The number of periods within the raw data
dur - The run duration
durunits - The units of the run duration, 1 = seconds
dur_freq - Test interval for above
dmp - Dump interval
dmp_units - The units (scaler) for above
dmp_freq - Test interval for above
freq - 2**k where source frequency = 50 / 2**k
gd_prtn_chrg - Good proton charge (uA.hour)
‘’’tot_prtn_chrg* ‘’’- Total proton charge (uA.hour)
goodfrm - Good frames
‘’’rawfrm* ‘’’- Raw frames
dur_wanted - Requested run duration (units as for “duration” above)
dur_secs - Actual run duration in seconds
mon_sum1 - Monitor sum 1
mon_sum2 - Monitor sum 2
mon_sum3 - Monitor sum 3
rb_proposal - The proposal number
ISIS Muon data¶
run_title - The run title
run_start - Start date and time. Format: YYYY-MM-DD HH:MM:SS (+)
run_end - End date and time. Format: YYYY-MM-DD HH:MM:SS (+)
nspectra - The number of spectra in the raw data file
goodfrm - Good frames
dur_secs - Run duration in seconds
run_number - Run number
sample_temp - Temperature of the sample
sample_magn_field - Magnetic field of the sample
(+) or YYYY-MM-DDTHH:MM:SS (ISO 8601 format, see 1)
Category: Concepts