from .......Internal.Core import Core
from .......Internal.CommandsGroup import CommandsGroup
from .......Internal import Conversions
from ....... import enums
from ....... import repcap
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class SelectCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("select", core, parent)
[docs]
def set(self, cdr_type: enums.CdrType, lane=repcap.Lane.Default) -> None:
"""
``LANE<*>:EQUalization:DFE:TIMReference:CDR[:SELect]`` \n
Snippet: ``driver.lane.equalization.dfe.timReference.cdr.select.set(cdr_type = enums.CdrType.HW, lane = repcap.Lane.Default)`` \n
Selects hardware or software clock data recovery. Available,
if method ``RsRtx.lane.equalization.dfe.timReference.source.set()`` is set to CDR.
:param cdr_type: SW | HW
:param lane: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Lane')
"""
param = Conversions.enum_scalar_to_str(cdr_type, enums.CdrType)
lane_cmd_val = self._cmd_group.get_repcap_cmd_value(lane, repcap.Lane)
self._core.io.write_with_opc(f'LANE{lane_cmd_val}:EQUalization:DFE:TIMReference:CDR:SELect {param}')
# noinspection PyTypeChecker
[docs]
def get(self, lane=repcap.Lane.Default) -> enums.CdrType:
"""
``LANE<*>:EQUalization:DFE:TIMReference:CDR[:SELect]`` \n
Snippet: ``value: enums.CdrType = driver.lane.equalization.dfe.timReference.cdr.select.get(lane = repcap.Lane.Default)`` \n
Selects hardware or software clock data recovery. Available,
if method ``RsRtx.lane.equalization.dfe.timReference.source.set()`` is set to CDR.
:param lane: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Lane')
:return: cdr_type: SW | HW
"""
lane_cmd_val = self._cmd_group.get_repcap_cmd_value(lane, repcap.Lane)
response = self._core.io.query_str_with_opc(f'LANE{lane_cmd_val}:EQUalization:DFE:TIMReference:CDR:SELect?')
return Conversions.str_to_scalar_enum(response, enums.CdrType)