quil_rs::program

Struct Calibrations

Source
pub struct Calibrations {
    pub calibrations: CalibrationSet<Calibration>,
    pub measure_calibrations: CalibrationSet<MeasureCalibrationDefinition>,
}
Expand description

A collection of Quil calibrations (DEFCAL instructions) with utility methods.

Fields§

§calibrations: CalibrationSet<Calibration>§measure_calibrations: CalibrationSet<MeasureCalibrationDefinition>

Implementations§

Source§

impl Calibrations

Source

pub fn calibrations(&self) -> Vec<&Calibration>

Return a vector containing a reference to all Calibrations in the set.

Source

pub fn measure_calibrations(&self) -> Vec<&MeasureCalibrationDefinition>

Return a vector containing a reference to all MeasureCalibrationDefinitions in the set.

Source

pub fn iter_calibrations(&self) -> impl Iterator<Item = &Calibration>

Iterate over all Calibrations in the set

Source

pub fn iter_measure_calibrations( &self, ) -> impl Iterator<Item = &MeasureCalibrationDefinition>

Iterate over all MeasureCalibrationDefinitions calibrations in the set

Source

pub fn expand( &self, instruction: &Instruction, previous_calibrations: &[Instruction], ) -> Result<Option<Vec<Instruction>>, ProgramError>

Given an instruction, return the instructions to which it is expanded if there is a match. Recursively calibrate instructions, returning an error if a calibration directly or indirectly expands into itself.

Return only the expanded instructions; for more information about the expansion process, see Self::expand_with_detail.

Source

pub fn expand_with_detail( &self, instruction: &Instruction, previous_calibrations: &[Instruction], ) -> Result<Option<CalibrationExpansionOutput>, ProgramError>

Given an instruction, return the instructions to which it is expanded if there is a match. Recursively calibrate instructions, returning an error if a calibration directly or indirectly expands into itself.

Also return information about the expansion.

Source

pub fn get_match_for_measurement( &self, measurement: &Measurement, ) -> Option<&MeasureCalibrationDefinition>

Returns the last-specified MeasureCalibrationDefinition that matches the target qubit (if any), or otherwise the last-specified one that specified no qubit.

If multiple calibrations match the measurement, the precedence is as follows:

  1. Match fixed qubit.
  2. Match variable qubit.
  3. Match no qubit.

In the case of multiple calibrations with equal precedence, the last one wins.

Source

pub fn get_match_for_gate(&self, gate: &Gate) -> Option<&Calibration>

Return the final calibration which matches the gate per the QuilT specification:

A calibration matches a gate if:

  1. It has the same name
  2. It has the same modifiers
  3. It has the same qubit count (any mix of fixed & variable)
  4. It has the same parameter count (both specified and unspecified)
  5. All fixed qubits in the calibration definition match those in the gate
  6. All specified parameters in the calibration definition match those in the gate
Source

pub fn len(&self) -> usize

Return the count of contained calibrations.

Source

pub fn is_empty(&self) -> bool

Return true if this contains no data.

Source

pub fn insert_calibration( &mut self, calibration: Calibration, ) -> Option<Calibration>

Insert a Calibration into the set.

If a calibration with the same [CalibrationSignature] already exists in the set, it will be replaced, and the old calibration is returned.

Source

pub fn insert_measurement_calibration( &mut self, calibration: MeasureCalibrationDefinition, ) -> Option<MeasureCalibrationDefinition>

Insert a [MeasureCalibration] into the set.

If a calibration with the same [CalibrationSignature] already exists in the set, it will be replaced, and the old calibration is returned.

Source

pub fn extend(&mut self, other: Calibrations)

Append another CalibrationSet onto this one.

Calibrations with conflicting [CalibrationSignature]s are overwritten by the ones in the given set.

Source

pub fn into_instructions(self) -> Vec<Instruction>

Return the Quil instructions which describe the contained calibrations, consuming the CalibrationSet

Source

pub fn to_instructions(&self) -> Vec<Instruction>

Return the Quil instructions which describe the contained calibrations.

Trait Implementations§

Source§

impl Clone for Calibrations

Source§

fn clone(&self) -> Calibrations

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Calibrations

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Calibrations

Source§

fn default() -> Calibrations

Returns the “default value” for a type. Read more
Source§

impl PartialEq for Calibrations

Source§

fn eq(&self, other: &Calibrations) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for Calibrations

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> Scalar for T
where T: 'static + Clone + PartialEq + Debug,