Skip to main content

Software for developing quantum computing programs

Project description

Qiskit

Release License DOI

[!IMPORTANT] The package qiskit-terra is not going to be updated after August 15th, 2024. Since Qiskit 0.44 (released on July 27th, 2023), the qiskit meta-package only contains qiskit-terra. In Qiskit 1.0 and beyond, the meta-package architecture is removed. If you are installing or depending on qiskit-terra, consider changing that to qiskit: Either qiskit>=0.x,<1 (if you did not transition to Qiskit 1.0 yet) or qiskit>=0.x,<2 (to also include Qiskit 1.*). Read more.

Qiskit is an open-source SDK for working with quantum computers at the level of extended quantum circuits, operators, and primitives.

This library is the core component of Qiskit, which contains the building blocks for creating and working with quantum circuits, quantum operators, and primitive functions (sampler and estimator). It also contains a transpiler that supports optimizing quantum circuits and a quantum information toolbox for creating advanced quantum operators.

For more details on how to use Qiskit, refer to the documentation located here:

https://qiskit.org/documentation/

Installation

[!WARNING] Do not try to upgrade an existing Qiskit 0.* environment to Qiskit 1.0 in-place. Read more.

We encourage installing Qiskit via pip:

pip install qiskit

Pip will handle all dependencies automatically and you will always install the latest (and well-tested) version.

To install from source, follow the instructions in the documentation.

Create your first quantum program in Qiskit

Now that Qiskit is installed, it's time to begin working with Qiskit. The essential parts of a quantum program are:

  1. Define and build a quantum circuit that represents the quantum state
  2. Define the classical output by measurements or a set of observable operators
  3. Depending on the output, use the primitive function sampler to sample outcomes or the estimator to estimate values.

Create an example quantum circuit using the QuantumCircuit class:

import numpy as np
from qiskit import QuantumCircuit

# 1. A quantum circuit for preparing the quantum state |000> + i |111>
qc_example = QuantumCircuit(3)
qc_example.h(0)          # generate superpostion
qc_example.p(np.pi/2,0)  # add quantum phase
qc_example.cx(0,1)       # 0th-qubit-Controlled-NOT gate on 1st qubit
qc_example.cx(0,2)       # 0th-qubit-Controlled-NOT gate on 2nd qubit

This simple example makes an entangled state known as a GHZ state $(|000\rangle + i|111\rangle)/\sqrt{2}$. It uses the standard quantum gates: Hadamard gate (h), Phase gate (p), and CNOT gate (cx).

Once you've made your first quantum circuit, choose which primitive function you will use. Starting with sampler, we use measure_all(inplace=False) to get a copy of the circuit in which all the qubits are measured:

# 2. Add the classical output in the form of measurement of all qubits
qc_measured = qc_example.measure_all(inplace=False)

# 3. Execute using the Sampler primitive
from qiskit.primitives.sampler import Sampler
sampler = Sampler()
job = sampler.run(qc_measured, shots=1000)
result = job.result()
print(f" > Quasi probability distribution: {result.quasi_dists}")

Running this will give an outcome similar to {0: 0.497, 7: 0.503} which is 000 50% of the time and 111 50% of the time up to statistical fluctuations.
To illustrate the power of Estimator, we now use the quantum information toolbox to create the operator $XXY+XYX+YXX-YYY$ and pass it to the run() function, along with our quantum circuit. Note the Estimator requires a circuit without measurement, so we use the qc_example circuit we created earlier.

# 2. define the observable to be measured 
from qiskit.quantum_info import SparsePauliOp
operator = SparsePauliOp.from_list([("XXY", 1), ("XYX", 1), ("YXX", 1), ("YYY", -1)])

# 3. Execute using the Estimator primitive
from qiskit.primitives import Estimator
estimator = Estimator()
job = estimator.run(qc_example, operator, shots=1000)
result = job.result()
print(f" > Expectation values: {result.values}")

Running this will give the outcome 4. For fun, try to assign a value of +/- 1 to each single-qubit operator X and Y and see if you can achieve this outcome. (Spoiler alert: this is not possible!)

Using the Qiskit-provided qiskit.primitives.Sampler and qiskit.primitives.Estimator will not take you very far. The power of quantum computing cannot be simulated on classical computers and you need to use real quantum hardware to scale to larger quantum circuits. However, running a quantum circuit on hardware requires rewriting them to the basis gates and connectivity of the quantum hardware. The tool that does this is the transpiler and Qiskit includes transpiler passes for synthesis, optimization, mapping, and scheduling. However, it also includes a default compiler which works very well in most examples. The following code will map the example circuit to the basis_gates = ['cz', 'sx', 'rz'] and a linear chain of qubits $0 \rightarrow 1 \rightarrow 2$ with the coupling_map =[[0, 1], [1, 2]].

from qiskit import transpile
qc_transpiled = transpile(qc_example, basis_gates = ['cz', 'sx', 'rz'], coupling_map =[[0, 1], [1, 2]] , optimization_level=3)

For further examples of using Qiskit you can look at the tutorials in the documentation here:

https://qiskit.org/documentation/tutorials.html

Executing your code on real quantum hardware

Qiskit provides an abstraction layer that lets users run quantum circuits on hardware from any vendor that provides a compatible interface. The best way to use Qiskit is with a runtime environment that provides optimized implementations of sampler and estimator for a given hardware platform. This runtime may involve using pre- and post-processing, such as optimized transpiler passes with error suppression, error mitigation, and, eventually, error correction built in. A runtime implements qiskit.primitives.BaseSampler and qiskit.primitives.BaseEstimator interfaces. For example, some packages that provide implementations of a runtime primitive implementation are:

Qiskit also provides a lower-level abstract interface for describing quantum backends. This interface, located in qiskit.providers, defines an abstract BackendV2 class that providers can implement to represent their hardware or simulators to Qiskit. The backend class includes a common interface for executing circuits on the backends; however, in this interface each provider may perform different types of pre- and post-processing and return outcomes that are vendor-defined. Some examples of published provider packages that interface with real hardware are:

You can refer to the documentation of these packages for further instructions on how to get access and use these systems.

Contribution Guidelines

If you'd like to contribute to 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. Please join the Qiskit Slack community for discussion, comments, and questions. For questions related to running or using Qiskit, Stack Overflow has a qiskit. For questions on quantum computing with Qiskit, use the qiskit tag in the Quantum Computing Stack Exchange (please, read first the guidelines on how to ask in that forum).

Authors and Citation

Qiskit is the work of many people who contribute to the project at different levels. If you use Qiskit, please cite as per the included BibTeX file.

Changelog and Release Notes

The changelog for a particular release is dynamically generated and gets written to the release page on Github for each release. For example, you can find the page for the 0.9.0 release here:

https://github.com/Qiskit/qiskit-terra/releases/tag/0.9.0

The changelog for the current release can be found in the releases tab: Releases The changelog provides a quick overview of notable changes for a given release.

Additionally, as part of each release detailed release notes are written to document in detail what has changed as part of a release. This includes any documentation on potential breaking changes on upgrade and new features. For example, you can find the release notes for the 0.9.0 release in the Qiskit documentation here:

https://qiskit.org/documentation/release_notes.html#terra-0-9

Acknowledgements

We acknowledge partial support for Qiskit development from the DOE Office of Science National Quantum Information Science Research Centers, Co-design Center for Quantum Advantage (C2QA) under contract number DE-SC0012704.

License

Apache License 2.0

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qiskit_terra-0.46.3.tar.gz (5.2 MB view details)

Uploaded Source

Built Distributions

qiskit_terra-0.46.3-cp38-abi3-win_amd64.whl (5.2 MB view details)

Uploaded CPython 3.8+ Windows x86-64

qiskit_terra-0.46.3-cp38-abi3-win32.whl (5.1 MB view details)

Uploaded CPython 3.8+ Windows x86

qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (5.4 MB view details)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ x86-64

qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_s390x.manylinux2014_s390x.whl (5.9 MB view details)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ s390x

qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (5.5 MB view details)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ ppc64le

qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (5.4 MB view details)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ ARM64

qiskit_terra-0.46.3-cp38-abi3-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl (5.5 MB view details)

Uploaded CPython 3.8+ manylinux: glibc 2.12+ i686 manylinux: glibc 2.17+ i686

qiskit_terra-0.46.3-cp38-abi3-macosx_11_0_arm64.whl (5.4 MB view details)

Uploaded CPython 3.8+ macOS 11.0+ ARM64

qiskit_terra-0.46.3-cp38-abi3-macosx_10_9_x86_64.whl (5.5 MB view details)

Uploaded CPython 3.8+ macOS 10.9+ x86-64

qiskit_terra-0.46.3-cp38-abi3-macosx_10_9_universal2.whl (6.4 MB view details)

Uploaded CPython 3.8+ macOS 10.9+ universal2 (ARM64, x86-64)

File details

Details for the file qiskit_terra-0.46.3.tar.gz.

File metadata

  • Download URL: qiskit_terra-0.46.3.tar.gz
  • Upload date:
  • Size: 5.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for qiskit_terra-0.46.3.tar.gz
Algorithm Hash digest
SHA256 48e0e193e322fe9ee7201a8f8a7b8e3dd463c4804e64c36a733d7ad34acdddb7
MD5 053717203402c124828480872b8348ae
BLAKE2b-256 e3277d4882c6bdce5c22b93b07533b9357a94a1010f9e563b1213e9d71478d43

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 ffd5ddc808e7780c49c085287608150d7e64748a6d874cf1a333f1ecc2781d37
MD5 cb2a0ecb47e1afed7c3745ec053540a2
BLAKE2b-256 9831bb89a69575820815d0256055bb1abcd4d67d537c36305b6cbdca60a7145e

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-win32.whl.

File metadata

  • Download URL: qiskit_terra-0.46.3-cp38-abi3-win32.whl
  • Upload date:
  • Size: 5.1 MB
  • Tags: CPython 3.8+, Windows x86
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-win32.whl
Algorithm Hash digest
SHA256 e4d45ed4262478c7c2db187376608488e7c5b38fed399470e7e91f2412605c5f
MD5 9ac3baf2d77bc04848ba9faaa4c21035
BLAKE2b-256 3413be6cbba39ba1d4129087c82535c81c5821879a332829c9d6f5f6797318d2

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 80f06b9bdd095d7cb16482d0baa0b081163b05fafd9ca1ab782b1769bee8213c
MD5 78d8cb8a0b33f674456b7082dce7eb34
BLAKE2b-256 e1f91531226e78a46e7ef6108b844531ccaa4880345314614941a2da8cd77794

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_s390x.manylinux2014_s390x.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_s390x.manylinux2014_s390x.whl
Algorithm Hash digest
SHA256 16509c43f2e673d3f2be4760d02a5b79799416f133a322b043bd65da1a08be58
MD5 496a5d9c24d67aa315e70f3c79c1d494
BLAKE2b-256 44767f93e3a81f4241546251fa3ea3386dbaddcc9f93c81122c373b406352944

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl
Algorithm Hash digest
SHA256 a8a2b6b49772310297032e0f3f30f33f3520dca6f7fae17c4f7b73f6f91c897f
MD5 cfe29a2c40ffe03a6e487252e535b9d4
BLAKE2b-256 650a1d2fe43fa14e12d8f3bb599322f7a74d68c3b497725aa43dc0f15019e199

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 997edd073f701173fe1a36fda00247664f23f17e596b3d6737fffea7ef761424
MD5 9625f7f92f4b8e04006cbac499e16484
BLAKE2b-256 d9bec6e25ca59139512d418ae2a5933c33e3ecade3e1dd7e1a5b21ed76118fcc

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl
Algorithm Hash digest
SHA256 baf4c44f5d4d9f82d053e316dfbb039a9a3057198bf413dea0ee29e0a5b59e11
MD5 8bd232a776675f1f647761dffab01bcf
BLAKE2b-256 3943e4e2ba2e5e33100432b7c7166b41d6fa92edb5a46681f58af1e75fea15fe

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 cfad66321ac0938dccea334eb049dc6288790cecc39fb85d5c9c473525b3565d
MD5 6a2260b769eea7d6bb23ba875ebd5f94
BLAKE2b-256 610040d7509e3852f869b62cda3509af0be3e33f7fcfac92b6778df843705e9c

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 fd1f31571f3a832928692dcf3945e16b64c87ccd70f68739a16d3d2fb95e64d4
MD5 a46cc5d8e6c451a49e6bc2fbd176739e
BLAKE2b-256 80bd2b74f586759134eb76a06ed40925be1a9d0fbc186b3172f0b383b75f6bbb

See more details on using hashes here.

File details

Details for the file qiskit_terra-0.46.3-cp38-abi3-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for qiskit_terra-0.46.3-cp38-abi3-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 3e6313e03706be8f35551e2abe950006047a09d037c96bc8d2907081b548e91b
MD5 d032b9426c2298bc5caf819ff1b6d00e
BLAKE2b-256 bb5dbebf97df13de1765280c064ec6d9810435850a3bb5d99e7fadda4260ac53

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page