Source code for rsrtx.Implementations.Search.Trigger.Slewrate.Range

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)