qermit.frame_randomisation#
- frame_randomisation.gen_Frame_Randomisation_MitRes(samples: int, **kwargs) MitRes #
Produces a MitRes object that applies FrameRandomisation techniques to experiment circuits.
- Parameters:
backend (Backend) – Backend which experiments are default run through.
samples (int) – Number of Frame Randomisation instances sampled in Frame Randomisation.
- Key mitres:
MitRes object FrameRandomisation MitRes built around if given.
- Key frame_randomisation:
FrameRandomisation Enum passed to specify method used. Default set to FrameRandomisation.UniversalFrameRandomisation.
- class qermit.frame_randomisation.frame_randomisation.FrameRandomisation(value)[source]#
An enumeration.
- static PauliFrameRandomisation(circuit: Circuit, shots: int, samples: int) List[CircuitShots] [source]#
Uses the pytket.tailoring method PauliFrameRandomisation to return a list of circuits corresponding to instances of frame randomisation for the input circuit.
- Parameters:
circuit (Circuit) – Circuit to have frame randomisation applied.
shots (int) – Number of shots of each frame randomisation circuit to take.
samples (int) – Number of frame randomisation instances to sample.
- static UniversalFrameRandomisation(circuit: Circuit, shots: int, samples: int) List[CircuitShots] [source]#
Uses the pytket.tailoring method UniversalFrameRandomisation to return a list of circuits corresponding to instances of frame randomisation for the input circuit. UniversalFrameRandomisation rebases the circuit to a gate set such that the whole circuit is a single cycle for frame randomisation. This is possible with the additional noise assumption on top of the regular Frame Randomisation assumptions that Rz(-x) and Rz(x) incur similar noise for any angle x.
- Parameters:
circuit (Circuit) – Circuit to have frame randomisation applied.
shots (int) – Number of shots of each frame randomisation circuit to take.
samples (int) – Number of frame randomisation instances to sample.
- frame_randomisation.frame_randomisation_circuits_task_gen(_fr_type: FrameRandomisation) MitTask #
Returns a MitTask object that produces Frame Randomisation circuits for some wire of experiment circuits.
- Parameters:
samples (int) – Number of samples of frame randomisation circuits to take for each circuit in wire.
- frame_randomisation.frame_randomisation_result_task_gen() MitTask #
Returns a MitTask object that sequentially collates samples number of BackendResult objects into single BackendResult object. These collated BackendResult objects should include all frame experiments for a single original circuit.
- Parameters:
samples (int) – Number of frame randomisation instances created in the first place, used to suitably collate results.