Skip to main content

Quantum circuits on top of tensor network

Project description

TENSORCIRCUIT

English | 简体中文

TensorCircuit is the next generation of quantum circuit simulator with support for automatic differentiation, just-in-time compiling, hardware acceleration, and vectorized parallelism.

TensorCircuit is built on top of modern machine learning frameworks, and is machine learning backend agnostic. It is specifically suitable for highly efficient simulations of quantum-classical hybrid paradigm and variational quantum algorithms.

Getting Started

Please begin with Quick Start and Jupyter Tutorials.

For more information and introductions, please refer to helpful example scripts and documentations. API docstrings and test cases in tests are also informative.

The following are some minimal demos.

Circuit manipulation:

import tensorcircuit as tc
c = tc.Circuit(2)
c.H(0)
c.CNOT(0,1)
c.rx(1, theta=0.2)
print(c.wavefunction())
print(c.expectation((tc.gates.z(), [1])))
print(c.perfect_sampling())

Runtime behavior customization:

tc.set_backend("tensorflow")
tc.set_dtype("complex128")
tc.set_contractor("greedy")

Automatic differentiations with jit:

def forward(theta):
    c = tc.Circuit(n=2)
    c.R(0, theta=theta, alpha=0.5, phi=0.8)
    return tc.backend.real(c.expectation((tc.gates.z(), [0])))

g = tc.backend.grad(forward)
g = tc.backend.jit(g)
theta = tc.gates.num_to_tensor(1.0)
print(g(theta))

Contributing

For contribution guidelines and notes, see CONTRIBUTING.

Install

For users, pip install tensorcircuit is enough. (Extra package installation may be required for some features.)

For developers, we suggest to first configure a good conda environment. The versions of dependence packages may vary in terms of development requirements. The minimum requirement is the TensorNetwork package. Dockerfiles may also be helpful for building a good development enviroment.

Researches and applications

DQAS

For application of Differentiable Quantum Architecture Search, see applications. Reference paper: https://arxiv.org/pdf/2010.08561.pdf.

VQNHE

For application of Variational Quantum-Neural Hybrid Eigensolver, see applications. Reference paper: https://arxiv.org/pdf/2106.05105.pdf and https://arxiv.org/pdf/2112.10380.pdf.

VQEX - MBL

For application of VQEX on MBL phase identification, see tutorial. Reference paper: https://arxiv.org/pdf/2111.13719.pdf.

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

tensorcircuit-0.0.220318.tar.gz (180.1 kB view details)

Uploaded Source

Built Distribution

tensorcircuit-0.0.220318-py3-none-any.whl (177.0 kB view details)

Uploaded Python 3

File details

Details for the file tensorcircuit-0.0.220318.tar.gz.

File metadata

  • Download URL: tensorcircuit-0.0.220318.tar.gz
  • Upload date:
  • Size: 180.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.26.0 requests-toolbelt/0.9.1 urllib3/1.26.7 tqdm/4.62.3 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.0

File hashes

Hashes for tensorcircuit-0.0.220318.tar.gz
Algorithm Hash digest
SHA256 fb5abd514e284eae74b42aac333a3980c44847ebf9bab1719957626a58fc9597
MD5 102d145fdf02ab24912d1dbe01511acd
BLAKE2b-256 1dd4326cdea5091af0c31ca20ebfbdc4c6fd6ce6488b10335ca182501fea2544

See more details on using hashes here.

File details

Details for the file tensorcircuit-0.0.220318-py3-none-any.whl.

File metadata

  • Download URL: tensorcircuit-0.0.220318-py3-none-any.whl
  • Upload date:
  • Size: 177.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.26.0 requests-toolbelt/0.9.1 urllib3/1.26.7 tqdm/4.62.3 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.0

File hashes

Hashes for tensorcircuit-0.0.220318-py3-none-any.whl
Algorithm Hash digest
SHA256 4030e7218e0d5a1adfe231c22dacc1c1b4de2e496aca9fbd354bb521534108c3
MD5 442e0145d091eca3dc046ce245b25230
BLAKE2b-256 d5f0c3fda35ed5b0a0f8de139aec3eb6ebb3c13321fca0fad7de633a1d615775

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