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
[docs]class ArbitraryCls: """Arbitrary commands group definition. 167 total commands, 13 Subgroups, 3 group commands""" def __init__(self, core: Core, parent): self._core = core self._cmd_group = CommandsGroup("arbitrary", core, parent) @property def cfr(self): """cfr commands group. 3 Sub-classes, 14 commands.""" if not hasattr(self, '_cfr'): from .Cfr import CfrCls self._cfr = CfrCls(self._core, self._cmd_group) return self._cfr @property def clock(self): """clock commands group. 0 Sub-classes, 4 commands.""" if not hasattr(self, '_clock'): from .Clock import ClockCls self._clock = ClockCls(self._core, self._cmd_group) return self._clock @property def coupled(self): """coupled commands group. 1 Sub-classes, 1 commands.""" if not hasattr(self, '_coupled'): from .Coupled import CoupledCls self._coupled = CoupledCls(self._core, self._cmd_group) return self._coupled @property def ethernet(self): """ethernet commands group. 2 Sub-classes, 1 commands.""" if not hasattr(self, '_ethernet'): from .Ethernet import EthernetCls self._ethernet = EthernetCls(self._core, self._cmd_group) return self._ethernet @property def mcarrier(self): """mcarrier commands group. 9 Sub-classes, 4 commands.""" if not hasattr(self, '_mcarrier'): from .Mcarrier import McarrierCls self._mcarrier = McarrierCls(self._core, self._cmd_group) return self._mcarrier @property def notch(self): """notch commands group. 4 Sub-classes, 3 commands.""" if not hasattr(self, '_notch'): from .Notch import NotchCls self._notch = NotchCls(self._core, self._cmd_group) return self._notch @property def pramp(self): """pramp commands group. 0 Sub-classes, 1 commands.""" if not hasattr(self, '_pramp'): from .Pramp import PrampCls self._pramp = PrampCls(self._core, self._cmd_group) return self._pramp @property def producer(self): """producer commands group. 0 Sub-classes, 2 commands.""" if not hasattr(self, '_producer'): from .Producer import ProducerCls self._producer = ProducerCls(self._core, self._cmd_group) return self._producer @property def signal(self): """signal commands group. 0 Sub-classes, 1 commands.""" if not hasattr(self, '_signal'): from .Signal import SignalCls self._signal = SignalCls(self._core, self._cmd_group) return self._signal @property def trigger(self): """trigger commands group. 7 Sub-classes, 7 commands.""" if not hasattr(self, '_trigger'): from .Trigger import TriggerCls self._trigger = TriggerCls(self._core, self._cmd_group) return self._trigger @property def tsignal(self): """tsignal commands group. 4 Sub-classes, 0 commands.""" if not hasattr(self, '_tsignal'): from .Tsignal import TsignalCls self._tsignal = TsignalCls(self._core, self._cmd_group) return self._tsignal @property def waveform(self): """waveform commands group. 2 Sub-classes, 5 commands.""" if not hasattr(self, '_waveform'): from .Waveform import WaveformCls self._waveform = WaveformCls(self._core, self._cmd_group) return self._waveform @property def wsegment(self): """wsegment commands group. 3 Sub-classes, 5 commands.""" 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: """SCPI: [SOURce<HW>]:BB:ARBitrary:MODE \n Snippet: value: enums.ArbMode = driver.source.bb.arbitrary.get_mode() \n Defines the mode of the ARB application. \n :return: arb_mode: STANdard| EUPLoad STANdard ARB standard mode using a waveform file as internal baseband source. EUPLoad ARB Ethernet upload mode for uploading waveform files 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: """SCPI: [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. \n :param arb_mode: STANdard| EUPLoad STANdard ARB standard mode using a waveform file as internal baseband source. EUPLoad ARB Ethernet upload mode for uploading waveform files 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: """SCPI: [SOURce<HW>]:BB:ARBitrary:PRESet \n Snippet: driver.source.bb.arbitrary.preset() \n Sets all ARB generator parameters to their default values. \n """ self._core.io.write(f'SOURce<HwInstance>:BB:ARBitrary:PRESet')
[docs] def preset_with_opc(self, opc_timeout_ms: int = -1) -> None: """SCPI: [SOURce<HW>]:BB:ARBitrary:PRESet \n Snippet: driver.source.bb.arbitrary.preset_with_opc() \n Sets all ARB generator parameters to their default values. \n 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. \n :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: """SCPI: [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. \n :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: """SCPI: [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. \n :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