Merge branch 'wip' of git.psi.ch:sinqdev/frappy into wip
This commit is contained in:
commit
6ec8348355
@ -23,7 +23,7 @@
|
|||||||
not tested yet"""
|
not tested yet"""
|
||||||
|
|
||||||
from secop.core import Attached, BoolType, EnumType, FloatRange, \
|
from secop.core import Attached, BoolType, EnumType, FloatRange, \
|
||||||
HasIodev, Module, Parameter, StringIO, Writable
|
HasIodev, Module, Parameter, StringIO, Writable, Done
|
||||||
|
|
||||||
|
|
||||||
class K2601bIO(StringIO):
|
class K2601bIO(StringIO):
|
||||||
@ -31,13 +31,16 @@ class K2601bIO(StringIO):
|
|||||||
|
|
||||||
|
|
||||||
SOURCECMDS = {
|
SOURCECMDS = {
|
||||||
|
0: 'reset()'
|
||||||
|
' smua.source.func = smua.OUTPUT_DCAMPS'
|
||||||
|
' display.smua.measure.func = display.MEASURE_VOLTS'
|
||||||
|
' smua.source.autorangei = 1'
|
||||||
|
' smua.source.output = %d print("ok"")',
|
||||||
1: 'reset()'
|
1: 'reset()'
|
||||||
'smua.source.func = smua.OUTPUT_DCVOLTS '
|
' smua.source.func = smua.OUTPUT_DCVOLTS'
|
||||||
'display.smua.measure.func = display.MEASURE_DCAMP '
|
' display.smua.measure.func = display.MEASURE_DCAMPS'
|
||||||
'smua.source.autorangev = 1',
|
' smua.source.autorangev = 1'
|
||||||
2: 'reset()'
|
' smua.source.output = %d print("ok"")',
|
||||||
'smua.source.func = smua.OUTPUT_DCAMPS '
|
|
||||||
'smua.source.autorangei = 1',
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -45,9 +48,8 @@ class SourceMeter(HasIodev, Module):
|
|||||||
|
|
||||||
resistivity = Parameter('readback resistivity', FloatRange(unit='Ohm'), poll=True)
|
resistivity = Parameter('readback resistivity', FloatRange(unit='Ohm'), poll=True)
|
||||||
power = Parameter('readback power', FloatRange(unit='W'), poll=True)
|
power = Parameter('readback power', FloatRange(unit='W'), poll=True)
|
||||||
mode = Parameter('measurement mode', EnumType(off=0, current=1, voltage=2),
|
mode = Parameter('measurement mode', EnumType(current_off=0, voltage_off=1, current_on=2, voltage_on=3),
|
||||||
readonly=False, default=0)
|
readonly=False, poll=True)
|
||||||
active = Parameter('output enable', BoolType(), readonly=False, poll=True)
|
|
||||||
|
|
||||||
iodevClass = K2601bIO
|
iodevClass = K2601bIO
|
||||||
|
|
||||||
@ -57,20 +59,12 @@ class SourceMeter(HasIodev, Module):
|
|||||||
def read_power(self):
|
def read_power(self):
|
||||||
return self.sendRecv('print(smua.measure.p())')
|
return self.sendRecv('print(smua.measure.p())')
|
||||||
|
|
||||||
def read_active(self):
|
def read_mode(self):
|
||||||
return self.sendRecv('print(smua.source.output)')
|
return float(self.sendRecv('print(smua.source.func+2*smua.source.output)'))
|
||||||
|
|
||||||
def write_active(self, value):
|
|
||||||
return self.sendRecv('smua.source.output = %d print(smua.source.output)' % value)
|
|
||||||
|
|
||||||
# for now, mode will not be read from hardware
|
|
||||||
|
|
||||||
def write_mode(self, value):
|
def write_mode(self, value):
|
||||||
if value == 0:
|
assert 'ok' == self.sendRecv(SOURCECMDS[value % 2] % (value >= 2))
|
||||||
self.write_active(0)
|
return self.read_mode()
|
||||||
else:
|
|
||||||
self.sendRecv(SOURCECMDS[value] + ' print(0)')
|
|
||||||
return value
|
|
||||||
|
|
||||||
|
|
||||||
class Current(HasIodev, Writable):
|
class Current(HasIodev, Writable):
|
||||||
@ -78,9 +72,12 @@ class Current(HasIodev, Writable):
|
|||||||
|
|
||||||
value = Parameter('measured current', FloatRange(unit='A'), poll=True)
|
value = Parameter('measured current', FloatRange(unit='A'), poll=True)
|
||||||
target = Parameter('set current', FloatRange(unit='A'), poll=True)
|
target = Parameter('set current', FloatRange(unit='A'), poll=True)
|
||||||
active = Parameter('current is controlled', BoolType(), default=False) # polled from Current/Voltage
|
active = Parameter('current is controlled', BoolType(), default=False) # polled by SourceMeter
|
||||||
limit = Parameter('current limit', FloatRange(0, 2.0, unit='A'), default=2, poll=True)
|
limit = Parameter('current limit', FloatRange(0, 2.0, unit='A'), default=2, poll=True)
|
||||||
|
|
||||||
|
def initModule(self):
|
||||||
|
self._sourcemeter.registerCallbacks(self)
|
||||||
|
|
||||||
def read_value(self):
|
def read_value(self):
|
||||||
return self.sendRecv('print(smua.measure.i())')
|
return self.sendRecv('print(smua.measure.i())')
|
||||||
|
|
||||||
@ -104,16 +101,16 @@ class Current(HasIodev, Writable):
|
|||||||
return value
|
return value
|
||||||
return self.sendRecv('smua.source.limiti = %g print(smua.source.limiti)' % value)
|
return self.sendRecv('smua.source.limiti = %g print(smua.source.limiti)' % value)
|
||||||
|
|
||||||
def read_active(self):
|
|
||||||
return self._sourcemeter.mode == 1 and self._sourcemeter.read_active()
|
|
||||||
|
|
||||||
def write_active(self, value):
|
def write_active(self, value):
|
||||||
if self._sourcemeter.mode != 1:
|
if value:
|
||||||
if value:
|
self._sourcemeter.write_mode('current_on')
|
||||||
self._sourcemeter.write_mode(1) # switch to current
|
elif self._sourcemeter.mode == 'current_on':
|
||||||
else:
|
self._sourcemeter.write_mode('current_off')
|
||||||
return 0
|
return self.active
|
||||||
return self._sourcemeter.write_active(value)
|
|
||||||
|
def update_mode(self, mode):
|
||||||
|
# will be called whenever the attached sourcemeters mode changes
|
||||||
|
self.active = mode == 'current_on'
|
||||||
|
|
||||||
|
|
||||||
class Voltage(HasIodev, Writable):
|
class Voltage(HasIodev, Writable):
|
||||||
@ -121,9 +118,12 @@ class Voltage(HasIodev, Writable):
|
|||||||
|
|
||||||
value = Parameter('measured voltage', FloatRange(unit='V'), poll=True)
|
value = Parameter('measured voltage', FloatRange(unit='V'), poll=True)
|
||||||
target = Parameter('set voltage', FloatRange(unit='V'), poll=True)
|
target = Parameter('set voltage', FloatRange(unit='V'), poll=True)
|
||||||
active = Parameter('voltage is controlled', BoolType(), poll=True)
|
active = Parameter('voltage is controlled', BoolType(), default=False) # polled by SourceMeter
|
||||||
limit = Parameter('current limit', FloatRange(0, 2.0, unit='V'), default=2, poll=True)
|
limit = Parameter('current limit', FloatRange(0, 2.0, unit='V'), default=2, poll=True)
|
||||||
|
|
||||||
|
def initModule(self):
|
||||||
|
self._sourcemeter.registerCallbacks(self)
|
||||||
|
|
||||||
def read_value(self):
|
def read_value(self):
|
||||||
return self.sendRecv('print(smua.measure.v())')
|
return self.sendRecv('print(smua.measure.v())')
|
||||||
|
|
||||||
@ -147,13 +147,13 @@ class Voltage(HasIodev, Writable):
|
|||||||
return value
|
return value
|
||||||
return self.sendRecv('smua.source.limitv = %g print(smua.source.limitv)' % value)
|
return self.sendRecv('smua.source.limitv = %g print(smua.source.limitv)' % value)
|
||||||
|
|
||||||
def read_active(self):
|
|
||||||
return self._sourcemeter.mode == 2 and self._sourcemeter.read_active()
|
|
||||||
|
|
||||||
def write_active(self, value):
|
def write_active(self, value):
|
||||||
if self._sourcemeter.mode != 2:
|
if value:
|
||||||
if value:
|
self._sourcemeter.write_mode('voltage_on')
|
||||||
self._sourcemeter.write_mode(2) # switch to voltage
|
elif self._sourcemeter.mode == 'voltage_on':
|
||||||
else:
|
self._sourcemeter.write_mode('voltage_off')
|
||||||
return 0
|
return self.active
|
||||||
return self._sourcemeter.write_active(value)
|
|
||||||
|
def update_mode(self, mode):
|
||||||
|
# will be called whenever the attached sourcemeters mode changes
|
||||||
|
self.active = mode == 'voltage_on'
|
||||||
|
@ -228,7 +228,7 @@ class ResChannel(HasIodev, Readable):
|
|||||||
if autorange:
|
if autorange:
|
||||||
result['autorange'] = 'hard'
|
result['autorange'] = 'hard'
|
||||||
# else: do not change autorange
|
# else: do not change autorange
|
||||||
self.log.info('%s range %r %r %r' % (self.name, rng, autorange, self.autorange))
|
# self.log.info('%s range %r %r %r' % (self.name, rng, autorange, self.autorange))
|
||||||
if excoff:
|
if excoff:
|
||||||
result.update(iexc=0, vexc=0)
|
result.update(iexc=0, vexc=0)
|
||||||
elif iscur:
|
elif iscur:
|
||||||
|
@ -181,13 +181,16 @@ class Sensor(Readable):
|
|||||||
pollerClass = None
|
pollerClass = None
|
||||||
_value_error = None
|
_value_error = None
|
||||||
|
|
||||||
def __init__(self, name, logger, cfgdict, srv):
|
def checkProperties(self):
|
||||||
cfgdict.setdefault('description', 'calibrated value of module %r' % cfgdict['rawsensor'])
|
if 'description' not in self.propertyValues:
|
||||||
super().__init__(name, logger, cfgdict, srv)
|
self.description = '_' # avoid complaining about missing description
|
||||||
|
super().checkProperties()
|
||||||
|
|
||||||
def initModule(self):
|
def initModule(self):
|
||||||
self._rawsensor.registerCallbacks(self, ['status']) # auto update status
|
self._rawsensor.registerCallbacks(self, ['status']) # auto update status
|
||||||
self._calib = CalCurve(self.calib)
|
self._calib = CalCurve(self.calib)
|
||||||
|
if self.description == '_':
|
||||||
|
self.description = '%r calibrated with curve %r' % (self.rawsensor, self.calib)
|
||||||
|
|
||||||
def write_calib(self, value):
|
def write_calib(self, value):
|
||||||
self._calib = CalCurve(value)
|
self._calib = CalCurve(value)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user