Skip to main content

A Quantum Error Processing toolkit developed by the Institute for Quantum Computing at Baidu Research.

Project description

Copyright (c) 2022 Institute for Quantum Computing, Baidu Inc. All Rights Reserved.

About QEP

QEP is a Quantum Error Processing toolkit developed by the Institute for Quantum Computing at Baidu Research. It aims to deal with quantum errors inherent in quantum devices using software solutions. Currently, it offers four powerful quantum error processing functions: performance evaluation, quantum error characterization, quantum error mitigation, and quantum error correction:

  • Performance Evaluation is used for assessing the capabilities and extendibilities of quantum computing hardware platforms, through estimating the error rates of quantum states, quantum gates, and quantum measurement apparatus. It provides standard randomized benchmarking, interleaved randomized benchmarking, cross-entropy benchmarking, unitarity randomized benchmarking, direct fidelity estimation, and cross-platform fidelity estimation methods.

  • Quantum Error Characterization is used for reconstructing the comprehensive information in quantum computing hardware platforms, through many partial and limited experimental results. It provides quantum state tomography, quantum process tomography, quantum detector tomography, quantum gateset tomography, and spectral quantum tomography.

  • Quantum Error Mitigation is used for improving the accuracy of quantum computational results, through post-processing the experiment data obtained by varying noisy experiments,
    extending the computational reach of a noisy superconducting quantum processor. It provides zero-noise extrapolation technique to mitigate quantum gate noise, and a collection of methods such as inverse, least-square, iterative Bayesian unfolding, Neumann series to mitigate quantum measurement noise.

  • Quantum Error Correction (QEC) is used to protect quantum information from errors due to environmental noise and imperfections in hardware. Quantum computers rely on the delicate properties of quantum systems, which are susceptible to errors, and thus, QEC has become an essential tool for realizing fault-tolerant quantum computing. It provides a simulator that can simulate error correction codes based on the stabilizer formalism, allowing users to study the effects of various types of noise, assess the performance of different error correction codes, and evaluate the robustness of quantum algorithms to errors.

QEP is based on QCompute, which a Python-based open-source quantum computing platform SDK also developed by Institute for Quantum Computing. It provides a full-stack programming experience for senior users via hybrid quantum programming language features and high-performance simulators. You can install QCompute via pypi. When you install QEP, QCompute will be automatically installed. Please refer to QCompute's official Open Source page for more details.

Installation

Install QEP

The package QEP is compatible with 64-bit Python 3.8 and 3.9, on Linux, MacOS (10.14 or later) and Windows. We highly recommend the users to install QEP via pip. Open the Terminal and run

pip install qcompute-qep

This will install the QEP binaries as well as the QEP package. For those using an older version of QEP, keep up to date by installing with the --upgrade flag for additional features and bug fixes.

Run Examples

After installation, you can try the following simple program to check whether QEP has been successfully installed.

from QCompute import *
import qcompute_qep.tomography as tomography


# Step 1. Initialize a quantum program for preparing the Bell state
qp = QEnv()  # qp is short for "quantum program", instance of QProgram
qp.Q.createList(2)
H(qp.Q[0])
CX(qp.Q[0], qp.Q[1])

# Step 2. Set the quantum computer (instance of QComputer).
# For debugging on ideal simulator, change qc to BackendName.LocalBaiduSim2
qc = BackendName.LocalBaiduSim2

# For test on real quantum hardware, change qc to BackendName.CloudBaiduQPUQian
# You must set your VIP token in order to access the hardware
# Define.hubToken = "Token"
# qc = BackendName.CloudBaiduQPUQian

# Step 3. Perform Quantum State Tomography, check how well the Bell state is prepared.
st = tomography.StateTomography()

# Alternatively, you may initialize the StateTomography instance as follows:
# st = StateTomography(qp, qc, method='inverse', shots=4096)

# Call the tomography procedure and obtain the noisy quantum state
st.fit(qp, qc, method='inverse', shots=4096)

print("***********************************************************************")
print("Testing whether 'qcompute-qep' is successfully installed or not now ...\n")

print('Fidelity of the Bell state is: F = {:.5f}'.format(st.fidelity))
print("Please change 'qc' to other quantum computers for more tests.\n")

print("Package 'qcompute-qep' is successfully installed! Please enjoy!")
print("***********************************************************************")

Note that more examples are provided in the API documentation, the QEP Tutorials, and the source file of QEP hosted in GitHub. You can get started from there.

Tutorials

QEP provides detailed and comprehensive tutorials for performance evaluation, quantum error characterization, quantum error mitigation, and quantum error correction, ranging from theoretical analysis to practical application. We recommend the interested researchers or developers to download the Jupyter Notebooks and try it. The tutorials are listed as follows:

More tutorials and demonstrations will be included in the future release.

API Documentation

For those who are looking for explanation on the python classes and functions in QEP, please refer to our API documentation.

Feedbacks

Users are encouraged to contact us via email quantum@baidu.com with general questions, unfixed bugs, and potential improvements. We hope to make QEP better together with the community!

Research based on QEP

We encourage researchers and developers to use QEP to explore quantum error processing. If your work uses QEP, please feel free to send us a notice via quantum@baidu.com and cite us with the following BibTeX:

@misc{QEP, 
    author={{Baidu Quantum}},
    title={{Quantum Error Processing Toolkit (QEP)}}, 
    year={2022}, 
    url={https://quantum-hub.baidu.com/qep/}, 
    version={1.1.0}
}

Copyright and License

QEP uses Apache-2.0 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

qcompute-qep-1.1.0.tar.gz (155.6 kB view details)

Uploaded Source

Built Distribution

qcompute_qep-1.1.0-py3-none-any.whl (208.8 kB view details)

Uploaded Python 3

File details

Details for the file qcompute-qep-1.1.0.tar.gz.

File metadata

  • Download URL: qcompute-qep-1.1.0.tar.gz
  • Upload date:
  • Size: 155.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for qcompute-qep-1.1.0.tar.gz
Algorithm Hash digest
SHA256 753aebd501b540f7ba1ec3b907efc882e33cfc2b5154ec2b86229d539348047c
MD5 18f98d536c72a3cc02b54cd250280b13
BLAKE2b-256 347155335a597777082e1c319b32751e37de596a022d7c5ba6e40aa3a7c743af

See more details on using hashes here.

File details

Details for the file qcompute_qep-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: qcompute_qep-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 208.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for qcompute_qep-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8e634d086d384bdfd4cbf31fcf7da885c8e76ee7474d6dfcbbf5913b330da854
MD5 7e6ef85bc2eb05ae5286750990908491
BLAKE2b-256 829554331dd2867edc3cb4ae135cc60fb2eaba34ce4c14af469dd02ad6d06083

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