Commit ba6ecc62 authored by Arnaud WATLET's avatar Arnaud WATLET
Browse files

Updates mux_2023_0_x as mux_2024_0_x

Showing with 14 additions and 25 deletions
+14 -25
...@@ -8,20 +8,8 @@ import adafruit_tca9548a # noqa ...@@ -8,20 +8,8 @@ import adafruit_tca9548a # noqa
from adafruit_mcp230xx.mcp23017 import MCP23017 # noqa from adafruit_mcp230xx.mcp23017 import MCP23017 # noqa
from digitalio import Direction # noqa from digitalio import Direction # noqa
# board specs # hardware characteristics and limitations
voltage_max = 50 SPECS = {'voltage_max': 50., 'current_max': 3., 'activation_delay': 0.01, 'release_delay': 0.005}
current_max = 3.
activation_delay = 0.01
release_delay = 0.005
MUX_CONFIG = HARDWARE_CONFIG['mux'].pop('default', {})
MUX_CONFIG.update({'voltage_max': max(0.,min(MUX_CONFIG.pop('voltage_max', voltage_max), voltage_max)),
'current_max': max(0.,min(MUX_CONFIG.pop('current_max', voltage_max), voltage_max))})
MUX_CONFIG.update({'activation_delay': max(MUX_CONFIG.pop('activation_delay', activation_delay), activation_delay),
'release_delay': max(MUX_CONFIG.pop('release_delay', release_delay), release_delay)})
# defaults to ic connection
ctl_connection = MUX_CONFIG.pop('connection', 'i2c')
default_mux_cabling = {(elec, role) : ('mux_1', elec) for role in ['A', 'B', 'M', 'N'] for elec in range(1,9)} # defaults to 4 roles cabling electrodes from 1 to 8 default_mux_cabling = {(elec, role) : ('mux_1', elec) for role in ['A', 'B', 'M', 'N'] for elec in range(1,9)} # defaults to 4 roles cabling electrodes from 1 to 8
...@@ -61,17 +49,19 @@ inner_cabling = {'1_role' : {(1, 'X'): {'MCP': 0, 'MCP_GPIO': 0}, (2, 'X'): {'MC ...@@ -61,17 +49,19 @@ inner_cabling = {'1_role' : {(1, 'X'): {'MCP': 0, 'MCP_GPIO': 0}, (2, 'X'): {'MC
class Mux(MuxAbstract): class Mux(MuxAbstract):
def __init__(self, **kwargs): def __init__(self, **kwargs):
if 'id' in kwargs.keys():
MUX_CONFIG.update(HARDWARE_CONFIG['mux']['boards'][kwargs['id']])
kwargs.update({'board_name': os.path.basename(__file__).rstrip('.py')}) kwargs.update({'board_name': os.path.basename(__file__).rstrip('.py')})
if 'cabling' not in kwargs.keys() or kwargs['cabling']=={}: kwargs.update({'cabling': kwargs.pop('cabling', default_mux_cabling)})
kwargs.update({'cabling': default_mux_cabling}) kwargs.update({'activation_delay': max(kwargs.pop('activation_delay', SPECS['activation_delay']),
if 'activation_delay' not in kwargs: SPECS['activation_delay'])})
kwargs.update({'activation_delay': MUX_CONFIG['activation_delay']}) kwargs.update({'release_delay': max(kwargs.pop('release_delay', SPECS['release_delay']),
if 'release_delay' not in kwargs: SPECS['activation_delay'])})
kwargs.update({'release_delay': MUX_CONFIG['release_delay']}) kwargs.update({'voltage_max': max(0., min(kwargs.pop('voltage_max', SPECS['voltage_max']),
SPECS['voltage_max']))})
kwargs.update({'current_max': max(0., min(kwargs.pop('current_max', SPECS['current_max']),
SPECS['current_max']))})
super().__init__(**kwargs) super().__init__(**kwargs)
self.exec_logger.debug(f'configuration: {MUX_CONFIG}') assert isinstance(self.connection, I2C)
self.exec_logger.debug(f'configuration: {kwargs}')
tca_address = kwargs.pop('tca_address', 0x70) tca_address = kwargs.pop('tca_address', 0x70)
# tca_channel = kwargs.pop('tca_channel', 0) # tca_channel = kwargs.pop('tca_channel', 0)
self._roles = kwargs.pop('roles', None) self._roles = kwargs.pop('roles', None)
...@@ -82,8 +72,7 @@ class Mux(MuxAbstract): ...@@ -82,8 +72,7 @@ class Mux(MuxAbstract):
else: else:
self.exec_logger.error(f'Invalid role assignment for {self.board_name}: {self._roles} !') self.exec_logger.error(f'Invalid role assignment for {self.board_name}: {self._roles} !')
self._mode = '' self._mode = ''
self.io = self.ctl.interfaces[kwargs.pop('connection', ctl_connection)] self._tca = [adafruit_tca9548a.TCA9548A(self.connection, tca_address)[i] for i in np.arange(7, 3, -1)]
self._tca = [adafruit_tca9548a.TCA9548A(self.io, tca_address)[i] for i in np.arange(7, 3, -1)]
# self._mcp_addresses = (kwargs.pop('mcp', '0x20')) # TODO: add assert on valid addresses.. # self._mcp_addresses = (kwargs.pop('mcp', '0x20')) # TODO: add assert on valid addresses..
self._mcp = [None, None, None, None] self._mcp = [None, None, None, None]
self.reset() self.reset()
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment