from .....Internal.Core import Core
from .....Internal.CommandsGroup import CommandsGroup
from .....Internal import Conversions
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
[docs]
class IqRatioCls:
"""IqRatio commands group definition. 1 total commands, 0 Subgroups, 1 group commands"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("iqRatio", core, parent)
[docs]
def get_magnitude(self) -> float:
"""SCPI: [SOURce<HW>]:IQ:IMPairment:IQRatio:[MAGNitude] \n
Snippet: value: float = driver.source.iq.impairment.iqRatio.get_magnitude() \n
Sets the ratio of I modulation to Q modulation (amplification 'imbalance') . The input may be either in dB or %.
The resolution is 0.001 dB, an input in percent is rounded to the closest valid value in dB. A query returns the value in
dB. \n
:return: ipartq_ratio: No help available
"""
response = self._core.io.query_str('SOURce<HwInstance>:IQ:IMPairment:IQRatio:MAGNitude?')
return Conversions.str_to_float(response)
[docs]
def set_magnitude(self, ipartq_ratio: float) -> None:
"""SCPI: [SOURce<HW>]:IQ:IMPairment:IQRatio:[MAGNitude] \n
Snippet: driver.source.iq.impairment.iqRatio.set_magnitude(ipartq_ratio = 1.0) \n
Sets the ratio of I modulation to Q modulation (amplification 'imbalance') . The input may be either in dB or %.
The resolution is 0.001 dB, an input in percent is rounded to the closest valid value in dB. A query returns the value in
dB. \n
:param ipartq_ratio: float Range: -1 to 1
"""
param = Conversions.decimal_value_to_str(ipartq_ratio)
self._core.io.write(f'SOURce<HwInstance>:IQ:IMPairment:IQRatio:MAGNitude {param}')