from ...Internal.Core import Core
from ...Internal.CommandsGroup import CommandsGroup
from ...Internal import Conversions
from ... import repcap
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class RangeCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("range", core, parent)
[docs]
def set(self, range_py: float, channel=repcap.Channel.Default) -> None:
"""
``CHANnel<*>:RANGe`` \n
Snippet: ``driver.channel.range.set(range_py = 1.0, channel = repcap.Channel.Default)`` \n
Sets the voltage range across the 10 vertical divisions of the diagram. Use the command alternativly instead of method
``RsRtx.channel.scale.set()`` .
:param range_py: Voltage range value
:param channel: optional repeated capability selector. Default value: Ch1 (settable in the interface 'Channel')
"""
param = Conversions.decimal_value_to_str(range_py)
channel_cmd_val = self._cmd_group.get_repcap_cmd_value(channel, repcap.Channel)
self._core.io.write_with_opc(f'CHANnel{channel_cmd_val}:RANGe {param}')
[docs]
def get(self, channel=repcap.Channel.Default) -> float:
"""
``CHANnel<*>:RANGe`` \n
Snippet: ``value: float = driver.channel.range.get(channel = repcap.Channel.Default)`` \n
Sets the voltage range across the 10 vertical divisions of the diagram. Use the command alternativly instead of method
``RsRtx.channel.scale.set()`` .
:param channel: optional repeated capability selector. Default value: Ch1 (settable in the interface 'Channel')
:return: range_py: Voltage range value
"""
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}:RANGe?')
return Conversions.str_to_float(response)