Source code for rsrtx.Implementations.Trigger.Parallel.Pattern.Mode

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


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

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

[docs] def set(self, mode: enums.PatternMode, trigger=repcap.Trigger.Default) -> None: """ ``TRIGger<*>:PARallel:PATTern:MODE`` \n Snippet: ``driver.trigger.parallel.pattern.mode.set(mode = enums.PatternMode.OFF, trigger = repcap.Trigger.Default)`` \n Sets the mode of the timing condition. :param mode: OFF | TIMeout | WIDTh \n - OFF: No timing condition, only the logical pattern condition is relevant. - TIMeout: Defines a minimum time qualification to avoid triggering on unstable or transitional conditions. Use TRIGgert:PARallel:PATTern:TIMeout:MODE and TRIGgert:PARallel:PATTern:TIMeout[:TIME] to specify the timeout. - WIDTh: Sets a pulse width as timing condition. The pulse starts when the pattern comes true, and the trigger event occurs when the pattern comes false during the specified time limit. Use TRIGgert:PARallel:PATTern:WIDTh:RANGe, TRIGgert:PARallel:PATTern:WIDTh[:WIDTh], and TRIGgert:PARallel:PATTern:WIDTh:DELTa to specify the width. :param trigger: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Trigger') """ param = Conversions.enum_scalar_to_str(mode, enums.PatternMode) trigger_cmd_val = self._cmd_group.get_repcap_cmd_value(trigger, repcap.Trigger) self._core.io.write_with_opc(f'TRIGger{trigger_cmd_val}:PARallel:PATTern:MODE {param}')
# noinspection PyTypeChecker
[docs] def get(self, trigger=repcap.Trigger.Default) -> enums.PatternMode: """ ``TRIGger<*>:PARallel:PATTern:MODE`` \n Snippet: ``value: enums.PatternMode = driver.trigger.parallel.pattern.mode.get(trigger = repcap.Trigger.Default)`` \n Sets the mode of the timing condition. :param trigger: optional repeated capability selector. Default value: Nr1 (settable in the interface 'Trigger') :return: mode: OFF | TIMeout | WIDTh \n - OFF: No timing condition, only the logical pattern condition is relevant. - TIMeout: Defines a minimum time qualification to avoid triggering on unstable or transitional conditions. Use TRIGgert:PARallel:PATTern:TIMeout:MODE and TRIGgert:PARallel:PATTern:TIMeout[:TIME] to specify the timeout. - WIDTh: Sets a pulse width as timing condition. The pulse starts when the pattern comes true, and the trigger event occurs when the pattern comes false during the specified time limit. Use TRIGgert:PARallel:PATTern:WIDTh:RANGe, TRIGgert:PARallel:PATTern:WIDTh[:WIDTh], and TRIGgert:PARallel:PATTern:WIDTh:DELTa to specify the width. """ trigger_cmd_val = self._cmd_group.get_repcap_cmd_value(trigger, repcap.Trigger) response = self._core.io.query_str_with_opc(f'TRIGger{trigger_cmd_val}:PARallel:PATTern:MODE?') return Conversions.str_to_scalar_enum(response, enums.PatternMode)