forked from Qiskit/documentation
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Port migration guide for Runtime 0.15 (Qiskit#374)
Brings over Qiskit/qiskit-ibm-runtime#1214. I did this by: 1. Copying and pasting the RST file 2. Running `st2myst convert docs/api/migration-guides/qiskit-runtime-backend-run.rst`, which generated a MD file 3. Renaming the file to end in `.mdx` and adding "front matter" (metadata) 4. Manually tweaking any issues 5. Attributing the original author in the Git commit with `git log --pretty="%an <%ae>" -- docs/migrate/backend_run_migration_guide.rst | sort -u | awk '{print "Co-authored-by: " $0}'` run in the qiskit-ibm-runtime repo I'll set up a redirect in Qiskit#216 for Nov 29. Co-authored-by: merav-aharoni <merav@il.ibm.com>
- Loading branch information
1 parent
7f4b1f6
commit f87d976
Showing
3 changed files
with
107 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
102 changes: 102 additions & 0 deletions
102
docs/api/migration-guides/qiskit-runtime-from-provider.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
--- | ||
title: Migrate from qiskit_ibm_provider to qiskit_ibm_runtime | ||
description: How to migrate `backend.run()` from Qiskit IBM Provider to Qiskit IBM Runtime | ||
--- | ||
|
||
# Migrate `backend.run()` from `qiskit_ibm_provider` to `qiskit_ibm_runtime` | ||
|
||
The Qiskit Runtime interface includes two packages: | ||
Qiskit IBM Provider (the [`qiskit_ibm_provider`](../qiskit-ibm-provider) package) and | ||
Qiskit IBM Runtime (the [`qiskit_ibm_runtime`](../qiskit-ibm-runtime) package). Until now, | ||
primitives (`Sampler` and `Estimator`) | ||
were run in Runtime. Custom circuits that were manually transpiled and used `IBMBackend.run()` | ||
were run in Provider. | ||
|
||
In the `qiskit-ibm-runtime` 0.15 release, we added support for running custom circuits using `IBMBackend.run()` in Runtime, | ||
so users can run all programs through Runtime. | ||
|
||
This guide describes how to migrate code that implemented `IBMBackend.run()` | ||
using Qiskit IBM Provider to use Qiskit IBM Runtime instead. | ||
|
||
**Example 1: Straightforward execution of IBMBackend.run()** | ||
|
||
```python | ||
from qiskit import * | ||
from qiskit.compiler import transpile, assemble | ||
|
||
circuit = QuantumCircuit(2, 2) | ||
circuit.h(0) | ||
circuit.cx(0, 1) | ||
circuit.measure_all() | ||
``` | ||
|
||
In Provider, the code is: | ||
|
||
```python | ||
from qiskit_ibm_provider import IBMProvider | ||
|
||
provider = IBMProvider() | ||
backend = provider.get_backend("ibmq_qasm_simulator") | ||
transpiled_circuit = transpile(circuit, backend=backend) | ||
job = backend.run(transpiled_circuit) | ||
print(job.result()) | ||
``` | ||
|
||
In Runtime, the code is: | ||
|
||
```python | ||
from qiskit_ibm_runtime import QiskitRuntimeService | ||
|
||
service = QiskitRuntimeService(channel="ibm_quantum") | ||
backend = service.backend("ibmq_qasm_simulator") | ||
transpiled_circuit = transpile(circuit, backend=backend) | ||
job = backend.run(transpiled_circuit) | ||
print(job.result()) | ||
``` | ||
|
||
**Example 2: Execution of backend.run() within a session:** | ||
|
||
This section of code is identical in Provider and in Runtime. | ||
|
||
```python | ||
with backend.open_session() as session: | ||
job1 = backend.run(transpiled_circuit) | ||
job2 = backend.run(transpiled_circuit) | ||
print(job1.session_id) | ||
print(job2.session_id) | ||
backend.cancel_session() | ||
``` | ||
|
||
Sessions are implemented differently in `IBMBackend` than when using primitives. | ||
Therefore, we cannot run a primitive and use backend.run() within a single session. If you specify both, one will be run outside of the session. | ||
|
||
**Example 3: Primitive session containing backend.run:** | ||
|
||
In this example, `sampler` is run within session, but `backend` is run independently | ||
of the session. | ||
|
||
```python | ||
from qiskit_ibm_runtime import Session, Sampler | ||
|
||
with Session(backend=backend) as session: | ||
sampler = Sampler(session=session) | ||
job1 = sampler.run(transpiled_circuit) | ||
job2 = backend.run(transpiled_circuit) # runs outside the session | ||
print(job1.session_id) | ||
print(job2.session_id) # is None | ||
``` | ||
|
||
**Example 4: Backend session containing Sampler:** | ||
|
||
In this example, `backend` is run within a session, but `sampler` is run independently | ||
of the session. | ||
|
||
```python | ||
with backend.open_session() as session: | ||
sampler = Sampler(backend=backend) | ||
job1 = sampler.run(transpiled_circuit) # runs outside the session | ||
job2 = backend.run(transpiled_circuit) | ||
session_id = session.session_id | ||
print(job1.session_id) # is None | ||
print(job2.session_id) | ||
``` |