Prefect workflow integration for Qiskit Primitives.
Project description
Prefect Qiskit
This library integrates Prefect with Qiskit Primitives, which are vendor-agnostic abstractions for quantum computation.
Given the high cost and limited processing time of quantum computation, fatal errors can disrupt the entire workflow. This library enhances software fault tolerance by implementing primitive execution within a Prefect workflow.
For more details, visit the full documentation here.
Installation
Prefect Qiskit requires Python 3.10 or later.
We encourage install via pip
pip install prefect-qiskit
Pip will handle all dependencies automatically and you will always install the latest version.
Quantum Computing Workflow
The programming model and syntax are largely consistent with conventional Qiskit primitives,
allowing easy integration of Prefect's powerful job management features
into existing experiment codebases.
The key difference is the use of the QuantumRuntime Block,
which implements the Prefect API for quantum computing.
Unlike the conventional pattern that uses primitive class instances to create jobs, the runtime Block encapsulates vendor-specific job handling and provides robust error handling during execution.
For example, the following script samples the probability distribution of the Bell state using the Qiskit Aer simulator.
from prefect import flow, task
from prefect_qiskit import QuantumRuntime
from prefect_qiskit.vendors import QiskitAerCredentials
from qiskit.circuit import QuantumCircuit
from qiskit.transpiler import generate_preset_pass_manager
@task
def transpile_task(circuit, target):
pm = generate_preset_pass_manager(
optimization_level=2,
target=target,
)
return pm.run(circuit)
@flow
def sample_bell():
# 1. Create QuantumRuntime for Aer backend
credentials = QiskitAerCredentials(
num_qubits=2,
noise=True,
)
runtime = QuantumRuntime(
resource_name="aer_simulator",
credentials=credentials,
)
# 2. Create ISA quantum circuit
bell = QuantumCircuit(2)
bell.h(0)
bell.cx(0, 1)
bell.measure_all()
isa_circ = transpile_task(
circuit=bell,
target=runtime.get_target(),
)
# 3. Execute workflow sampler
result = runtime.sampler(
[isa_circ],
options={"default_shots": 100},
)
print(result[0].data.meas.get_counts())
# Run the flow
if __name__ == "__main__":
sample_bell()
Before running your workflow, start the Prefect server:
prefect server start --background
You can then run the workflow as a standard Python script. Once the workflow begins, you can monitor its execution status in the Prefect console. For common workflow usage, refer to the Prefect documentation.
[!TIP] The runtime Block also supports asynchronous execution. For massive parallel execution of primitives, using the
awaitexpression will efficiently utilize your computational resources.
Registering Blocks
Register Blocks to make them available for use with the Prefect console.
prefect block register -m prefect_qiskit
prefect block register -m prefect_qiskit.vendors
Contribution Guidelines
If you'd like to contribute to Prefect Qiskit, please take a look at our contribution guidelines. By participating, you are expected to uphold our code of conduct.
We use GitHub issues for tracking requests and bugs. For Prefect workflow, open issues and PRs against PrefectHQ/prefect instead of this repository. Likewise, open issues and PRs against Qiskit/qiskit for Qiskit Primitives.
License
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file prefect_qiskit-0.2.0.tar.gz.
File metadata
- Download URL: prefect_qiskit-0.2.0.tar.gz
- Upload date:
- Size: 891.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fae6648b98e64d883c1f0dd6f5031298a0cba34e7b0ef35c953c6afb0bcd03f5
|
|
| MD5 |
f947cbd71aba2e4dd8a1a47ca91aafd2
|
|
| BLAKE2b-256 |
e4ab477ae54c20e5dd5183b15b76d86f4f51e9bea1728fd6ae4bf80fef76b440
|
Provenance
The following attestation bundles were made for prefect_qiskit-0.2.0.tar.gz:
Publisher:
release.yml on qiskit-community/prefect-qiskit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prefect_qiskit-0.2.0.tar.gz -
Subject digest:
fae6648b98e64d883c1f0dd6f5031298a0cba34e7b0ef35c953c6afb0bcd03f5 - Sigstore transparency entry: 281093735
- Sigstore integration time:
-
Permalink:
qiskit-community/prefect-qiskit@860256d80ba2dc35ab2547eaa56bd8c48ed1b9de -
Branch / Tag:
refs/tags/0.2.0 - Owner: https://github.com/qiskit-community
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@860256d80ba2dc35ab2547eaa56bd8c48ed1b9de -
Trigger Event:
push
-
Statement type:
File details
Details for the file prefect_qiskit-0.2.0-py3-none-any.whl.
File metadata
- Download URL: prefect_qiskit-0.2.0-py3-none-any.whl
- Upload date:
- Size: 715.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
681e56c1c3629f4571948df6c31ce064b5c7492a5335833f6982ed710226a743
|
|
| MD5 |
3d227a53def8c781b22d62792eacb493
|
|
| BLAKE2b-256 |
3eb36a6c5e07640442822e75914c3917992d67006507c65bb3d0e67b89aae356
|
Provenance
The following attestation bundles were made for prefect_qiskit-0.2.0-py3-none-any.whl:
Publisher:
release.yml on qiskit-community/prefect-qiskit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prefect_qiskit-0.2.0-py3-none-any.whl -
Subject digest:
681e56c1c3629f4571948df6c31ce064b5c7492a5335833f6982ed710226a743 - Sigstore transparency entry: 281093760
- Sigstore integration time:
-
Permalink:
qiskit-community/prefect-qiskit@860256d80ba2dc35ab2547eaa56bd8c48ed1b9de -
Branch / Tag:
refs/tags/0.2.0 - Owner: https://github.com/qiskit-community
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@860256d80ba2dc35ab2547eaa56bd8c48ed1b9de -
Trigger Event:
push
-
Statement type: