API documentation¶
The pytket-quantinuum extension allows submission of pytket circuits to the H-series trapped ion devices (and emulators) via the QuantinuumBackend
.
See the pytket-quantinuum section of the documentation website for some example usage.
- enum pytket.extensions.quantinuum.Language(value)[source]¶
Language used for submission of circuits.
Valid values are as follows:
- QASM = <Language.QASM: 0>¶
- QIR = <Language.QIR: 1>¶
- PQIR = <Language.PQIR: 2>¶
- class pytket.extensions.quantinuum.QuantinuumBackend(device_name, label='job', simulator='state-vector', group=None, provider=None, machine_debug=False, api_handler=<pytket.extensions.quantinuum.backends.api_wrappers.QuantinuumAPI object>, compilation_config=None, **kwargs)[source]¶
Bases:
Backend
Interface to a Quantinuum device. More information about the QuantinuumBackend can be found on this page https://docs.quantinuum.com/tket/extensions/pytket-quantinuum/index.html
- __init__(device_name, label='job', simulator='state-vector', group=None, provider=None, machine_debug=False, api_handler=<pytket.extensions.quantinuum.backends.api_wrappers.QuantinuumAPI object>, compilation_config=None, **kwargs)[source]¶
Construct a new Quantinuum backend.
- Parameters:
device_name (
str
) – Name of device, e.g. “H1-1”label (
Optional
[str
]) – Job labels used if Circuits have no name, defaults to “job”simulator (
str
) – Only applies to simulator devices, options are “state-vector” or “stabilizer”, defaults to “state-vector”group (
Optional
[str
]) – string identifier of a collection of jobs, can be used for usage tracking.provider (
Optional
[str
]) – select a provider for federated authentication. We currently only support ‘microsoft’, which enables the microsoft Device Flow.api_handler (
QuantinuumAPI
) – Instance of API handler, defaults to DEFAULT_API_HANDLERcompilation_config (
Optional
[QuantinuumBackendCompilationConfig
]) – Optional compilation configuration
Supported kwargs:
options: items to add to the “options” dictionary of the request body, as a json-style dictionary (see
QuantinuumBackend.process_circuits()
)
- add_to_batch(batch_start_job, circuit, n_shots=None, batch_end=False, valid_check=True, **kwargs)[source]¶
Add to a batch of jobs on the backend, behaves like process_circuit except in two ways:
1. The first argument must be the result handle of the first job of batch.
2. The optional argument batch_end should be set to “True” for the final circuit of the batch. By default it is False.
See
pytket.backends.Backend.process_circuits()
for documentation on remaining parameters.- Parameters:
batch_start_job (
ResultHandle
) – Handle of first circuit submitted to batch.batch_end (
bool
) – Boolean flag to signal the final circuit of batch, defaults to False
- Return type:
- Returns:
Handle for submitted circuit.
- classmethod available_devices(**kwargs)[source]¶
See
pytket.backends.Backend.available_devices()
.- Parameters:
api_handler – Instance of API handler, defaults to DEFAULT_API_HANDLER
- Return type:
- Returns:
A list of BackendInfo objects for each available Backend.
- cancel(handle)[source]¶
Cancel a job.
- Parameters:
handle (ResultHandle) – handle to job
- Raises:
NotImplementedError – If backend does not support job cancellation
- Return type:
- circuit_status(handle, **kwargs)[source]¶
Return a CircuitStatus reporting the status of the circuit execution corresponding to the ResultHandle
- Return type:
- cost(circuit, n_shots, syntax_checker=None, use_websocket=None, **kwargs)[source]¶
Return the cost in HQC to process this circuit with n_shots repeats on this backend.
The cost is obtained by sending the circuit to a “syntax-checker” backend, which incurs no cost itself but reports what the cost would be for the actual backend (
self
).If
self
is a syntax checker then the cost will be zero.See
QuantinuumBackend.process_circuits()
for the supported kwargs.- Parameters:
circuit (
Circuit
) – Circuit to calculate runtime estimate for. Must be valid for backend.n_shots (
int
) – Number of shots.syntax_checker (
Optional
[str
]) – Optional. Name of the syntax checker to use to get cost. For example for the “H1-1” device that would be “H1-1SC”. For most devices this is automatically inferred, default=None.use_websocket (
Optional
[bool
]) – Optional. Boolean flag to use a websocket connection.
- Raises:
ValueError – Circuit is not valid, needs to be compiled.
- Return type:
- Returns:
Cost in HQC to execute the shots.
- default_compilation_pass(optimisation_level=2, timeout=300)[source]¶
- Parameters:
optimisation_level (
int
) – Allows values of 0, 1, 2 or 3, with higher values prompting more computationally heavy optimising compilation that can lead to reduced gate count in circuits.timeout (
int
) – Only valid for optimisation level 3, gives a maximimum time for running a single thread of the pass GreedyPauliSimp. Increase for optimising larger circuits.
- Return type:
- Returns:
Compilation pass for compiling circuits to Quantinuum devices
- classmethod device_state(device_name, api_handler=<pytket.extensions.quantinuum.backends.api_wrappers.QuantinuumAPI object>)[source]¶
Check the status of a device.
>>> QuantinuumBackend.device_state('H1') # e.g. "online"
- Parameters:
device_name (
str
) – Name of the device.api_handler (
QuantinuumAPI
) – Instance of API handler, defaults to DEFAULT_API_HANDLER
- Return type:
- Returns:
String of state, e.g. “online”
- get_calendar(start_date, end_date, localise=True)[source]¶
Retrieves the Quantinuum H-Series operations calendar for the period specified by start_date and end_date. The calendar data returned is for the local timezone of the end-user.
The output is a sorted list of dictionaries. Each dictionary is an event on the operations calendar for the period specified by the end-user. The output from this function can be readily used to instantiate a pandas.DataFrame.
The dictionary has the following properties. * ‘start-date’: The start date and start time as a datetime.datetime object. * ‘end-date’: The end date and end time as a datetime.datetime object. * ‘machine’: A string specifying the H-Series device attached to the event. * ‘event-type’: The type of event as a string. The value online denotes queued
access to the device, and the value reservation denotes priority access for a particular organisation.
- ‘organization’: If the ‘event-type’ is assigned the value ‘reservation’, the
organization with reservation access is specified. Only users within an organization have visibility on organization reservations. Otherwise, organization is listed as ‘Fair-Share Queue’, which means all users from all organizations are able to submit jobs to the Fairshare queue during this period.
- Parameters:
start_date (
datetime
) – The start date as datetime.date object for the period to return the operations calendar.end_date (
datetime
) – The end date as datetime.date object for the period to return the operations calendar.localise (
bool
) – Apply localization to the datetime based on the end-users time zone. Default is True. Disable by setting False.
- Return type:
- Returns:
A list of events from the H-Series operations calendar, sorted by the start-date of each event. Each event is a python dictionary.
- Return_type:
List[Dict[str, str]]
- Raises:
RuntimeError if an emulator or syntax-checker is specified
- Raises:
ValueError if the argument start_date or end_date are not datetime.datetime objects.
- get_compiled_circuit(circuit, optimisation_level=2, timeout=300)[source]¶
Return a single circuit compiled with
default_compilation_pass()
.- Parameters:
optimisation_level (int, optional) – Allows values of 0, 1, 2 or 3, with higher values prompting more computationally heavy optimising compilation that can lead to reduced gate count in circuits.
timeout (int, optional) – Only valid for optimisation level 3, gives a maximimum time for running a single thread of the pass GreedyPauliSimp. Increase for optimising larger circuits.
- Returns:
An optimised quantum circuit
- Return type:
Circuit
- get_compiled_circuits(circuits, optimisation_level=2, timeout=300)[source]¶
Compile a sequence of circuits with
default_compilation_pass()
and return the list of compiled circuits (does not act in place).As well as applying a degree of optimisation (controlled by the optimisation_level parameter), this method tries to ensure that the circuits can be run on the backend (i.e. successfully passed to
process_circuits()
), for example by rebasing to the supported gate set, or routing to match the connectivity of the device. However, this is not always possible, for example if the circuit contains classical operations that are not supported by the backend. You may usevalid_circuit()
to check whether the circuit meets the backend’s requirements after compilation. This validity check is included inprocess_circuits()
by default, before any circuits are submitted to the backend.If the validity check fails, you can obtain more information about the failure by iterating through the predicates in the required_predicates property of the backend, and running the
verify()
method on each in turn with your circuit.- Parameters:
optimisation_level (int, optional) – The level of optimisation to perform during compilation. See
default_compilation_pass()
for a description of the different levels (0, 1, 2 or 3). Defaults to 2.timeout (int, optional) – Only valid for optimisation level 3, gives a maximimum time for running a single thread of the pass GreedyPauliSimp. Increase for optimising larger circuits.
- Returns:
Compiled circuits.
- Return type:
List[Circuit]
- static get_jobid(handle)[source]¶
Return the corresponding Quantinuum Job ID from a ResultHandle.
- Parameters:
handle (
ResultHandle
) – result handle.- Return type:
- Returns:
Quantinuum API Job ID string.
- get_partial_result(handle)[source]¶
Retrieve partial results for a given job, regardless of its current state.
- Parameters:
handle (
ResultHandle
) – handle to results- Return type:
- Returns:
A tuple containing the results and circuit status. If no results are available, the first element is None.
- static get_ppcirc_rep(handle)[source]¶
Return the JSON serialization of the classiocal postprocessing circuit attached to a handle, if any.
- Parameters:
handle (
ResultHandle
) – result handle- Return type:
- Returns:
serialized post-processing circuit, if any
- get_result(handle, **kwargs)[source]¶
See
pytket.backends.Backend.get_result()
. Supported kwargs: timeout, wait, use_websocket.- Return type:
- static get_results_selection(handle)[source]¶
Return a list of pairs (register name, register index) representing the order of the expected results in the response. If None, then all results in the response are used, in lexicographic order.
- Return type:
- static get_results_width(handle)[source]¶
Return the truncation width of the results, if any.
- Parameters:
handle (
ResultHandle
) – result handle- Return type:
- Returns:
truncation width of results, if any
- login()[source]¶
Log in to Quantinuum API. Requests username and password from stdin (e.g. shell input or dialogue box in Jupytet notebooks.). Passwords are not stored. After log in you should not need to provide credentials again while that session (script/notebook) is alive.
- Return type:
- logout()[source]¶
Clear stored JWT tokens from login. Will need to login again to make API calls.
- Return type:
- process_circuits(circuits, n_shots=None, valid_check=True, **kwargs)[source]¶
See
pytket.backends.Backend.process_circuits()
.- Return type:
Supported kwargs¶
postprocess: apply end-of-circuit simplifications and classical postprocessing to improve fidelity of results (bool, default False)
simplify_initial: apply the pytket
SimplifyInitial
pass to improve fidelity of results assuming all qubits initialized to zero (bool, default False)noisy_simulation: boolean flag to specify whether the simulator should perform noisy simulation with an error model (default value is True).
group: string identifier of a collection of jobs, can be used for usage tracking. Overrides the instance variable group.
wasm_file_handler: a
WasmFileHandler
object for linked WASM module.- pytketpass: a
pytket.passes.BasePass
intended to be applied by the backend (beta feature, may be ignored).
- pytketpass: a
options: items to add to the “options” dictionary of the request body, as a json-style dictionary (in addition to any that were set in the backend constructor)
request_options: extra options to add to the request body as a json-style dictionary
language: languange for submission, of type
Language
, default QASM.leakage_detection: if true, adds additional Qubit and Bit to Circuit to detect leakage errors. Run prune_shots_detected_as_leaky on returned BackendResult to get counts with leakage errors removed.
n_leakage_detection_qubits: if set, sets an upper bound on the number of additional qubits to be used when adding leakage detection
seed: for local emulators only, PRNG seed for reproduciblity (int)
multithreading: for local emulators only, boolean to indicate whether to use multithreading for emulation (defaults to False)
- rebase_pass()[source]¶
A single compilation pass that when run converts all gates in a Circuit to an OpType supported by the Backend (ignoring architecture constraints).
- Returns:
Compilation pass that converts gates to primitives supported by Backend.
- Return type:
BasePass
- set_compilation_config_allow_implicit_swaps(allow_implicit_swaps)[source]¶
Set the option to allow or disallow implicit swaps during compilation.
- Return type:
- set_compilation_config_target_2qb_gate(target_2qb_gate)[source]¶
Set the target two-qubit gate for compilation.
- Return type:
- start_batch(max_batch_cost, circuit, n_shots=None, valid_check=True, **kwargs)[source]¶
- Start a batch of jobs on the backend, behaves like process_circuit
but with additional parameter max_batch_cost as the first argument. See
pytket.backends.Backend.process_circuits()
for documentation on remaining parameters.
- Parameters:
max_batch_cost (
int
) – Maximum cost to be used for the batch, if a job exceeds the batch max it will be rejected.- Return type:
- Returns:
Handle for submitted circuit.
- submit_program(language, program, n_shots, name=None, noisy_simulation=True, group=None, wasm_file_handler=None, pytket_pass=None, options=None, request_options=None, results_selection=None)[source]¶
Submit a program directly to the backend.
- Parameters:
program (
str
) – program (encoded as string)language (
Language
) – languagen_shots (
int
) – Number of shotsnoisy_simulation (
bool
) – Boolean flag to specify whether the simulator should perform noisy simulation with an error model defaults to Truegroup (
Optional
[str
]) – String identifier of a collection of jobs, can be used for usage tracking. Overrides the instance variable group, defaults to Nonewasm_file_handler (
Optional
[WasmFileHandler
]) –WasmFileHandler
object for linked WASM module, defaults to Nonepytket_pass (
Optional
[BasePass
]) –pytket.passes.BasePass
intended to be applied by the backend (beta feature, may be ignored), defaults to Noneoptions (
Optional
[dict
[str
,Any
]]) – Items to add to the “options” dictionary of the request bodyrequest_options (
Optional
[dict
[str
,Any
]]) – Extra options to add to the request body as a json-style dictionary, defaults to Noneresults_selection (
Optional
[list
[tuple
[str
,int
]]]) – Ordered list of register names and indices used to construct finalBackendResult
. If None, all all results are used in lexicographic order.
- Raises:
WasmUnsupported – WASM submitted to backend that does not support it.
QuantinuumAPIError – API error.
ConnectionError – Connection to remote API failed
- Return type:
- Returns:
ResultHandle for submitted job.
- view_calendar(month, year, figsize=(40, 20), fontsize=15, titlesize=40)[source]¶
Visualise the H-Series operations calendar for a user-specified month and year. The operations hours are shown for the machine name used to construct the QuantinuumBackend object, i.e. ‘H1-1’. Operations days are coloured. In addition, a description of the event is also displayed (start-time, duration and event-type, see the get_calendar method for more information).
- Parameters:
month (
int
) – An integer specifying the calendar month to visualise. 1 is January and 12 is December.year (
int
) – An integer specifying the calendar year to visualise.figsize (
tuple
[float
,float
]) – A tuple specifying width and height of the output matplotlib.figure.Figure.fontsize (
float
) – The fontsize of the event description within the calendar.
- Return type:
matplotlib.figure.Figure
- Returns:
A matplotlib.figure.Figure visualising the H-Series calendar for a user-specified calendar month.
- Return_type:
matplotlib.figure.Figure
- property backend_info: BackendInfo | None¶
Retrieve all Backend properties in a BackendInfo object, including device architecture, supported gate set, gate errors and other hardware-specific information.
- Returns:
The BackendInfo describing this backend if it exists.
- Return type:
Optional[BackendInfo]
- property compilation_config: QuantinuumBackendCompilationConfig¶
The current compilation configuration for the Backend.
Accessing this property will set the target_2qb_gate if it has not already been set.
- class pytket.extensions.quantinuum.QuantinuumBackendCompilationConfig(allow_implicit_swaps=True, target_2qb_gate=None)[source]¶
Options to configure default compilation and rebase passes.
allow_implicit_swaps
: Whether to allow use of implicit swaps when rebasing. The default is to allow implicit swaps.target_2qb_gate
: Choice of two-qubit gate. The default is to use the device’s default.
- class pytket.extensions.quantinuum.QuantinuumAPI(token_store=None, api_url=None, api_version=1, use_websocket=True, provider=None, support_mfa=True, session=None, _QuantinuumAPI__user_name=None, _QuantinuumAPI__pwd=None)[source]¶
Interface to the Quantinuum online remote API.
- get_calendar(start_date, end_date)[source]¶
Retrieves calendar data using L4 API. All dates and times are in the UTC timezone.
- get_machine_list()[source]¶
Returns a given list of the available machines :rtype:
list
[dict
[str
,Any
]] :return: list of machines
- login()[source]¶
This methods checks if we have a valid (non-expired) id-token and returns it, otherwise it gets a new one with refresh-token. If refresh-token doesn’t exist, it asks user for credentials.
- Return type:
- Returns:
(str) login token
- class pytket.extensions.quantinuum.QuantinuumAPIOffline(machine_list=None)[source]¶
Offline copy of the interface to the Quantinuum remote API.
- get_machine_list()[source]¶
Returns a given list of the available machines :rtype:
list
[dict
[str
,Any
]] :return: list of machines
- login()[source]¶
No login offline with the offline API, this function will always return an empty api token
- Return type:
Quantinuum config.
- class pytket.extensions.quantinuum.backends.config.QuantinuumConfig(username, refresh_token, id_token, refresh_token_timeout, id_token_timeout)[source]¶
Holds config parameters for pytket-quantinuum.
- pytket.extensions.quantinuum.backends.config.set_quantinuum_config(username)[source]¶
Set default value for Quantinuum username. Can be overriden in backend construction.
- Return type:
Methods for generating a leakage detection Pytket Circuit.
- pytket.extensions.quantinuum.backends.leakage_gadget.get_detection_circuit(circuit, n_device_qubits)[source]¶
For a passed circuit, appends a leakage detection circuit for each end of circuit measurement using spare device qubits. All additional Qubit added for leakage detection are written to a new register “leakage_detection_qubit” and all additional Bit are written to a new register “leakage_detection_bit”.
- pytket.extensions.quantinuum.backends.leakage_gadget.get_leakage_gadget_circuit(circuit_qubit, postselection_qubit, postselection_bit)[source]¶
Returns a two qubit Circuit for detecting leakage errors.
- Parameters:
- Return type:
- Returns:
Circuit for detecting leakage errors for specified ids.
- pytket.extensions.quantinuum.backends.leakage_gadget.prune_shots_detected_as_leaky(result)[source]¶
For all states with a Bit with name “leakage_detection_bit” in a state 1 sets the counts to 0.
- Parameters:
result (BackendResult) – Shots returned from device.
- Returns:
Shots with leakage cases removed.
- Return type:
BackendResult
- class pytket.extensions.quantinuum.backends.credential_storage.CredentialStorage(id_token_timedelt=datetime.timedelta(seconds=3300), refresh_token_timedelt=datetime.timedelta(days=29))[source]¶
Base class for storing Quantinuum username and authentication tokens.
pytket-quantinuum
interacts with Quantinuum services by making API requests, such as submitting quantum programs and retrieving results. These requests often require an ID token, which is obtained through the Quantinuum login API. The login process also returns a refresh token, allowing the ID token to be refreshed without requiring a new login.CredentialStorage
defines the interface for storing and accessing these credentials, with derived classes providing specific implementations.- __init__(id_token_timedelt=datetime.timedelta(seconds=3300), refresh_token_timedelt=datetime.timedelta(days=29))[source]¶
- class pytket.extensions.quantinuum.backends.credential_storage.MemoryCredentialStorage(id_token_timedelt=datetime.timedelta(seconds=3300), refresh_token_timedelt=datetime.timedelta(days=29))[source]¶
Bases:
CredentialStorage
In-memory credential storage.
This storage option allows credentials to be temporarily stored in memory during the application’s runtime.
- class pytket.extensions.quantinuum.backends.credential_storage.QuantinuumConfigCredentialStorage(id_token_timedelt=datetime.timedelta(seconds=3300), refresh_token_timedelt=datetime.timedelta(days=29))[source]¶
Bases:
CredentialStorage
Store username and tokens in the default pytket configuration file.
This storage option allows authentication status to persist beyond the current session, reducing the need to re-enter credentials when constructing new backends.
Example:
>>> backend = QuantinuumBackend( >>> device_name=machine, >>> api_handler=QuantinuumAPI(token_store=QuantinuumConfigCredentialStorage()), >>> )