from .......Internal.Core import Core
from .......Internal.CommandsGroup import CommandsGroup
from .......Internal import Conversions
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class AutoCls:
"""
| Commands in total: 2
| Subgroups: 1
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("auto", core, parent)
@property
def mode(self):
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
if not hasattr(self, '_mode'):
from .Mode import ModeCls
self._mode = ModeCls(self._core, self._cmd_group)
return self._mode
[docs]
def set(self, state: bool) -> None:
"""
``INPut:ATTenuation:AUTO`` \n
Snippet: ``driver.applications.k18AmplifierEt.inputPy.attenuation.auto.set(state = False)`` \n
Couples or decouples the attenuation to the reference level. Thus, when the reference level is changed, the FSW
determines the signal level for optimal internal data processing and sets the required attenuation accordingly.
If an external frontend is active (see [SENSe:]EFRontend[:STATe]) , you can configure the attenuation of the external
frontend and the analyzer separately. See also method ``RsFsw.inputPy.sanalyzer.attenuation.auto.set()`` and method
``RsFsw.inputPy.sanalyzer.attenuation.set()`` .
:param state: ON | OFF | 0 | 1
"""
param = Conversions.bool_to_str(state)
self._core.io.write(f'INPut:ATTenuation:AUTO {param}')
[docs]
def get(self) -> bool:
"""
``INPut:ATTenuation:AUTO`` \n
Snippet: ``value: bool = driver.applications.k18AmplifierEt.inputPy.attenuation.auto.get()`` \n
Couples or decouples the attenuation to the reference level. Thus, when the reference level is changed, the FSW
determines the signal level for optimal internal data processing and sets the required attenuation accordingly.
If an external frontend is active (see [SENSe:]EFRontend[:STATe]) , you can configure the attenuation of the external
frontend and the analyzer separately. See also method ``RsFsw.inputPy.sanalyzer.attenuation.auto.set()`` and method
``RsFsw.inputPy.sanalyzer.attenuation.set()`` .
:return: state: ON | OFF | 0 | 1
"""
response = self._core.io.query_str(f'INPut:ATTenuation:AUTO?')
return Conversions.str_to_bool(response)
def clone(self) -> 'AutoCls':
"""
Clones the group by creating new object from it and its whole existing subgroups.
Also copies all the existing default Repeated Capabilities setting,
which you can change independently without affecting the original group.
"""
new_group = AutoCls(self._core, self._cmd_group.parent)
self._cmd_group.synchronize_repcaps(new_group)
return new_group