/QCompute

QCompute is a Python-based quantum software development kit (SDK). It provides a full-stack programming experience for advanced users via hybrid quantum programming language features and a high-performance simulator.

Primary LanguagePythonOtherNOASSERTION

QCompute

Quantum Leaf (量易伏) is a Cloud-Native quantum computing platform developed by the Institute for Quantum Computing, Baidu. It is used for programming, simulating and executing quantum computers, aiming at providing the quantum programming environment for Quantum infrastructure as a Service (QaaS).

QCompute is a Python-based open-source SDK. It provides a full-stack programming experience for advanced users via the features of hybrid quantum programming language and a high-performance simulator. Users can use the already-built objects and modules of quantum programming environment, pass parameters to build and execute the quantum circuits on the local simulator or the cloud simulator/hardware.

QCompute provides services for creating and analyzing quantum circuits, and calling quantum backend. The architecture of Quantum Leaf including QCompute is shown in the figure below.

In particular, cloud service requires login at Quantum-hub. The token, large-scale results and more information can be found from the website.

Getting Started

Use one-step live setup

pip install qcompute

Or use local setup

pip install -e .

Then, config the python interpreter to execute examples.

Please prepare Python environment and Pip tool. Be careful about different path separators on operating systems. At present, Python 3.6-3.8 versions are compatible.

Running the tests

python -m QCompute.Test.PostInstall.PostInstall

Please test on a local simulator first, and then fill in your token of Quantum-hub to test on a cloud simulator.

Development

  1. QCompute SDK contains quantum toolkits, simulators, examples and docs. If concerned with quantum toolkits, e.g., the QCompute subfolder, you are highly suggested using 'local setup' process to ensure that any development could be reflected in the executing process.
  2. Most researchers who only work on the quantum applications (examples) are suggested to use one-step live setup. In this case, the local modification of QCompute would NOT be reflected in the executing process. However, the modification on the subfolder, Example, would be still valid.

Contributing

Coding requirements:

  1. Be familiar with quantum circuit model. Any pull should be tested first and then submitted. Be careful about the order of qubits.
  2. Please comply with development specifications of relevant programming languages.

Discussion

  1. If any questions, advices, suggestions, please contact us via Email: quantum@baidu.com ;
  2. Or, you can use internal feedback table in Quantum-hub to provide any feedbacks;
  3. Or, you are also welcomed to join our discussion QQ group: QQ Group Number:1147781135

Maintainers & Authors

Institute for Quantum Computing, Baidu.

Changelog

The changelog of this project can be found in CHANGELOG.md.

License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details