Source code for quantify_scheduler.device_under_test.edge
# Repository: https://gitlab.com/quantify-os/quantify-scheduler
# Licensed according to the LICENCE file on the main branch
from qcodes.instrument.base import Instrument
from quantify_scheduler.backends.graph_compilation import DeviceCompilationConfig
from quantify_scheduler.device_under_test.device_element import DeviceElement
[docs]class Edge(Instrument):
"""
This class encapsulates the connection information between DeviceElements in the
QuantumDevice. It provides an interface for the QuantumDevice to generate the
edge information for use in the device compilation step. See
:class:`quantify_scheduler.device_under_test.composite_square_edge` for an example
edge implementation.
"""
def __init__(self, parent_element_name: str, child_element_name: str, **kwargs):
self._parent_element_name = parent_element_name
self._child_element_name = child_element_name
super().__init__(name=f"{parent_element_name}_{child_element_name}", **kwargs)
def __getstate__(self):
"""
Serializes `Edge` into a dict containing the parent and child element names of
this edge and a dict for each submodule containing its parameter names
and corresponding values.
"""
snapshot = self.snapshot()
edge_data = {
"parent_element_name": self._parent_element_name,
"child_element_name": self._child_element_name,
}
for submodule_name, submodule_data in snapshot["submodules"].items():
edge_data[submodule_name] = {
name: data["value"]
for name, data in submodule_data["parameters"].items()
}
state = {
"deserialization_type": self.__class__.__name__, # Will return derived class name
"mode": "__init__",
"data": edge_data,
}
return state
@property
[docs] def parent_device_element(self):
"""
The parent DeviceElement connected by the edge.
"""
found_parent_element = self.find_instrument(
name=self._parent_element_name, instrument_class=DeviceElement
)
return found_parent_element
@property
[docs] def child_device_element(self):
"""
The child DeviceElement connected by the edge.
"""
found_child_element = self.find_instrument(
name=self._child_element_name, instrument_class=DeviceElement
)
return found_child_element
[docs] def generate_edge_config(self) -> DeviceCompilationConfig:
"""
Generates part of the device configuration specific to an edge connecting
different device elements.
This method is intended to be used when this object is part of a
device object containing multiple elements.
"""
raise NotImplementedError