Source code for RsSmw.Implementations.Source.Bb.Arbitrary

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


# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class ArbitraryCls:
	"""
	| Commands in total: 174
	| Subgroups: 13
	| Direct child commands: 3
	"""

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

	@property
	def cfr(self):
		"""
		| Commands in total: 17
		| Subgroups: 3
		| Direct child commands: 14
		"""
		if not hasattr(self, '_cfr'):
			from .Cfr import CfrCls
			self._cfr = CfrCls(self._core, self._cmd_group)
		return self._cfr

	@property
	def clock(self):
		"""
		| Commands in total: 4
		| Subgroups: 0
		| Direct child commands: 4
		"""
		if not hasattr(self, '_clock'):
			from .Clock import ClockCls
			self._clock = ClockCls(self._core, self._cmd_group)
		return self._clock

	@property
	def coupled(self):
		"""
		| Commands in total: 2
		| Subgroups: 1
		| Direct child commands: 1
		"""
		if not hasattr(self, '_coupled'):
			from .Coupled import CoupledCls
			self._coupled = CoupledCls(self._core, self._cmd_group)
		return self._coupled

	@property
	def ethernet(self):
		"""
		| Commands in total: 16
		| Subgroups: 4
		| Direct child commands: 1
		"""
		if not hasattr(self, '_ethernet'):
			from .Ethernet import EthernetCls
			self._ethernet = EthernetCls(self._core, self._cmd_group)
		return self._ethernet

	@property
	def mcarrier(self):
		"""
		| Commands in total: 37
		| Subgroups: 9
		| Direct child commands: 4
		"""
		if not hasattr(self, '_mcarrier'):
			from .Mcarrier import McarrierCls
			self._mcarrier = McarrierCls(self._core, self._cmd_group)
		return self._mcarrier

	@property
	def notch(self):
		"""
		| Commands in total: 8
		| Subgroups: 4
		| Direct child commands: 3
		"""
		if not hasattr(self, '_notch'):
			from .Notch import NotchCls
			self._notch = NotchCls(self._core, self._cmd_group)
		return self._notch

	@property
	def pramp(self):
		"""
		| Commands in total: 1
		| Subgroups: 0
		| Direct child commands: 1
		"""
		if not hasattr(self, '_pramp'):
			from .Pramp import PrampCls
			self._pramp = PrampCls(self._core, self._cmd_group)
		return self._pramp

	@property
	def producer(self):
		"""
		| Commands in total: 2
		| Subgroups: 0
		| Direct child commands: 2
		"""
		if not hasattr(self, '_producer'):
			from .Producer import ProducerCls
			self._producer = ProducerCls(self._core, self._cmd_group)
		return self._producer

	@property
	def signal(self):
		"""
		| Commands in total: 1
		| Subgroups: 0
		| Direct child commands: 1
		"""
		if not hasattr(self, '_signal'):
			from .Signal import SignalCls
			self._signal = SignalCls(self._core, self._cmd_group)
		return self._signal

	@property
	def trigger(self):
		"""
		| Commands in total: 30
		| Subgroups: 7
		| Direct child commands: 7
		"""
		if not hasattr(self, '_trigger'):
			from .Trigger import TriggerCls
			self._trigger = TriggerCls(self._core, self._cmd_group)
		return self._trigger

	@property
	def tsignal(self):
		"""
		| Commands in total: 18
		| Subgroups: 4
		| Direct child commands: 0
		"""
		if not hasattr(self, '_tsignal'):
			from .Tsignal import TsignalCls
			self._tsignal = TsignalCls(self._core, self._cmd_group)
		return self._tsignal

	@property
	def waveform(self):
		"""
		| Commands in total: 9
		| Subgroups: 2
		| Direct child commands: 5
		"""
		if not hasattr(self, '_waveform'):
			from .Waveform import WaveformCls
			self._waveform = WaveformCls(self._core, self._cmd_group)
		return self._waveform

	@property
	def wsegment(self):
		"""
		| Commands in total: 26
		| Subgroups: 3
		| Direct child commands: 5
		"""
		if not hasattr(self, '_wsegment'):
			from .Wsegment import WsegmentCls
			self._wsegment = WsegmentCls(self._core, self._cmd_group)
		return self._wsegment

	# noinspection PyTypeChecker
[docs] def get_mode(self) -> enums.ArbMode: """ ``[SOURce<HW>]:BB:ARBitrary:MODE`` \n Snippet: ``value: enums.ArbMode = driver.source.bb.arbitrary.get_mode()`` \n Defines the mode of the ARB application. :return: arb_mode: STANdard | EUPLoad | ESTReaming STANdard ARB standard mode using a waveform file as an internal baseband source. EUPLoad ARB Ethernet upload mode for uploading waveform files via the external QSFP+ interface. ESTReaming ARB Ethernet streaming mode for I/Q streaming via the external QSFP+ interface. """ response = self._core.io.query_str('SOURce<HwInstance>:BB:ARBitrary:MODE?') return Conversions.str_to_scalar_enum(response, enums.ArbMode)
[docs] def set_mode(self, arb_mode: enums.ArbMode) -> None: """ ``[SOURce<HW>]:BB:ARBitrary:MODE`` \n Snippet: ``driver.source.bb.arbitrary.set_mode(arb_mode = enums.ArbMode.ESTReaming)`` \n Defines the mode of the ARB application. :param arb_mode: STANdard | EUPLoad | ESTReaming STANdard ARB standard mode using a waveform file as an internal baseband source. EUPLoad ARB Ethernet upload mode for uploading waveform files via the external QSFP+ interface. ESTReaming ARB Ethernet streaming mode for I/Q streaming via the external QSFP+ interface. """ param = Conversions.enum_scalar_to_str(arb_mode, enums.ArbMode) self._core.io.write(f'SOURce<HwInstance>:BB:ARBitrary:MODE {param}')
[docs] def preset(self) -> None: """ ``[SOURce<HW>]:BB:ARBitrary:PRESet`` \n Snippet: ``driver.source.bb.arbitrary.preset()`` \n Sets all ARB generator parameters to their default values. """ self._core.io.write(f'SOURce<HwInstance>:BB:ARBitrary:PRESet')
[docs] def preset_with_opc(self, opc_timeout_ms: int = -1) -> None: """ ``[SOURce<HW>]:BB:ARBitrary:PRESet`` \n Snippet: ``driver.source.bb.arbitrary.preset_with_opc()`` \n Sets all ARB generator parameters to their default values. Same as preset, but waits for the operation to complete before continuing further. Use the RsSmw.utilities.opc_timeout_set() to set the timeout value. :param opc_timeout_ms: Maximum time to wait in milliseconds, valid only for this call. """ self._core.io.write_with_opc(f'SOURce<HwInstance>:BB:ARBitrary:PRESet', opc_timeout_ms)
[docs] def get_state(self) -> bool: """ ``[SOURce<HW>]:BB:ARBitrary:STATe`` \n Snippet: ``value: bool = driver.source.bb.arbitrary.get_state()`` \n Enables the ARB generator. A waveform must be selected before the ARB generator is activated. :return: state: 1 | ON | 0| OFF """ response = self._core.io.query_str('SOURce<HwInstance>:BB:ARBitrary:STATe?') return Conversions.str_to_bool(response)
[docs] def set_state(self, state: bool) -> None: """ ``[SOURce<HW>]:BB:ARBitrary:STATe`` \n Snippet: ``driver.source.bb.arbitrary.set_state(state = False)`` \n Enables the ARB generator. A waveform must be selected before the ARB generator is activated. :param state: 1 | ON | 0| OFF """ param = Conversions.bool_to_str(state) self._core.io.write(f'SOURce<HwInstance>:BB:ARBitrary:STATe {param}')
def clone(self) -> 'ArbitraryCls': """ Clones the group by creating new object from it and its whole existing subgroups. Also copies all the existing default Repeated Capabilities setting, which you can change independently without affecting the original group. """ new_group = ArbitraryCls(self._core, self._cmd_group.parent) self._cmd_group.synchronize_repcaps(new_group) return new_group