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