python funcs

This commit is contained in:
Erik Frojdh 2020-09-10 16:47:34 +02:00
parent 6cfaa92b61
commit d70090967d
6 changed files with 38 additions and 77 deletions

View File

@ -35,8 +35,7 @@ set( PYTHON_FILES
gotthard.py
gotthard2.py
moench.py
jsonproxy.py
slowadcproxy.py
proxy.py
ctb.py
jungfrau.py
mythen3.py

View File

@ -8,8 +8,6 @@ from slsdet import Detector
pycmd = dir(Detector)
#Add commands that we should not expect as direct commands in python
# dacs are in general not included in the python commands and we expect to
# set them from the specialized class or using an enum
@ -119,6 +117,7 @@ print(f'Excluded: {len(dacs)} dacs')
print(f'Excluded: {len(intentionally_missing)} other commands')
not_in_cmd = []
for c in pycmd:
if c.islower() and not c.startswith('_'):

View File

@ -11,8 +11,7 @@ detectorType = slsDetectorDefs.detectorType
from .utils import element_if_equal, all_equal, get_set_bits, list_to_bitmask
from .utils import Geometry, to_geo, element, reduce_time, is_iterable
from . import utils as ut
from .jsonproxy import JsonProxy
from .slowadcproxy import SlowAdcProxy
from .proxy import JsonProxy, SlowAdcProxy
from .registers import Register, Adc_register
import datetime as dt
@ -195,6 +194,10 @@ class Detector(CppDetectorApi):
def dr(self, dr):
self.setDynamicRange(dr)
@property
def drlist(self):
return self.getDynamicRangeList()
@property
def module_geometry(self):
return to_geo(self.getModuleGeometry())
@ -205,7 +208,7 @@ class Detector(CppDetectorApi):
return element_if_equal(ms)
@property
def detector_size(self):
def detsize(self):
return to_geo(self.getDetectorSize())
@property
@ -244,6 +247,11 @@ class Detector(CppDetectorApi):
def frames(self, n_frames):
self.setNumberOfFrames(n_frames)
@property
@element
def framesl(self):
return self.getNumberOfFramesLeft()
@property
@element
def nframes(self):
@ -596,13 +604,14 @@ class Detector(CppDetectorApi):
self.setFileFormat(format)
@property
@element
def findex(self):
"""File or Acquisition index in receiver."""
return element_if_equal(self.getAcquisitionIndex())
return self.getAcquisitionIndex()
@findex.setter
def findex(self, index):
self.setAcquisitionIndex(index)
ut.set_using_dict(self.setAcquisitionIndex, index)
@property
def fname(self):
@ -687,6 +696,7 @@ class Detector(CppDetectorApi):
# ZMQ Streaming Parameters (Receiver<->Client)
@property
@element
def rx_zmqstream(self):
"""
Enable/ disable data streaming from receiver via zmq (eg. to GUI or to another process for further processing). \n
@ -694,11 +704,11 @@ class Detector(CppDetectorApi):
Switching to Gui automatically enables data streaming in receiver. \n
Switching back to command line acquire will require disabling data streaming in receiver for fast applications.
"""
return element_if_equal(self.getRxZmqDataStream())
return self.getRxZmqDataStream()
@rx_zmqstream.setter
def rx_zmqdatastream(self, enable):
self.setRxZmqDataStream(enable)
def rx_zmqstream(self, enable):
ut.set_using_dict(self.setRxZmqDataStream, enable)
@property
def rx_zmqfreq(self):
@ -1180,19 +1190,17 @@ class Detector(CppDetectorApi):
return JsonProxy(self)
@rx_jsonpara.setter
def rx_jsonpara(self, args):
for key, value in args.items():
self.setAdditionalJsonParameter(key, str(value))
@property
@element
def rx_jsonaddheader(self):
return self.getAdditionalJsonHeader()
@rx_jsonaddheader.setter
def rx_jsonaddheader(self, args):
ut.set_using_dict(self.setAdditionalJsonHeader, args)
@property
def frameindex(self):
def rx_frameindex(self):
return self.getRxCurrentFrameIndex()
@property
@ -1243,7 +1251,7 @@ class Detector(CppDetectorApi):
"""
<<<Eiger>>>
<<<-----------------------Eiger specific----------------------->>>
"""
@ -2263,3 +2271,13 @@ class Detector(CppDetectorApi):
"""
<<<-----------------------Gotthard specific----------------------->>>
"""
@property
def exptimel(self):
t = self.getExptimeLeft()
return reduce_time(t)

View File

@ -1,30 +0,0 @@
from .utils import element_if_equal
class JsonProxy:
"""
Proxy class to allow for intuitive setting and getting of rx_jsonpara
This class is returned by Detectr.rx_jsonpara
"""
def __init__(self, det):
self.det = det
def __getitem__(self, key):
return element_if_equal(self.det.getAdditionalJsonParameter(key))
def __setitem__(self, key, value):
self.det.setAdditionalJsonParameter(key, str(value))
def __repr__(self):
r = element_if_equal(self.det.getAdditionalJsonHeader())
if isinstance(r, list):
rstr = ''
for i, list_item in enumerate(r):
list_item = dict(list_item)
rstr += ''.join([f'{i}:{key}: {value}\n' for key, value in list_item.items()])
return rstr.strip('\n')
else:
r = dict(r)
return '\n'.join([f'{key}: {value}' for key, value in r.items()])

View File

@ -1,25 +0,0 @@
from .utils import element_if_equal
from .enums import dacIndex
class SlowAdcProxy:
"""
Proxy class to allow for more intuitive reading the slow ADCs
"""
def __init__(self, det):
self.det = det
def __getitem__(self, key):
dac_index = dacIndex(int(dacIndex.SLOW_ADC0)+key)
return element_if_equal(self.det.getSlowADC(dac_index))
def __repr__(self):
rstr = ''
for i in range(7):
r = element_if_equal(self.__getitem__(i))
if isinstance(r, list):
rstr += ' '.join(f'{item} mV' for item in r)
else:
rstr += f'{i}: {r} mV\n'
return rstr.strip('\n')

View File

@ -111,14 +111,14 @@ def make_string_path(path):
def set_using_dict(func, args):
if isinstance(args, dict):
if isinstance(args, dict) and all(isinstance(k, int) for k in args.keys()):
for key, value in args.items():
func(value, [key])
else:
func(args)
def set_time_using_dict(func, args):
if isinstance(args, dict):
if isinstance(args, dict) and all(isinstance(k, int) for k in args.keys()):
for key, value in args.items():
if isinstance(value, int):
value = float(value)