Source code for RsSmbv.Implementations.Source.Bb.Impairment.Digital.IqRatio

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]:BB:IMPairment:DIGital:IQRatio:[MAGNitude] \n Snippet: value: float = driver.source.bb.impairment.digital.iqRatio.get_magnitude() \n Sets the ratio of I modulation to Q modulation (amplification imbalance) of the corresponding digital channel. Value range Table Header: Impairments / Min /dB / Max /dB / Increment \n - Digital / 4 / 4 / 0.0001 - Analog / 1 / 1 / 0.0001 \n :return: ipartq_ratio: No help available """ response = self._core.io.query_str('SOURce:BB:IMPairment:DIGital:IQRatio:MAGNitude?') return Conversions.str_to_float(response)
[docs] def set_magnitude(self, ipartq_ratio: float) -> None: """SCPI: [SOURce]:BB:IMPairment:DIGital:IQRatio:[MAGNitude] \n Snippet: driver.source.bb.impairment.digital.iqRatio.set_magnitude(ipartq_ratio = 1.0) \n Sets the ratio of I modulation to Q modulation (amplification imbalance) of the corresponding digital channel. Value range Table Header: Impairments / Min /dB / Max /dB / Increment \n - Digital / 4 / 4 / 0.0001 - Analog / 1 / 1 / 0.0001 \n :param ipartq_ratio: float The setting value can be either in dB or %. An input in percent is rounded to the closest valid value in dB. Range: -4 to 4, Unit: dB | PCT (setting command) / dB (result value) """ param = Conversions.decimal_value_to_str(ipartq_ratio) self._core.io.write(f'SOURce:BB:IMPairment:DIGital:IQRatio:MAGNitude {param}')