from .....Internal.Core import Core
from .....Internal.CommandsGroup import CommandsGroup
from .....Internal import Conversions
from .....Internal.Types import DataType
from .....Internal.ArgSingleList import ArgSingleList
from .....Internal.ArgSingle import ArgSingle
from ..... import enums
# 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, search: str, range_mode: enums.SlewRangeMode) -> None:
"""
``SEARch:TRIGger:SLEWrate:RANGe`` \n
Snippet: ``driver.search.trigger.slewrate.range.set(search = 'abc', range_mode = enums.SlewRangeMode.GTHan)`` \n
Selects how the time limit for the slew rate is defined. The time measurement starts when the signal crosses the first
trigger level - the upper or lower level depending on the selected slope - and stops when the signal crosses the second
level.
:param search: String with the name of the search
:param range_mode: INSRange | OUTRange | LTHan | GTHan \n
- INSRange: Triggers on slew rates inside a given time range. The range is defined by Slew rate and ±Delta.
- OUTRange: Triggers on slew rates outside a given time range. The range definition is the same as for Within range.
- LTHan: Triggers on slew rates shorter than the given Slew rate limit.
- GTHan: Triggers on slew rates longer than the given Slew rate limit.
"""
param = ArgSingleList().compose_cmd_string(ArgSingle('search', search, DataType.String), ArgSingle('range_mode', range_mode, DataType.Enum, enums.SlewRangeMode))
self._core.io.write_with_opc(f'SEARch:TRIGger:SLEWrate:RANGe {param}'.rstrip())
# noinspection PyTypeChecker
[docs]
def get(self, search: str) -> enums.SlewRangeMode:
"""
``SEARch:TRIGger:SLEWrate:RANGe`` \n
Snippet: ``value: enums.SlewRangeMode = driver.search.trigger.slewrate.range.get(search = 'abc')`` \n
Selects how the time limit for the slew rate is defined. The time measurement starts when the signal crosses the first
trigger level - the upper or lower level depending on the selected slope - and stops when the signal crosses the second
level.
:param search: String with the name of the search
:return: range_mode: INSRange | OUTRange | LTHan | GTHan \n
- INSRange: Triggers on slew rates inside a given time range. The range is defined by Slew rate and ±Delta.
- OUTRange: Triggers on slew rates outside a given time range. The range definition is the same as for Within range.
- LTHan: Triggers on slew rates shorter than the given Slew rate limit.
- GTHan: Triggers on slew rates longer than the given Slew rate limit.
"""
param = Conversions.value_to_quoted_str(search)
response = self._core.io.query_str_with_opc(f'SEARch:TRIGger:SLEWrate:RANGe? {param}')
return Conversions.str_to_scalar_enum(response, enums.SlewRangeMode)