from ....Internal.Core import Core
from ....Internal.CommandsGroup import CommandsGroup
from ....Internal import Conversions
from .... import repcap
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class AttenuationCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("attenuation", core, parent)
[docs]
def set(self, attenuation: float, bus=repcap.Bus.Default) -> None:
"""
``BUS<*>:TBTO:ATTN`` \n
Snippet: ``driver.bus.tbto.attenuation.set(attenuation = 1.0, bus = repcap.Bus.Default)`` \n
Sets the attenuation factor. It is used to de-amplify the reverse signal before subtracting it from the forward signal.
:param attenuation: -100 to 0
:param bus: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Bus')
"""
param = Conversions.decimal_value_to_str(attenuation)
bus_cmd_val = self._cmd_group.get_repcap_cmd_value(bus, repcap.Bus)
self._core.io.write(f'BUS{bus_cmd_val}:TBTO:ATTN {param}')
[docs]
def get(self, bus=repcap.Bus.Default) -> float:
"""
``BUS<*>:TBTO:ATTN`` \n
Snippet: ``value: float = driver.bus.tbto.attenuation.get(bus = repcap.Bus.Default)`` \n
Sets the attenuation factor. It is used to de-amplify the reverse signal before subtracting it from the forward signal.
:param bus: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Bus')
:return: attenuation: -100 to 0
"""
bus_cmd_val = self._cmd_group.get_repcap_cmd_value(bus, repcap.Bus)
response = self._core.io.query_str(f'BUS{bus_cmd_val}:TBTO:ATTN?')
return Conversions.str_to_float(response)