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.24.1.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.24.1-py3-none-any.whl (3.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: quri_sdk-0.24.1.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.24.1.tar.gz
Algorithm Hash digest
SHA256 2d5e9963a220bce5c5d5d05ddb11d121e46e3cfa12530a54efcfc2a3eda23669
MD5 24e934fd8a8cc6fef04b5a075ea7a10f
BLAKE2b-256 19a23157ad1dffd377546a09477b1eb40c511e3dffa9876b802205204e373a6e

See more details on using hashes here.

File details

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

File metadata

  • Download URL: quri_sdk-0.24.1-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.24.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f37152fbeb4e6a672ea38b50fff036f4b98eb9569486e4108cb76c07cdac3ae0
MD5 8d1dd668393eabcfc335c5fce0e0689a
BLAKE2b-256 6bb85af180dcb67e6a071ccbbf34f17373734668ca679c59c8ec01206598979a

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