Source code for RsFsw.Implementations.Sense.Espectrum.Range.InputPy.Gain.Value

from .......Internal.Core import Core
from .......Internal.CommandsGroup import CommandsGroup
from .......Internal import Conversions
from ....... import repcap


# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class ValueCls:
	"""
	| Commands in total: 1
	| Subgroups: 0
	| Direct child commands: 1
	"""

	def __init__(self, core: Core, parent):
		self._core = core
		self._cmd_group = CommandsGroup("value", core, parent)

[docs] def set(self, gain: float, subBlock=repcap.SubBlock.Default, rangePy=repcap.RangePy.Default) -> None: """ ``[SENSe]:ESPectrum<sb>:RANGe<ri>:INPut:GAIN[:VALue]`` \n Snippet: ``driver.sense.espectrum.range.inputPy.gain.value.set(gain = 1.0, subBlock = repcap.SubBlock.Default, rangePy = repcap.RangePy.Default)`` \n This command selects the gain for a SEM range. In case of high speed measurements, the level of the preamplifier has to be identical for all ranges. :param gain: 15 dB | 30 dB The availability of preamplification levels depends on the FSW model. - FSW8/13: 15dB and 30 dB - FSW26 or higher: 30 dB All other values are rounded to the nearest of these two. :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(gain) 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}:INPut:GAIN:VALue {param}')
[docs] def get(self, subBlock=repcap.SubBlock.Default, rangePy=repcap.RangePy.Default) -> float: """ ``[SENSe]:ESPectrum<sb>:RANGe<ri>:INPut:GAIN[:VALue]`` \n Snippet: ``value: float = driver.sense.espectrum.range.inputPy.gain.value.get(subBlock = repcap.SubBlock.Default, rangePy = repcap.RangePy.Default)`` \n This command selects the gain for a SEM range. In case of high speed measurements, the level of the preamplifier 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: gain: 15 dB | 30 dB The availability of preamplification levels depends on the FSW model. - FSW8/13: 15dB and 30 dB - FSW26 or higher: 30 dB All other values are rounded to the nearest of these two. """ 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}:INPut:GAIN:VALue?') return Conversions.str_to_float(response)