from ........Internal.Core import Core
from ........Internal.CommandsGroup import CommandsGroup
from ........Internal import Conversions
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class RelativeCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("relative", core, parent)
[docs]
def set(self, percentage: float) -> None:
"""
``[SENSe]:FREQuency:VERify:TOLerance[:RELative]`` \n
Snippet: ``driver.applications.k40PhaseNoise.sense.frequency.verify.tolerance.relative.set(percentage = 1.0)`` \n
Defines a relative frequency tolerance for frequency verification. If you define both an absolute and relative tolerance,
the application uses the higher tolerance level.
:param percentage: Numeric value in %, relative to the current nominal frequency. Range: 1 to 100, Unit: PCT
"""
param = Conversions.decimal_value_to_str(percentage)
self._core.io.write(f'SENSe:FREQuency:VERify:TOLerance:RELative {param}')
[docs]
def get(self) -> float:
"""
``[SENSe]:FREQuency:VERify:TOLerance[:RELative]`` \n
Snippet: ``value: float = driver.applications.k40PhaseNoise.sense.frequency.verify.tolerance.relative.get()`` \n
Defines a relative frequency tolerance for frequency verification. If you define both an absolute and relative tolerance,
the application uses the higher tolerance level.
:return: percentage: Numeric value in %, relative to the current nominal frequency. Range: 1 to 100, Unit: PCT
"""
response = self._core.io.query_str(f'SENSe:FREQuency:VERify:TOLerance:RELative?')
return Conversions.str_to_float(response)