This commit is contained in:
sfop
2017-04-12 19:04:05 +02:00
parent bc51796d4a
commit c587fcbd0f
4 changed files with 39 additions and 56 deletions

View File

@@ -1,10 +1,11 @@
is_panel = get_exec_pars().source != CommandSource.ui #Must be checked before callin "run"
is_panel = get_exec_pars().source != CommandSource.ui #Must be checked before callin "run"
run("Devices/Elements")
run("Devices/WireScanner")
#BPM_SENSORS = {"x":"X1", "y":"Y1", "q":"Q1"}
BPM_SENSORS = {"x":"X1"}
BPM_SENSORS = {"x":"X1", "y":"Y1", "q":"Q1"}
#Paramter parsing
if is_panel:
prefix = args[0]
sel = args[1]
@@ -21,76 +22,66 @@ else:
cycles = 5
velocity = 200
bpm3 = None
print "WireScan parameters: ", prefix, sel, start, end, cycles, cycles, bpm3
print prefix, sel, start, end, cycles, cycles, bpm3
#Creating WireScanner object
print "Creating scanner..."
if prefix not in get_wire_scans():
raise Exception("Invalid wire scan: " + prefix)
scanner = WireScanner(prefix, sel, start, end, cycles, velocity, True)
scanner.init()
scanner.waitValue("At start", 60000)
#Stream channels
bs_position = scanner.motor_bs_readback.get_name()
bpms = get_wire_scans_bpms(prefix)
if bpms is None:
raise Exception("Cannot determine wire scan bpms: " + prefix)
#List of stream channels
channels = [("w_pos", scanner.motor_bs_readback.get_name()),
("cur_cycle", scanner.curr_cycl.get_name()),
("scanning", scanner.status_channels[0].get_name())]
bpms = get_wire_scans_bpms(prefix)
if bpms is None:
raise Exception("Cannot determine wire scan bpms: " + prefix)
if bpm3 is not None:
bpms.append(bpm3)
bpms = ["SINDI01-DBPM060", "SINDI02-DBPM010"]
#bpms = ["SINDI01-DBPM060", "SINDI02-DBPM010"] #For testing
for i in range (len(bpms)):
for sensor in BPM_SENSORS.keys():
channels.append (("bpm" + str(i+1) + "_" + sensor, bpms[i] + ":" + BPM_SENSORS[sensor]))
channels.append (("timer", "SINDI01-RLLE-STA:SLAVE1-CPUTIMER"))
#Stream creation
print "Starting stream..."
st = Stream("pulse_id", dispatcher)
#st.setFilter(scanner.status_channels[0].get_name() + ">0") #Not used because we must the reansition to know when the finished
scanner.curr_cycl.write(0)
st.setFilter(scanner.curr_cycl.get_name() + ">0")
st.setFilter(scanner.curr_cycl.get_name() + ">0") #scanner.status_channels[0].get_name() + ">0" not used because we must the reansition to know when the finished
for c in channels:
print c[1]
st.addScalar(c[0], c[1], 10, 0)
st.initialize()
st.start()
st.waitCacheChange(10000)
scanner.scan()
scanner.waitState(State.Busy, 60000)
st.waitCacheChange(10000) #Wait stream be running before starting scan
#End of scan checking
scan_complete=False
cur_cycle = scanner.curr_cycl.get()
cur_cycle = 1
def check_end_scan(record, scan):
global scan_complete
global cur_cycle
#print record[1] ,scanner.readback
global scan_complete,cur_cycle
if record[3]<1:
print "Data aquisition completed"
scan_complete=True
scan.abort()
elif record[2] != cur_cycle:
print "New step"
print cur_cycle, record[2]
cur_cycle = record[2]
scan.abort()
scan.start()
get_context().dataManager.splitScanData(scan)
#Metadata
def write_metadata(path):
try:
set_attribute(path, "Wire Scan", prefix)
set_attribute(path, "Selection", sel)
set_attribute(path, "Range", scaner.scan_range)
set_attribute(path, "Cycles", scanner.cycles )
set_attribute(path, "Velocity", scanner.velocity )
except:
pass
set_attribute("/", "Wire Scan", prefix)
set_attribute("/", "Selection", sel)
set_attribute("/", "Range", scanner.scan_range)
set_attribute("/", "Cycles", scanner.cycles )
set_attribute("/", "Velocity", scanner.velocity )
#Scan
try:
print "Starting scan..."
scanner.scan() #scanner.waitState(State.Busy, 60000) Not needed as stream filter will make the wait
mscan (st, st.getReadables(), -1, -1, after_read = check_end_scan)
except:
if not scanner.isReady():
@@ -99,9 +90,9 @@ except:
if not scan_complete:
raise
finally:
write_metadata(get_exec_pars().scanPath)
print "Closing scanner"
scanner.close()
print "Closing stream"
st.close()