-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathS26_commandline.py
213 lines (194 loc) · 9.22 KB
/
S26_commandline.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
# Enables command line scripting for HXN microscope operation
# start this with /APSshare/anaconda/x86_64/bin/ipython -i S26_commandline.py
import sys
import epics
import epics.devices
import time
import datetime
import numpy as np
import os
import math
from IPython import get_ipython
ipython=get_ipython()
# Define motors
fomx = epics.Motor('26idcnpi:m10.') # motor for moving focusing optics in the x direction, a positive value moves the motor in the outboard direction
fomy = epics.Motor('26idcnpi:m11.') # motor for moving focusing optics in the y direction, a positive value moves the motor up in the lab frame
fomz = epics.Motor('26idcnpi:m12.') # motor for moving focusing optics in the z direction, a positive value moves the motor further downstream
samy = epics.Motor('26idcnpi:m17.') # motor for moving the sample in the y direction, a positive value moves the sample up in the lab frame
samth = epics.Motor('atto2:PIC867:1:m1.')
osax = epics.Motor('26idcnpi:m13.')
osay = epics.Motor('26idcnpi:m14.')
osaz = epics.Motor('26idcnpi:m15.')
condx = epics.Motor('26idcnpi:m5.')
attox = epics.Motor('atto2:m4.') # motor for moving the sample in the x direction, a positive value move the sample outboard if samth is at 0 degree.
attoz = epics.Motor('atto2:m3.') # motor for moving the sample in the z direction, a positive value move the sample downstream if samth is at 0 degree.
objx = epics.Motor('26idcnpi:m1.')
xrfx = epics.Motor('26idcDET:m7.') # motor for moving the XRF detector in
DCMenergy = epics.Motor("26idbDCM:sm8")
hybridx = epics.Device('26idcnpi:X_HYBRID_SP.', attrs=('VAL','DESC')) # motor for moving the x-ray beam in the x direction. A positive value moves the beam outboard.
hybridx.add_pv('26idcnpi:m34.RBV', attr='RBV')
hybridy = epics.Device('26idcnpi:Y_HYBRID_SP.', attrs=('VAL','DESC')) # motor for moving the x-ray beam in the y direction. A positive value moves the beam up in the lab frame.
hybridy.add_pv('26idcnpi:m35.RBV', attr='RBV')
twotheta = epics.Motor('26idcSOFT:sm3.')
not_epics_motors = [hybridx.NAME, hybridy.NAME, twotheta.NAME]
def movr(motor,tweakvalue):
"""
Move motor to absolute position, tweakvalue is in um
"""
if motor in [fomx, fomy, samy]:
epics.caput('26idcnpi:m34.STOP',1)
epics.caput('26idcnpi:m35.STOP',1)
if ( (motor in [hybridx, hybridy]) and ( (abs(hybridx.RBV-hybridx.VAL)>100) or (abs(hybridy.RBV-hybridy.VAL)>100) ) ):
print("Please use lock_hybrid() to lock piezos at current position first...")
return
if motor.NAME in not_epics_motors:
motor.VAL = motor.VAL+tweakvalue
time.sleep(1)
print(motor.DESC+"---> "+str(motor.RBV))
else:
result = motor.move(tweakvalue, relative=True, wait=True)
if result==0:
time.sleep(0.5)
print(motor.DESC+" ---> "+str(motor.RBV))
fp = open(logbook,"a")
fp.write(motor.DESC+" ---> "+str(motor.RBV)+"\n")
fp.close()
else:
print("Motion failed")
def lock_hybrid():
"""
Function that must be called before any motor movement when applied to a hybrid motor
denoted by the hybrid prefix
"""
tempx = hybridx.RBV
time.sleep(1)
mov(hybridx,tempx)
time.sleep(1)
tempy = hybridy.RBV
time.sleep(1)
mov(hybridy,tempy)
time.sleep(1)
def unlock_hybrid():
"""
Function that must be called after any motor movement when applied to a hybrid motor
denoted by the hybrid prefix
"""
tempx = hybridx.RBV
tempy = hybridy.RBV
print("before unlock: x = {0} and y = {1}".format(tempx, tempy))
epics.caput('26idcnpi:m34.STOP',1)
epics.caput('26idcnpi:m35.STOP',1)
if ( (abs(fomx.RBV-optic_in_x)<100) and (abs(fomy.RBV-optic_in_y)<100) ):
mov(fomx,optic_in_x);
mov(fomy,optic_in_y);
time.sleep(1)
tempx = hybridx.RBV
tempy = hybridy.RBV
print("after unlock: x = {0} and y = {1}".format(tempx, tempy))
def postscan():
# post scan macro
pathname = epics.caget(scanrecord+':saveData_fullPathName',as_string=True)
epics.caput("QMPX3:TIFF1:FilePath",pathname[:-4]+'Images/')
time.sleep(1)
epics.caput("QMPX3:TIFF1:FileName",'image')
time.sleep(1)
for i in range(1,5):
det_name = epics.caget("26idbSOFT:scan1.T{0}PV".format(i))
if 'pilatus' in det_name:
epics.caput("dp_pilatus4:cam1:FilePath",'/home/det/s26data/'+pathname[15:-4]+'Images/')
time.sleep(1)
epics.caput("dp_pilatus4:cam1:FileName",'pilatus')
time.sleep(1)
epics.caput("26idc:filter:Fi1:Set",1)
time.sleep(1)
def scan1d(motor,startpos,endpos,numpts,dettime, absolute=False):
"""
# if absolute flag is set to True, scan a single motor from start position (startpos) to end position (endpos), with number of points (numpts) and count time in seconds (dettime)
# if absolute flag is set to False, scan a single motor from current position minux startpos to current position plus endpos, with number of points (numpts) and count time in seconds (dettime)
"""
if motor in [fomx, fomy, samy]:
epics.caput('26idcnpi:m34.STOP',1)
epics.caput('26idcnpi:m35.STOP',1)
if ( (motor in [hybridx, hybridy]) and ( (abs(hybridx.RBV-hybridx.VAL)>100) or (abs(hybridy.RBV-hybridy.VAL)>100) ) ):
print("Please use lock_hybrid() to lock piezos at current position first...")
return
sc1.P1PV = motor.NAME+'.VAL'
if absolute:
sc1.P1AR=0
else:
sc1.P1AR=1
sc1.P1SP = startpos
sc1.P1EP = endpos
sc1.NPTS = numpts
count_time(dettime)
fp = open(logbook,"a")
fp.write(' ----- \n')
fp.write('SCAN #: '+epics.caget(scanrecord+':saveData_scanNumber',as_string=True)+' ---- '+str(datetime.datetime.now())+'\n')
if absolute:
fp.write('Scanning '+motor.DESC+' from '+str(startpos)+' ---> '+str(endpos)+' in '+str(numpts)+' points at '+str(dettime)+' seconds acquisition\n')
else:
fp.write('Scanning '+motor.DESC+' from '+str(startpos+motor.VAL)+' ---> '+str(endpos+motor.VAL))
fp.write(' in '+str(numpts)+' points at '+str(dettime)+' seconds acquisition\n')
fp.write(' ----- \n')
fp.close()
time.sleep(1)
stopnow = prescan();
if (stopnow):
return
sc1.execute=1
print("Scanning...")
time.sleep(1)
while(sc1.BUSY == 1):
time.sleep(1)
postscan()
def scan2d(motor1,startpos1,endpos1,numpts1,motor2,startpos2,endpos2,numpts2,dettime, absolute=False):
# if absolute flag is set to True, move one motor (motor1) from start position (startpos1) to end position (endpos), with number of steps determined by numpts1. At each of those steps, scan another motor (motor2) from start position (startpos2) to end position (endpos2), with number of steps determined by numpts2. The exposure time is set by dettime, and its unit is in seconds.
# if absolute flag is set to False, move one motor (motor1) from current position minus startpos1 to current position plus endpos1, with number of steps determined by numpts1. At each of those steps, scan another motor (motor2) from current position minus startpos2 to current position plus endpos2, with number of steps determined by numpts2. The exposure time is set by dettime, and its unit is in seconds.
if (motor1 in [fomx, fomy, samy]) or (motor2 in [fomx, fomy, samy]):
epics.caput('26idcnpi:m34.STOP',1)
epics.caput('26idcnpi:m35.STOP',1)
if ( ( (motor1 in [hybridx, hybridy]) or (motor2 in [hybridx,hybridy]) ) and ( (abs(hybridx.RBV-hybridx.VAL)>100) or (abs(hybridy.RBV-hybridy.VAL)>100) ) ):
print("Please use lock_hybrid() to lock piezos at current position first...")
return
sc2.P1PV = motor1.NAME+'.VAL'
sc1.P1PV = motor2.NAME+'.VAL'
if absolute:
sc1.P1AR=0
sc2.P1AR=0
else:
sc1.P1AR=1
sc2.P1AR=1
sc2.P1SP = startpos1
sc1.P1SP = startpos2
sc2.P1EP = endpos1
sc1.P1EP = endpos2
sc2.NPTS = numpts1
sc1.NPTS = numpts2
count_time(dettime)
fp = open(logbook,"a")
fp.write(' ----- \n')
fp.write('SCAN #: '+epics.caget(scanrecord+':saveData_scanNumber',as_string=True)+' ---- '+str(datetime.datetime.now())+'\n')
if absolute:
fp.write('2D Scan:\n')
fp.write('Inner loop: '+motor2.DESC+' from '+str(startpos2)+' ---> '+str(endpos2))
fp.write(' in '+str(numpts2)+' points at '+str(dettime)+' seconds acquisition\n')
fp.write('Outer loop: '+motor1.DESC+' from '+str(startpos1)+' ---> '+str(endpos1))
fp.write(' in '+str(numpts1)+' points at '+str(dettime)+' seconds acquisition\n')
else:
fp.write('2D Scan:\n')
fp.write('Outer loop: '+motor1.DESC+' from '+str(startpos1+motor1.VAL)+' ---> '+str(endpos1+motor1.VAL))
fp.write(' in '+str(numpts1)+' points at '+str(dettime)+' seconds acquisition\n')
fp.write('Inner loop: '+motor2.DESC+' from '+str(startpos2+motor2.VAL)+' ---> '+str(endpos2+motor2.VAL))
fp.write(' in '+str(numpts2)+' points at '+str(dettime)+' seconds acquisition\n')
fp.write(' ----- \n')
fp.close()
time.sleep(1)
stopnow = prescan();
if (stopnow):
return
sc2.execute=1
print("Scanning...")
time.sleep(1)
while(sc2.BUSY == 1):
time.sleep(1)
postscan()