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