Source code for qblox_instruments.types

# ----------------------------------------------------------------------------
# Description    : Qblox instruments instrument and module types
# Git repository : https://gitlab.com/qblox/packages/software/qblox_instruments.git
# Copyright (C) Qblox BV (2020)
# ----------------------------------------------------------------------------


# -- include -----------------------------------------------------------------

import re

from enum import Enum
from typing import Any, Union

from qcodes import DelegateParameter


# -- definitions -------------------------------------------------------------


[docs] class TypeEnum(Enum): """ Type base class that arranges child enum string representations. """ def __repr__(self) -> str: return "<{}.{}>".format(str(type(self)).split("'")[1], self.name) def __str__(self) -> str: return str(self.value) def __eq__(self, other: Any) -> bool: if type(self) == type(other): return str(self) == str(other) elif other in [str(val) for val in type(self)]: return str(self) == other else: raise KeyError(f"{other} is not of type {type(self)}") def __key__(self): return str(self) def __hash__(self): return hash(self.__key__())
[docs] class InstrumentClass(TypeEnum): """ Instrument class enum. """ CLUSTER = "Cluster"
[docs] class InstrumentType(TypeEnum): """ Instrument/module type enum. """ MM = "MM" QCM = "QCM" QRM = "QRM" QTM = "QTM" QDM = "QDM" LINQ = "LINQ" QRC = "QRC" _RF = "RF"
[docs] class ClusterType(TypeEnum): """ Cluster module type enum. """ _CLUSTER_MM = "Cluster MM" CLUSTER_QCM = "Cluster QCM" CLUSTER_QCM_RF = "Cluster QCM-RF" CLUSTER_QRM = "Cluster QRM" CLUSTER_QRM_RF = "Cluster QRM-RF" CLUSTER_QTM = "Cluster QTM" CLUSTER_QDM = "Cluster QDM" CLUSTER_LINQ = "Cluster LINQ" CLUSTER_QRC = "Cluster QRC"
# -- class -------------------------------------------------------------------
[docs] class TypeHandle: """ Instrument type handler class. """ # ------------------------------------------------------------------------
[docs] def __init__(self, instrument: Union[ClusterType, str]): """ Create instrument type handler object. Parameters ---------- instrument : Union[ClusterType, str] Instrument/module type specification. Returns ---------- Raises ---------- """ # Set instrument type specification try: instrument = re.split(" |_|-", str(instrument).upper()) self._instrument_class = InstrumentClass[instrument[0]] self._instrument_type = InstrumentType[instrument[1]] self._is_mm_type = self._instrument_type == InstrumentType.MM self._is_qrm_type = self._instrument_type == InstrumentType.QRM self._is_qcm_type = self._instrument_type == InstrumentType.QCM self._is_qtm_type = self._instrument_type == InstrumentType.QTM self._is_qdm_type = self._instrument_type == InstrumentType.QDM self._is_linq_type = self._instrument_type == InstrumentType.LINQ self._is_qrc_type = self._instrument_type == InstrumentType.QRC except Exception: raise RuntimeError("Invalid instrument type.") # Do a first RF assignment, it is necessary for dummy modules but will get overwritten for real ones self._is_rf_type = False if len(instrument) > 2: self._is_rf_type = instrument[2] == str(InstrumentType._RF) if not self._is_rf_type: raise RuntimeError("Invalid instrument type.") # Add QRC to RF types self._is_rf_type |= self._is_qrc_type
# ------------------------------------------------------------------------ @property def instrument_class(self) -> InstrumentClass: """ Get instrument class (e.g. Cluster). Parameters ---------- Returns ---------- InstrumentClass Instrument class Raises ---------- """ return self._instrument_class # ------------------------------------------------------------------------ @property def instrument_type(self) -> InstrumentType: """ Get instrument type (e.g. MM, QRM, QCM, QTM). Parameters ---------- Returns ---------- InstrumentType Instrument type Raises ---------- """ return self._instrument_type # ------------------------------------------------------------------------ @property def is_mm_type(self) -> bool: """ Return if module is of type MM. Parameters ---------- Returns ---------- bool True if module is of type MM. Raises ---------- """ return self._is_mm_type # ------------------------------------------------------------------------ @property def is_qcm_type(self) -> bool: """ Return if module is of type QCM. Parameters ---------- Returns ---------- bool True if module is of type QCM. Raises ---------- """ return self._is_qcm_type # ------------------------------------------------------------------------ @property def is_qrm_type(self) -> bool: """ Return if module is of type QRM. Parameters ---------- Returns ---------- bool True if module is of type QRM. Raises ---------- """ return self._is_qrm_type # ------------------------------------------------------------------------ @property def is_qtm_type(self) -> bool: """ Return if module is of type QTM. Parameters ---------- Returns ---------- bool True if module is of type QTM. Raises ---------- """ return self._is_qtm_type # ------------------------------------------------------------------------ @property def is_qdm_type(self) -> bool: """ Return if module is of type QDM. Parameters ---------- Returns ---------- bool True if module is of type QDM. Raises ---------- """ return self._is_qdm_type # ------------------------------------------------------------------------ @property def is_linq_type(self) -> bool: """ Return if module is of type LINQ. Parameters ---------- Returns ---------- bool True if module is of type LINQ. Raises ---------- """ return self._is_linq_type # ------------------------------------------------------------------------ @property def is_qrc_type(self) -> bool: """ Return if module is of type QRC. Parameters ---------- Returns ---------- bool True if module is of type QRC. Raises ---------- """ return self._is_qrc_type # ------------------------------------------------------------------------ @property def is_rf_type(self) -> bool: """ Return if has RF functionality. Parameters ---------- Returns ---------- bool True if module has RF functionality. Raises ---------- """ return self._is_rf_type
class FrequencyParameter(DelegateParameter): def __init__(self, *args, calibration_function, **kwargs): self._calibration_function = calibration_function super().__init__(*args, **kwargs) def set_raw(self, val, cal_type=None): self.source.set(val) self._calibration_function(cal_type=cal_type)