Skip to main content

Quantum circuits on top of tensor network

Project description

English | 简体中文

TensorCircuit is the next generation of quantum circuit simulators 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 full documentation. 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))

Install

pip install tensorcircuit.

Extra package installation may be required for some features.

Contributing

For contribution guidelines and notes, see CONTRIBUTING.

For developers, we suggest first configuring a good conda environment. The versions of dependence packages may vary in terms of development requirements. The minimum requirement is the TensorNetwork package. Dockerfile is also provided.

Researches and applications

DQAS

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

VQNHE

For the 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 the application of VQEX on MBL phase identification, see the 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.220413.tar.gz (216.3 kB view details)

Uploaded Source

Built Distribution

tensorcircuit-0.0.220413-py3-none-any.whl (186.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for tensorcircuit-0.0.220413.tar.gz
Algorithm Hash digest
SHA256 a8e585baae9e78d5f94b59b61414341a6a45a8a1b98b1a9249b5dbdc02842e56
MD5 028d44006c508715d7aec1f4305c0e44
BLAKE2b-256 7a561edf2505ce7c51757654955e7f6578d189a6d28f69f00478d0b06bb039ce

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for tensorcircuit-0.0.220413-py3-none-any.whl
Algorithm Hash digest
SHA256 3f934c71aac50d0e9678ccfd28da077bde8ed0b0b650b92ad2c40b43382f532d
MD5 4381842c2c8fc1a64796f5ad93b016ce
BLAKE2b-256 24bad8299452acf1409951779c304aa971edba9c31edc45155f3c280dfae5890

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