Skip to main content

Platform-independent quantum computing software development kit

Project description

QURI SDK

QURI SDK is an open source library suite for creating and executing quantum algorithms on various quantum computers and simulators. QURI SDK focuses on the followings:

  • Modularity and extensibility: It provides small parts with which you can assemble your own algorithms. You can also use ready-made algorithms, customizing their details by replacing sub components easily.
  • Platform independence: Once you assemble an algorithm with QURI SDK, you can execute it on various quantum computers or simulators without modifying the main algorithm code. Typically you only need to replace a few lines to switch to a different device or simulator.
  • Performance: When dealing with a simulator, it is often the case that classical computation before and after quantum circuit simulation (such as data preparation and post processing) takes considerable time, spoiling performance of the simulator. We put an emphasis on computational performance and try to get the most out of simulators.

Covered areas and components

QURI SDK is a meta-package that bundles the following packages, ensuring that versions are always compatible.

  • Core components
    • quri-parts: Quantum circuit and operator library. QURI Parts contains abstractions that represent generic quantum circuits and operators, including noise, estimators, samplers, etc. It also features a wide range of transpilers and interfaces with commonly used quantum SDKs. In addition it features a quantum circuit synthesis module that allows for advanced construction of circuits for fault tolerant quantum computing (FTQC). QURI Parts is platform independent -- quantum simulation and device execution is facilitated through backends defined in various subpackages
      • Quantum circuit simulators
      • Quantum platforms/SDKs
      • Intermediate representation support
      • Higher level packages
        • quri-parts-qsub: Structured circuit generation for FTQC algorithms
        • quri-parts-algo: NISQ algorithm components
          • Ansatz, optimizer, error mitigation etc.
      • Chemistry
        • quri-parts-chem: General concepts
          • Fermion-qubit mapping, electron integrals, ansatz etc.
        • quri-parts-pyscf: PySCF
        • Library support
    • quri-algo: Quantum algorithms and components for FTQC and Early FTQC. Contains time-evolution circuit factories and abstractions for algorithms, cost-functions, various problem definitions. It uses a modular design in which individual solvers and objective functions can be replaced or rewritten easily. Algorithms in QURI Algo are written to interface with QURI VM, although they use an abstract interface that can be used with user-defined virtual machines defined independently of QURI SDK.
    • quri-vm: Quantum virtual machine library written to facilitate quantum resource estimation and device aware quantum circuit simulation. The user defines a VM which generates its own sampler and estimator as well as an analyzer for quantum circuit resource analysis.

Installation

QURI SDK requires Python 3.10 or later.

Use pip to install QURI Parts. Default installation only contains components not depending specific platforms (devices/simulators) or external libraries. You need to specify extras with square brackets ([]) to use those platforms and external libraries with QURI Parts:

# Default installation, no extras
pip install quri-sdk

# Use Qulacs, a quantum circuit simulator through its quri-parts interface
pip install "quri-sdk[qulacs]"

# Use Amazon Braket SDK
pip install "quri-sdk[braket]"

# Use Qulacs and OpenFermion, a quantum chemistry library for quantum computers
pip install "quri-sdk[qulacs,openfermion]"

Currently available extras for quri-parts are:

  • qulacs
  • braket
  • qiskit
  • cirq
  • openfermion
  • stim
  • openqasm
  • itensor
  • qsub
  • quantinuum
  • ionq
  • pyscf
  • tket
  • tensornetwork

You can also install individual components (quri-parts-*) directly. In fact, quri-parts is a meta package, a convenience method to install those individual components.

Documentation and tutorials

Documentation of QURI SDK is available at https://quri-sdk.qunasys.com/. Tutorials would be a good starting point.

Release notes

See Releases page on GitHub.

Contribution guidelines

If you are interested in contributing to QURI Parts, please take a look at our contribution guidelines.

Authors

QURI SDK developed and maintained by QunaSys Inc.. All contributors can be viewed on GitHub.

License

QURI Parts is licensed under Apache License 2.0. QURI Algo is licensed under an MIT license. QURI VM is licensed under an MIT 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

quri_sdk-0.23.0.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

quri_sdk-0.23.0-py3-none-any.whl (3.8 kB view details)

Uploaded Python 3

File details

Details for the file quri_sdk-0.23.0.tar.gz.

File metadata

  • Download URL: quri_sdk-0.23.0.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for quri_sdk-0.23.0.tar.gz
Algorithm Hash digest
SHA256 87280ba5cb32a6bef243822b4c126cb780adc02c3a3642a4fbc211d82d8ca19b
MD5 5113ef6750865429942505c35871faf4
BLAKE2b-256 3f53ed994612045a01f1e8aa210e19bc0420b11592dbd2b3e09edd40f490e974

See more details on using hashes here.

File details

Details for the file quri_sdk-0.23.0-py3-none-any.whl.

File metadata

  • Download URL: quri_sdk-0.23.0-py3-none-any.whl
  • Upload date:
  • Size: 3.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for quri_sdk-0.23.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8165b78702e665e0176094f36eafe6be75331643d4c0b8783b842de25123a90c
MD5 6f672bda212bcb7f7595ae0404804fdd
BLAKE2b-256 7a790981b2d1cbb1269bce94dce5195d860156d6bed988e966a9438dd7fe2f8e

See more details on using hashes here.

Supported by

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