added attenuator

This commit is contained in:
2020-07-05 21:12:17 +02:00
parent 670ebe0e99
commit 00da9d59f6
2 changed files with 91 additions and 6 deletions

74
devices/attenuator.py Normal file
View File

@ -0,0 +1,74 @@
from time import sleep
from types import SimpleNamespace
from slic.utils import typename
from slic.core.task import Task
import epics
class PV(epics.PV):
def put(self, *args, wait=True, **kwargs):
super().put(*args, wait=wait, **kwargs)
class Attenuator:
def __init__(self, name, n_motors=6):
if not name.endswith(":"):
name += ":"
self.name = name
self.pvs = SimpleNamespace(
energy = PV(name + "ENERGY"),
transmission = PV(name + "TRANS_SP"),
motors_done_moving = [PV(name + "MOTOR_{}.DMOV".format(i+1)) for i in range(n_motors)]
)
def get_current_value(self):
return self.get_transmission()
def set_target_value(self, value):
def changer():
self.set_transmission(value)
return Task(changer)
def set_transmission(self, value):
self.pvs.transmission.put(value)
self.wait_for_motors()
def get_transmission(self):
return self.pvs.transmission.get()
transmission = property(get_transmission, set_transmission)
def set_energy(self, value):
self.pvs.energy.put(value)
def get_energy(self):
return self.pvs.energy.get()
energy = property(get_energy, set_energy)
def motors_are_moving(self):
is_moving = lambda dmov: not bool(dmov.get())
return any(is_moving(dmov) for dmov in self.pvs.motors_done_moving)
def wait_for_motors(self):
while self.motors_are_moving():
sleep(0.01)
def __repr__(self):
tn = typename(self)
trans = self.get_transmission() * 100
energ = self.get_energy()
return "{}(\"{}\") at {}% transmission for {} eV".format(tn, self.name, trans, energ)

View File

@ -8,6 +8,12 @@ from slic.core.scanner import Scanner
#from slic.utils import devices
from devices.attenuator import Attenuator
att = Attenuator("SATFE10-OATT064")
channels_inten = [
# "SATFE10-PEPG046:PHOTON-ENERGY-PER-PULSE-AVG"
"SATFE10-PEPG046-EVR0:CALCI",
@ -20,20 +26,25 @@ channels_inten = [
"SLAAR11-LTIM01-EVR0:DUMMY_PV5_NBS"
]
channels_ks = channels_inten + [
channels_ks = [
"SATES21-GES1:A1_VALUES",
]
channels_cam = channels_inten + [
"SATES21-CAMS154-M1:FPICTURE"
channels_cam = [
"SATES21-CAMS154-M1:FPICTURE",
"SATES24-CAMS161-M1:FPICTURE"
]
channels = channels_inten + channels_ks + channels_cam
daq = SFAcquisition("maloja", "p18493", default_channels=channels_ks, rate_multiplicator=40)
scan = Scanner(scan_info_dir="/sf/maloja/data/p18493/res/scan_info", default_acquisitions=[daq], make_scan_sub_dir=False)
instrument = "maloja"
pgroup = "p18493"
daq = SFAcquisition(instrument, pgroup, default_channels=channels, rate_multiplicator=40)
scan = Scanner(scan_info_dir=f"/sf/{instrument}/data/{pgroup}/res/scan_info", default_acquisitions=[daq])