To try out this library, you can run example notebooks in a pre-made binder. Alternately, you can run the following to build and run the image locally:
docker build -t qiskit-tutorials .
docker run --rm -p 8888:8888 qiskit-tutorials
then click on the link that is displayed after the container starts up.
- Install Docker
- Download qelib1.inc
- Place
qelib1.inc
in a folder calledinc
in the project root
Run docker compose up
to see service logs or docker compose up -d
to run in the background.
-
Start the QVM:
docker run --rm -it -p 5000:5000 rigetti/qvm -S
-
Start the compiler:
docker run --rm -it -p 5555:5555 -v "$PWD"/inc:/inc rigetti/quilc -S -P --safe-include-directory /inc/
Example:
from qiskit import execute
from qiskit_rigetti import RigettiQCSProvider, QuilCircuit
# Get provider and backend
p = RigettiQCSProvider()
backend = p.get_simulator(num_qubits=2, noisy=True) # or p.get_backend(name='Aspen-9')
# Create a Bell state circuit
circuit = QuilCircuit(2, 2)
circuit.h(0)
circuit.cx(0, 1)
circuit.measure([0, 1], [0, 1])
# Execute the circuit on the backend
job = execute(circuit, backend, shots=10, coupling_map=backend.coupling_map)
# Grab results from the job
result = job.result()
# Return memory and counts
memory = result.get_memory(circuit)
counts = result.get_counts(circuit)
print("Result memory:", memory)
print("Result counts:", counts)
Execution against a QPU requires a reservation via QCS. For more information on using QCS, see the QCS documentation.
For advanced QASM and Quil manipulation, before_compile
and before_execute
keyword arguments can be passed to
RigettiQCSBackend.run()
or to Qiskit's execute()
.
Any before_compile
hooks will apply, in order, just before compilation from QASM to native Quil.
For example:
...
def custom_hook_1(qasm: str) -> str:
new_qasm = ...
return new_qasm
def custom_hook_2(qasm: str) -> str:
new_qasm = ...
return new_qasm
job = execute(circuit, backend, shots=10, before_compile=[custom_hook_1, custom_hook_2])
...
Any before_execute
hooks will apply, in order, just before execution (after translation from QASM to native Quil).
For example:
from pyquil import Program
...
def custom_hook_1(quil: Program) -> Program:
new_quil = ...
return new_quil
def custom_hook_2(quil: Program) -> Program:
new_quil = ...
return new_quil
job = execute(circuit, backend, shots=10, before_execute=[custom_hook_1, custom_hook_2])
...
Note:
Only certain forms of Quil can can be executed on a QPU. If pre-execution transformations produce a final program that is not QPU-compliant,
ensure_native_quil=True
can be passed toexecute()
orRigettiQCSBackend.run()
to recompile the final Quil program to native Quil prior to execution. If no pre-execution hooks were supplied, this setting is ignored. If this setting is omitted, a value ofFalse
is assumed.Example: Adding the Quil instruction
H 0
would result in an error ifensure_native_quil=False
and the QPU does not natively implement Hadamard gates.
The hooks.pre_compilation
and hooks.pre_execution
packages provide a number of convenient hooks:
Use set_rewiring
to provide a rewiring directive
to the Quil compiler. For example:
from qiskit_rigetti.hooks.pre_compilation import set_rewiring
...
job = execute(circuit, backend, shots=10, before_compile=[set_rewiring("NAIVE")])
...
Note: Rewiring directives require
quilc
version 1.25 or higher.
Use enable_active_reset
to enable active qubit reset,
an optimization that can significantly reduce the time between executions. For example:
from qiskit_rigetti.hooks.pre_execution import enable_active_reset
...
job = execute(circuit, backend, shots=10, before_execute=[enable_active_reset])
...
Note: This module is developed in Python 3.8, 3.9, and 3.10, other versions will currently fail type checking.
Dependencies are managed with Poetry so you need to install that first. Once you've installed all dependencies (poetry install
) and activated the virtual environment (poetry shell
), you can use these rules from the Makefile
to run common tasks:
- Run tests:
make test
- Check style and types:
make check-all
- Check style only:
make check-style
- Check types only:
make check-types
- Reformat all code (to make
check-style
pass):make format
- Build documentation, serve locally, and watch for changes:
make watch-docs
(requiresdocs
extra:poetry install -E docs
)