IBM Quantum

Overview

IBM Quantum Services provides access to more than 20 currently available quantum systems (known as backends). IBM’s quantum processors are made up of superconducting transmon qubits, and users can utilize these systems via the universal, gate-based, circuit model of quantum computation. Additionally, users have access to 5 different types of simulators, simulating from 32 up to 5000 qubits to represent different aspects of the quantum backends.

This guide describes how to use the system once you have access. For instructions on how to gain access, see our Quantum Access page instead.

Connecting

Access to the IBM Quantum Computing queues, reservations, and simulators can be obtained via multiple methods – either through the cloud or locally.

Cloud Access

Users can access information about IBM Quantum’s systems, view queue information, and submit jobs on their cloud dashboard at https://quantum-computing.ibm.com. The cloud dashboard allows access to IBM Quantum’s graphical circuit builder, Quantum Composer, IBM’s Quantum Lab, and associated program examples. A Jupyterlab server is provisioned with IBM Quantum’s Qiskit programming framework for job submission.

Locally via Qiskit

IBM Quantum provides Qiskit (Quantum Information Software Kit for Quantum Computation) for working with OpenQASM and the IBM Q quantum processors. Qiskit allows users to build quantum circuits, compile them for a particular backend, and run the compiled circuits as jobs. Additional information on using Qiskit is available at https://qiskit.org/learn/ and in our Software Section below.

As opposed to using IBM’s JupyterLab server (described in Cloud Access above), users are able to install IBM Quantum Qiskit locally via two methods:

Running Jobs & Queue Policies

User can submit jobs to IBM Quantum backends both via a fair-sharing queue system as well as via priority sessions system. As discussed below, the dynamic fair-sharing queue system determines the queuing order of jobs so as to fairly balance system time between access providers, of which the OLCF QCUP is only one. Because of this, the order of when a user’s job in the fair-share queue will run varies dynamically, and can’t be predicted. In light of this, for time-critical applications or iterative algorithms, IBM Quantum recommends users consider using sessions.

Fair-Share Queue Policy

When jobs are submitted on IBM Quantum backends, the jobs enter into the “fair-share” queuing system, in which jobs run in a dynamically calculated order so as to provide fair sharing among all users of the device, to prevent individual projects or users from monopolizing a given backend.

All OLCF users have access to the “premium” (>=20 qubits) and “open” (<20 qubit) devices. Since most of the open devices are shared with the public, queue times will often be longer than the queues for the larger devices.

Allocations & Usage Limits

Warning

Due to a change in IBM’s usage model: As of Sept. 3rd 2024, we have implemented a new system for requesting large allocation times.

  • Project allocations have a default limit of 100 minutes during a moving 28-day window.

  • Minutes are shared across all users on a given project and across all backends.

  • Once a project reaches the usage limit, no jobs will be able to run until minutes are freed up on the project (see example below).

For more information on how job priority is affected based on your limit, please see https://docs.quantum.ibm.com/guides/instances#how-usage-affects-job-priority-within-an-instance.

If you are planning to use a large allocation (over 100 minutes), please send a usage request to our Quantum Resource Utilization Council (QRUC) through our help ticket system (help@olcf.ornl.gov). Special requests must be submitted by a project PI with sufficient computational and scientific justification. QRUC will evaluate the merit of your request, and if approved, can get you the additional time you need for your work.

The 28-day rolling window

The new 28-day rolling window only considers usage in a given 28 days. Every new day, the window “rolls” by 1 day, which effectively erases usage run on the specific day 29 days ago. Any past usage that has fallen out of the new window is no longer accounted for, thus freeing up usage on the project. If no past usage falls out of the new window (i.e., no jobs were run specifically 29 days ago), then no minutes get freed up.

Example window

Example for a project that has a 1000 minute limit in the 10/18-11/15 window. For simplicity, let’s just say in this example that they aren’t running any new jobs right now, and have only run jobs in the past.

The “current” 10/18-11/15 window:

  • 100 minutes used on 10/18

  • 10 minutes used on 10/22

  • 500 minutes used on 10/24

A total of 610 minutes out of 1000 limit.

Tomorrow’s window 10/19-11/16:

  • 10 minutes used on 10/22

  • 500 minutes used on 10/24

A total of 510 minutes out of 1000 limit (100 minutes “freed” up because they fell out of the rolling window).

The next window 10/20-11/17:

  • 10 minutes used on 10/22

  • 500 minutes used on 10/24

Still 510 minutes accounted for since no “new” past usage rolled out of the window.

The takeaway is that if I run a job on Day XYZ, then I won’t get those minutes back until 29 days from Day XYZ. Until then, they will be accounted for in a given window and count toward the minute limit for a project.

Submitting Jobs

Jobs are compiled and submitted via Qiskit in a Python virtual environment or Jupyter notebook (see Cloud Access and Local Access sections above).

  • Circuit jobs comprise jobs of constructed quantum circuits and algorithms submitted to backends in IBM Quantum fair-share queue.

  • Program jobs utilize a pre-compiled quantum program utilizing the Qiskit Runtime framework.

Sessions

Warning

IBM Quantum retired reservations on Apr. 1st 2024. Reservations were replaced by sessions.

A session in Qiskit Runtime is a tool designed for running multiple jobs in sequence more effectively. It streamlines the process by grouping jobs together, reducing the wait times often associated with individually queued jobs. For more information on sessions can be found here: https://docs.quantum.ibm.com/run/sessions

Warning

Please note, starting a session by using the /jobs endpoint will no longer be supported after March 31, 2024. After this date, qiskit-ibm-runtime version 0.20.0 or later, or qiskit-ibm-provider version 0.10.0 or later must be used to start a session. If you are calling the API directly, use the /sessions endpoint instead. Refer to this documentation for information about using the Qiskit IBM Runtime API: https://docs.quantum.ibm.com/api/runtime

Checking System Availability & Capability

Current status listing, scheduled maintenance, and system capabilities for IBM Quantum’s quantum resources can be found here: https://quantum-computing.ibm.com/services?services=systems

Software

Additional Resources