iqm.cpc.interface.compiler.DDStrategy#

class iqm.cpc.interface.compiler.DDStrategy(merge_contiguous_waits=True, target_qubits=None, skip_leading_wait=True, skip_trailing_wait=True, gate_sequences=<factory>)#

Bases: object

Describes a particular dynamical decoupling strategy.

The current standard DD stategy can be found in STANDARD_DD_STRATEGY, but users can use this class to provide their own dynamical decoupling strategies.

See [1] for information on DD sequences.

Attributes

merge_contiguous_waits

Merge contiguous Wait instructions into one if they are separated only by Block instructions.

skip_leading_wait

Skip processing leading Wait instructions.

skip_trailing_wait

Skip processing trailing Wait instructions.

target_qubits

Qubits on which dynamical decoupling should be applied.

gate_sequences

Available decoupling gate sequences to chose from in this strategy.

Methods

__eq__(other)

Return self==value.

__repr__()

Return repr(self).

Parameters:
merge_contiguous_waits: bool = True#

Merge contiguous Wait instructions into one if they are separated only by Block instructions.

target_qubits: frozenset[str] | None = None#

Qubits on which dynamical decoupling should be applied. If None, all qubits are targeted.

skip_leading_wait: bool = True#

Skip processing leading Wait instructions.

skip_trailing_wait: bool = True#

Skip processing trailing Wait instructions.

gate_sequences: list[tuple[int, str | list[tuple[float, float]], str]]#

Available decoupling gate sequences to chose from in this strategy.

Each sequence is defined by a tuple of (ratio, gate pattern, align):

  • ratio: Minimal duration for the sequence (in PRX gate durations).

  • gate pattern: Gate pattern can be defined in two ways. It can be a string containing “X” and “Y” characters, encoding a PRX gate sequence. For example, “YXYX” corresponds to the XY4 sequence, “XYXYYXYX” to the EDD sequence, etc. If more flexibility is needed, a gate pattern can be defined as a sequence of PRX gate argument tuples (that contain a rotation angle and a phase angle). For example, sequence “YX” could be written as [(math.pi, math.pi / 2), (math.pi, 0)].

  • align: Controls the alignment of the sequence within the time window it is inserted in. Supported values:

    • “asap”: Corresponds to a ASAP-aligned sequence with no waiting time before the first pulse.

    • “center”: Corresponds to a symmetric sequence.

    • “alap”: Corresponds to a ALAP-aligned sequence.

The Dynamical Decoupling algorithm uses the best fitting gate sequence by first sorting them by ratio in descending order. Then the longest fitting pattern is determined by comparing ratio with the duration of the time window divided by the PRX gate duration.