forked from NSLS-II/lsdc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gon_lib.py
executable file
·93 lines (66 loc) · 2.14 KB
/
gon_lib.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
import time
import beamline_lib
import beamline_support
from beamline_support import getPvValFromDescriptor as getPvDesc, setPvValFromDescriptor as setPvDesc
from start_bs import back_light, back_light_range
import logging
logger = logging.getLogger(__name__)
BACK_LIGHT_STEP = 0.05 # percent of intensity range
def backlightBrighter():
intensity = back_light.get()
intensity += BACK_LIGHT_STEP * (back_light_range[1]-back_light_range[0])
back_light.put(intensity)
def backlightDimmer():
intensity = back_light.get()
intensity -= BACK_LIGHT_STEP * (back_light_range[1]-back_light_range[0])
back_light.put(intensity)
def lib_init_diffractometer():
beamline_support.initControlPVs()
def lib_gon_center_xtal(x,y,angle_omega,angle_phi):
setPvDesc("C2C_TargetX",float(x))
setPvDesc("C2C_TargetY",float(y))
setPvDesc("C2C_Omega",angle_omega)
setPvDesc("C2C_Go",1)
wait_for_goniohead()
def lib_open_shutter():
beamline_lib.mvaDescriptor("fastShutter",getPvDesc("fastShutterOpenPos"))
def lib_close_shutter():
beamline_lib.mvaDescriptor("fastShutter",getPvDesc("fastShutterClosePos"))
def lib_home():
pass
def lib_home_omega():
pass
def lib_home_dist():
pass #for now
def gon_stop():
logger.info("setting osc abort")
setPvDesc("vectorAbort",1)
def oscWait():
time.sleep(0.15)
while (getPvDesc("oscRunning")):
time.sleep(0.05)
def gon_osc(angle_start,width,exptime):
angle_end = angle_start+width
setPvDesc("oscOmegaStart",angle_start)
setPvDesc("oscOmegaEnd",angle_end)
setPvDesc("oscDuration",exptime)
setPvDesc("oscGo",1)
oscWait()
end_osc = beamline_lib.motorPosFromDescriptor("omega")
logger.info("end_osc in gon_osc = " + str(end_osc) + "\n")
return end_osc
def wait_for_goniohead(): #why can't I just call wait_motors????
while (1):
try:
done_stat = getPvDesc("gonioDone")
if (done_stat != 0):
break
else:
time.sleep(.2)
pass
except KeyboardInterrupt:
pass
except CaChannelException as status:
logger.error(ca.message(status))
logger.error("\n\nHandled Epics Error in wait for motors-2\n\n")
continue