from ........Internal.Core import Core
from ........Internal.CommandsGroup import CommandsGroup
from ........Internal import Conversions
from ........ import repcap
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class ResolutionCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("resolution", core, parent)
[docs]
def set(self, rbw: float, subBlock=repcap.SubBlock.Default, rangePy=repcap.RangePy.Default) -> None:
"""
``[SENSe]:ESPectrum<sb>:RANGe<range>:BANDwidth:RESolution`` \n
Snippet: ``driver.applications.k14Xnr5G.sense.espectrum.range.bandwidth.resolution.set(rbw = 1.0, subBlock = repcap.SubBlock.Default, rangePy = repcap.RangePy.Default)`` \n
Defines the resolution bandwidth for a SEM range. In case of high speed measurements, the resolution bandwidth has to be
identical for all ranges.
:param rbw: Resolution bandwidth. Refer to the specifications document for available resolution bandwidths. Unit: Hz
:param subBlock: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Espectrum')
:param rangePy: optional repeated capability selector. Default value: Ix1 (settable in the interface 'Range')
"""
param = Conversions.decimal_value_to_str(rbw)
subBlock_cmd_val = self._cmd_group.get_repcap_cmd_value(subBlock, repcap.SubBlock)
rangePy_cmd_val = self._cmd_group.get_repcap_cmd_value(rangePy, repcap.RangePy)
self._core.io.write(f'SENSe:ESPectrum{subBlock_cmd_val}:RANGe{rangePy_cmd_val}:BANDwidth:RESolution {param}')
[docs]
def get(self, subBlock=repcap.SubBlock.Default, rangePy=repcap.RangePy.Default) -> float:
"""
``[SENSe]:ESPectrum<sb>:RANGe<range>:BANDwidth:RESolution`` \n
Snippet: ``value: float = driver.applications.k14Xnr5G.sense.espectrum.range.bandwidth.resolution.get(subBlock = repcap.SubBlock.Default, rangePy = repcap.RangePy.Default)`` \n
Defines the resolution bandwidth for a SEM range. In case of high speed measurements, the resolution bandwidth has to be
identical for all ranges.
:param subBlock: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Espectrum')
:param rangePy: optional repeated capability selector. Default value: Ix1 (settable in the interface 'Range')
:return: rbw: Resolution bandwidth. Refer to the specifications document for available resolution bandwidths. Unit: Hz
"""
subBlock_cmd_val = self._cmd_group.get_repcap_cmd_value(subBlock, repcap.SubBlock)
rangePy_cmd_val = self._cmd_group.get_repcap_cmd_value(rangePy, repcap.RangePy)
response = self._core.io.query_str(f'SENSe:ESPectrum{subBlock_cmd_val}:RANGe{rangePy_cmd_val}:BANDwidth:RESolution?')
return Conversions.str_to_float(response)