1 | from mantid import * |
---|
2 | import sys |
---|
3 | def run_comparison(input_ws_name, output_ws_name, relative_time_shift =0.0, absolute_time_shift="", log = False): |
---|
4 | # Create a duplicate |
---|
5 | duplicate = CloneWorkspace(InputWorkspace = input_ws_name) |
---|
6 | |
---|
7 | # Run ChangeTimeZero |
---|
8 | ChangeTimeZero(InputWorkspace = input_ws_name, OutputWorkspace = output_ws_name, |
---|
9 | RelativeTimeOffset= relative_time_shift , AbsoluteTimeOffset = absolute_time_shift) |
---|
10 | |
---|
11 | # Compare the sample logs |
---|
12 | time_shift = 0.0 |
---|
13 | if (absolute_time_shift != ""): |
---|
14 | proton_charge_times = duplicate.getRun().getProperty("proton_charge").times |
---|
15 | if len(proton_charge_times) == 0: |
---|
16 | sys.exit("When using absolute times you need a proton charge log") |
---|
17 | time_shift = time_duration.total_nanoseconds(proton_charge_times[0]- DateAndTime(absolute_time_shift)) |
---|
18 | else: |
---|
19 | time_shift = relative_time_shift |
---|
20 | |
---|
21 | compare_logs(output_ws_name, duplicate, time_shift, log) |
---|
22 | |
---|
23 | # Compare the neutrons for event workspaces |
---|
24 | if isinstance(duplicate, IEventWorkspace): |
---|
25 | compare_neutrons(output_ws_name, duplicate, time_shift) |
---|
26 | |
---|
27 | def compare_logs(output_ws_name, duplicate, time_shift, log): |
---|
28 | # Iterate over all TimeSeries properties |
---|
29 | ws = mtd[output_ws_name] |
---|
30 | run = ws.getRun() |
---|
31 | props = run.getProperties() |
---|
32 | props_duplicate = duplicate.getRun().getProperties() |
---|
33 | |
---|
34 | size = len(props) |
---|
35 | size_duplicate = len(props_duplicate) |
---|
36 | assert(size == size_duplicate) |
---|
37 | |
---|
38 | for prop in props: |
---|
39 | prop_2 = [] |
---|
40 | for prop_duplicate in props_duplicate: |
---|
41 | prop_2 = [] |
---|
42 | if prop_duplicate.name == prop.name: |
---|
43 | prop_2 = prop_duplicate |
---|
44 | break |
---|
45 | |
---|
46 | if isinstance(prop, FloatTimeSeriesProperty) or isinstance(prop, BoolTimeSeriesProperty) or isinstance(prop, StringTimeSeriesProperty): |
---|
47 | # Need to find the property in duplicate ws |
---|
48 | times_1 = prop.times |
---|
49 | times_2 = prop_2.times |
---|
50 | assert(len(times_1) == len(times_2)) |
---|
51 | compare_time_series_log(times_1, times_2, time_shift, log) |
---|
52 | elif isinstance(prop, StringPropertyWithValue) and isinstance(prop_2, StringPropertyWithValue): |
---|
53 | val_1 = 0.0 |
---|
54 | val_2 = 0.0 |
---|
55 | try: |
---|
56 | val_1 = DateAndTime(prop.value) |
---|
57 | val_2 = DateAndTime(prop_2.value) |
---|
58 | compare_string_value(val_1, val_2, time_shift, log) |
---|
59 | except ValueError: |
---|
60 | pass |
---|
61 | |
---|
62 | def compare_time_series_log(times_1, times_2, expected_time_shift, log): |
---|
63 | for i in range(0,len(times_1)): |
---|
64 | if time_duration.total_nanoseconds(times_1[i] - times_2[i])/1e9 != expected_time_shift: |
---|
65 | sys.exit("The time difference for a time series property does not seem correct.") |
---|
66 | |
---|
67 | if log: |
---|
68 | print "| Orig: " + str(times_1[i]) + " | Shift: " + str(times_2[i]) + " | Diff[s]: " + str(time_duration.total_nanoseconds(times_1[i] - times_2[i])/1e9) + " |" |
---|
69 | |
---|
70 | |
---|
71 | def compare_string_value(val1, val2, expected_time_shift, log): |
---|
72 | if time_duration.total_nanoseconds(val1 - val2)/1e9 != expected_time_shift: |
---|
73 | sys.exit("The time difference for a string property does not seem correct.") |
---|
74 | if log: |
---|
75 | print "| ValOrig: " + str(val1) + " | ValShift: " + str(val2) + " | Diff[s]: " + str(time_duration.total_nanoseconds(val1 - val2)/1e9) + " |" |
---|
76 | |
---|
77 | def compare_neutrons(output_ws_name, duplicate, time_shift): |
---|
78 | ws = mtd[output_ws_name] |
---|
79 | for index in range(0,ws.getNumberHistograms()): |
---|
80 | pulse_times = ws.getEventList(index).getPulseTimes() |
---|
81 | pulse_times_2 = duplicate.getEventList(index).getPulseTimes() |
---|
82 | for i in range(0, len(pulse_times)): |
---|
83 | time1 = pulse_times[i] |
---|
84 | time2 = pulse_times_2[i] |
---|
85 | if time_duration.total_nanoseconds(pulse_times[i] - pulse_times_2[i])/1e9 != time_shift: |
---|
86 | sys.exit("The time difference for neutrons does not seem correct. Original was: " + str(pulse_times[i]) + " and shifted was: pulse_times_2[i]" ) |
---|
87 | |
---|
88 | #------------------------------------------------------------------------- |
---|
89 | # DEFINE SHIFTS HERE - You need to load a your workspace into Mantid and use their name as the input |
---|
90 | #------------------------------------------------------------------------- |
---|
91 | #SET THIS FLAG TO PRINT LOG COMPARISON |
---|
92 | PRINT_LOG = True |
---|
93 | |
---|
94 | #-- RELATIVE TIME SHIFT |
---|
95 | input_ws_name_REL = "SANS2D00022023" |
---|
96 | output_ws_name_REL = "REL_SAMPLE" |
---|
97 | time_shift_REL = 1000.0 |
---|
98 | run_comparison(input_ws_name= input_ws_name_REL, output_ws_name= output_ws_name_REL, relative_time_shift= time_shift_REL, log = PRINT_LOG) |
---|
99 | |
---|
100 | #-- ABSOLUTE TIME SHIFT |
---|
101 | input_ws_name_ABS = "SANS2D00022023" |
---|
102 | output_ws_name_ABS = "ABS_SAMPLE" |
---|
103 | absolute_time_shift_ABS ="2013-10-25T13:58:03" |
---|
104 | run_comparison(input_ws_name= input_ws_name_ABS, output_ws_name= output_ws_name_ABS, absolute_time_shift= absolute_time_shift_ABS) |
---|
105 | |
---|