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-tutorialsthen click on the link that is displayed after the container starts up.
- Install Docker
- Download qelib1.inc
- Place
qelib1.incin a folder calledincin 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=Truecan 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 ofFalseis assumed.Example: Adding the Quil instruction
H 0would result in an error ifensure_native_quil=Falseand 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
quilcversion 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-stylepass):make format - Build documentation, serve locally, and watch for changes:
make watch-docs(requiresdocsextra:poetry install -E docs)