# Repository: https://gitlab.com/quantify-os/quantify-scheduler
# Licensed according to the LICENCE file on the main branch
import warnings
from typing import Optional
from .operation import Operation
[docs]class SpectroscopyOperation(Operation):
"""Spectroscopy operation to find energy between computational basis states.
Spectroscopy operations can be supported by various qubit types, but not all of
them. They are typically translated into a spectroscopy pulse by the quantum
device. The frequency is taken from a clock of the device element.
"""
def __init__(
self,
qubit: str,
data: Optional[dict] = None,
):
"""
Parameters
----------
qubit
The target qubit.
data
The operation's dictionary, by default None\n
Note: if the data parameter is not None all other parameters are
overwritten using the contents of data.\n
Deprecated: support for the data argument will be dropped in
quantify-scheduler >= 0.13.0. Please consider updating the data
dictionary after initialization.
"""
if data is None:
super().__init__(name=f"Spectroscopy operation {qubit}")
self.data.update(
{
"gate_info": {
"unitary": None,
"plot_func": "quantify_scheduler.visualization"
".circuit_diagram.pulse_modulated",
"tex": r"Spectroscopy operation",
"qubits": [qubit],
"operation_type": "spectroscopy_operation",
},
}
)
self._update()
else:
warnings.warn(
"Support for the data argument will be dropped in"
"quantify-scheduler >= 0.13.0.\n"
"Please consider updating the data "
"dictionary after initialization.",
DeprecationWarning,
)
super().__init__(data["name"], data=data)
def __str__(self) -> str:
gate_info = self.data["gate_info"]
qubit = gate_info["qubits"][0]
return f'{self.__class__.__name__}(qubit="{qubit}")'