Skip to content
Snippets Groups Projects
pydeviceCRL.cmd 2.74 KiB
Newer Older
mwyman's avatar
mwyman committed
################################################################################
# PyDevice Support for Transfocator
################################################################################

mwyman's avatar
mwyman committed
# Set CRL number
epicsEnvSet("_N","1")

# Next two lines set up some testing tools for energy and slits
mwyman's avatar
mwyman committed
epicsEnvSet("MONOE","testMonoE")
epicsEnvSet("IDENERGY","testIDE")
dbLoadRecords("${TOP}/db/energyTestTools.db","P=$(PREFIX), MONOE=$(MONOE), IDENERGY=$(IDENERGY)")
dbLoadRecords("${TOP}/db/slitTestTools.db","P=$(PREFIX), SLITH=testSSH, SLITV=testSSV")

# Setting some variables beamline-dependent PVs
epicsEnvSet('_SLITH',"$(PREFIX)testSSH")	# Horizontal size of slit PV before CRL
epicsEnvSet('_SLITV',"$(PREFIX)testSSV")	# Vertical size of slit PV before CRL
epicsEnvSet("BLE","$(PREFIX)$(MONOE)")	# Beam energy PV at CRL
mwyman's avatar
mwyman committed

mwyman's avatar
mwyman committed
# CRL DBs and defining substitution file to get stack properties
mwyman's avatar
mwyman committed
dbLoadTemplate("substitutions/pyDeviceTfor.substitutions","P=$(PREFIX)")
mwyman's avatar
mwyman committed
pydev("stack_subFile = 'substitutions/pyDeviceTfor.substitutions'")
mwyman's avatar
mwyman committed
# Import Transfocator class
mwyman's avatar
mwyman committed
pydev("from pyTransfocator_single import singleTF")

mwyman's avatar
mwyman committed
# Create Transfocator object
pydev("CRL1 = singleTF(crl_setup = 'crl_setup.toml')")
mwyman's avatar
mwyman committed

mwyman's avatar
mwyman committed
# DB for Transfocator system
mwyman's avatar
mwyman committed
dbLoadRecords(""${TOP}/db/pyDevCRLsingle.db","P=$(PREFIX), N=$(_N), OBJ=CRL1, KEV=$(BLE), SLITH = $(_SLITH), SLITV = $(_SLITV)")

################################################################################
# After iocInit, need to setup focal size lookup table -- because setting slit
# sizes and energy causes the table to be recalculated, will first disable 
# lookup table calc PV, set the slit sizes and energy, calculate the table 
# directly via python call, then enable calc PV so future slit/energy changes
# update the lookup table

# Disable calc of lookup table
doAfterIocInit("dbpf('$(PREFIX)CRL$(_N):recalc_enable','0')") # Disable table calc
mwyman's avatar
mwyman committed

mwyman's avatar
mwyman committed
# Process current slit and energy PV settings
doAfterIocInit("dbpf('$(PREFIX)CRL$(_N):slitSize_H.PROC','1')") # PROC H slit size read and update CRL1 object
doAfterIocInit("dbpf('$(PREFIX)CRL$(_N):slitSize_V.PROC','1')") # PROC V slit size read and update CRL1 object
doAfterIocInit("dbpf('$(PREFIX)CRL$(_N):energy.PROC','1')") # PROC energy read and update CRL1 object

# Calc lookup table via python; later re-calculations started via EPICS (changes to energy, slits)
mwyman's avatar
mwyman committed
# 	stack_subFile - string holding name/rel. location of substitutions file loaded
mwyman's avatar
mwyman committed
#                     loaded in  dbLoadTemplate
mwyman's avatar
mwyman committed
#   $(_STACKS)  - number of stacks of lenses
mwyman's avatar
mwyman committed
doAfterIocInit("pydev('CRL1.setupLookupTable(stack_subFile, $(_STACKS)')") 

# Enable lookup table calc PV
doAfterIocInit("dbpf('$(PREFIX)CRL$(_N):recalc_enable','1')") # Enable table calc
################################################################################