Helpers

Helper methods for mapping Qiskit classes to IonQ REST API compatible values.

qiskit_ionq.helpers.compress_to_metadata_string(metadata: dict | list) str[source]

Convert a metadata object to a compact string format (dumped, gzipped, base64 encoded) for storing in IonQ API metadata

Parameters:

metadata (dict or list) – a dict or list of dicts with metadata relevant to building the results object on a returned job.

Returns:

encoded string

Return type:

str

qiskit_ionq.helpers.decompress_metadata_string(input_string: str) dict | list[source]

Convert compact string format (dumped, gzipped, base64 encoded) from IonQ API metadata back into a dict or list of dicts relevant to building the results object on a returned job.

Parameters:

input_string (str) – compressed string format of metadata dict

Returns:

decompressed metadata dict or list of dicts

Return type:

dict or list

qiskit_ionq.helpers.get_n_qubits(backend: str, fallback: int = 100) int[source]

Get the number of qubits for a given backend.

Parameters:
  • backend (str) – The name of the backend.

  • fallback (int) – Fallback number of qubits if API call fails.

Returns:

The number of qubits for the backend.

Return type:

int

qiskit_ionq.helpers.get_user_agent()[source]

Generates the user agent string which is helpful in identifying different tools in the internet. Valid user-agent ionq_client header that indicates the request is from qiskit_ionq along with the system, os, python,libraries details.

Returns:

A string of generated user agent.

Return type:

str

qiskit_ionq.helpers.qiskit_circ_to_ionq_circ(input_circuit: QuantumCircuit, gateset: Literal['qis', 'native'] = 'qis', ionq_compiler_synthesis: bool = False)[source]

Build a circuit in IonQ’s instruction format from qiskit instructions.

Attention

This function ignores the following compiler directives: * barrier

Parameters:
  • input_circuit (qiskit.circuit.QuantumCircuit) – A Qiskit quantum circuit.

  • gateset (string) – Set of gates to target. It can be QIS (required transpilation pass in IonQ backend, which is sent standard gates) or native (only IonQ native gates are allowed, in the future we may provide transpilation to these gates in Qiskit).

  • ionq_compiler_synthesis (bool) – Whether to opt-in to IonQ compiler’s intelligent trotterization.

Raises:
  • IonQGateError – If an unsupported instruction is supplied.

  • IonQMidCircuitMeasurementError – If a mid-circuit measurement is detected.

  • IonQPauliExponentialError – If non-commuting PauliExponentials are found without the appropriate flag.

Returns:

A list of instructions in a converted dict format. int: The number of measurements. dict: The measurement map from qubit number to classical bit number.

Return type:

list[dict]

qiskit_ionq.helpers.qiskit_to_ionq(circuit, backend, passed_args=None, extra_query_params=None, extra_metadata=None) str[source]

Convert a Qiskit circuit to a IonQ compatible dict.

Parameters:
  • circuit (qiskit.circuit.QuantumCircuit) – A Qiskit quantum circuit.

  • backend (qiskit_ionq.IonQBackend) – The IonQ backend.

  • passed_args (dict) – Dictionary containing additional passed arguments, eg. shots.

  • extra_query_params (dict) – Specify any parameters to include in the request

  • extra_metadata (dict) – Specify any additional metadata to include.

Returns:

A string / JSON-serialized dictionary with IonQ API compatible values.

Return type:

str

qiskit_ionq.helpers.resolve_credentials(token: str | None = None, url: str | None = None) dict[source]

Resolve credentials for use in IonQ API calls.

If the provided token and url are both None, then these values are loaded from the IONQ_API_TOKEN and IONQ_API_URL environment variables, respectively.

If no url is discovered, then https://api.ionq.co/v0.3 is used.

Parameters:
  • token (str) – IonQ API access token.

  • url (str, optional) – IonQ API url. Defaults to None.

Returns:

A dict with “token” and “url” keys, for use by a client.

Return type:

dict[str]

qiskit_ionq.helpers.retry(exceptions: Any, tries: int = -1, delay: float = 0, max_delay: float = inf, backoff: float = 1, jitter: float = 0, enable_logging: bool = True)[source]

Retry decorator with exponential backoff.

Parameters:
  • exceptions – The exception(s) to catch. Can be a tuple of exceptions.

  • tries – Number of attempts before giving up. -1 means infinite tries.

  • delay – Initial delay between retries in seconds.

  • max_delay – Maximum delay between retries.

  • backoff – Multiplier applied to delay after each retry.

  • jitter – Maximum random jitter added to delay.

  • enable_logging – Whether to log failures.