from .....Internal.Core import Core
from .....Internal.CommandsGroup import CommandsGroup
from .....Internal import Conversions
from ..... import repcap
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class AutoCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("auto", core, parent)
[docs]
def set(self, rf_att_auto: bool, channel=repcap.Channel.Default) -> None:
"""
``CHANnel<*>:EFRontend:ATTenuation:AUTO`` \n
Snippet: ``driver.channel.efrontend.attenuation.auto.set(rf_att_auto = False, channel = repcap.Channel.Default)`` \n
Defines the RF attenuation, which is meant to protect the mixer of the external frontend from high RF input levels.
:param rf_att_auto: OFF | ON \n
- ON: The instrument provides a good compromise between intermodulation and noise.
- OFF: Set CHANnelch:EFRontend:ATTenuation[:VALue] to fine-tune the effect of intermodulation and noise.
:param channel: optional repeated capability selector. Default value: Ch1 (settable in the interface 'Channel')
"""
param = Conversions.bool_to_str(rf_att_auto)
channel_cmd_val = self._cmd_group.get_repcap_cmd_value(channel, repcap.Channel)
self._core.io.write_with_opc(f'CHANnel{channel_cmd_val}:EFRontend:ATTenuation:AUTO {param}')
[docs]
def get(self, channel=repcap.Channel.Default) -> bool:
"""
``CHANnel<*>:EFRontend:ATTenuation:AUTO`` \n
Snippet: ``value: bool = driver.channel.efrontend.attenuation.auto.get(channel = repcap.Channel.Default)`` \n
Defines the RF attenuation, which is meant to protect the mixer of the external frontend from high RF input levels.
:param channel: optional repeated capability selector. Default value: Ch1 (settable in the interface 'Channel')
"""
channel_cmd_val = self._cmd_group.get_repcap_cmd_value(channel, repcap.Channel)
response = self._core.io.query_str_with_opc(f'CHANnel{channel_cmd_val}:EFRontend:ATTenuation:AUTO?')
return Conversions.str_to_bool(response)