All Projects → PennyLaneAI → pennylane-lightning

PennyLaneAI / pennylane-lightning

Licence: Apache-2.0 license
The PennyLane-Lightning plugin provides a fast state-vector simulator written in C++ for use with PennyLane

Programming Languages

C++
36643 projects - #6 most used programming language
python
139335 projects - #7 most used programming language
CMake
9771 projects

Projects that are alternatives of or similar to pennylane-lightning

cruise
User space POSIX-like file system in main memory
Stars: ✭ 27 (-3.57%)
Mutual labels:  hpc, parallel
Core
parallel finite element unstructured meshes
Stars: ✭ 124 (+342.86%)
Mutual labels:  hpc, parallel
future.batchtools
🚀 R package future.batchtools: A Future API for Parallel and Distributed Processing using batchtools
Stars: ✭ 77 (+175%)
Mutual labels:  hpc, parallel
Easylambda
distributed dataflows with functional list operations for data processing with C++14
Stars: ✭ 475 (+1596.43%)
Mutual labels:  hpc, parallel
hp2p
Heavy Peer To Peer: a MPI based benchmark for network diagnostic
Stars: ✭ 17 (-39.29%)
Mutual labels:  hpc, parallel
parallel
PARALLEL: Stata module for parallel computing
Stars: ✭ 97 (+246.43%)
Mutual labels:  hpc, parallel
Raftlib
The RaftLib C++ library, streaming/dataflow concurrency via C++ iostream-like operators
Stars: ✭ 717 (+2460.71%)
Mutual labels:  hpc, parallel
ParallelUtilities.jl
Fast and easy parallel mapreduce on HPC clusters
Stars: ✭ 28 (+0%)
Mutual labels:  hpc, parallel
Singularity
Singularity: Application containers for Linux
Stars: ✭ 2,290 (+8078.57%)
Mutual labels:  hpc, parallel
Hpcinfo
Information about many aspects of high-performance computing. Wiki content moved to ~/docs.
Stars: ✭ 171 (+510.71%)
Mutual labels:  hpc, parallel
Future.apply
🚀 R package: future.apply - Apply Function to Elements in Parallel using Futures
Stars: ✭ 159 (+467.86%)
Mutual labels:  hpc, parallel
t8code
Parallel algorithms and data structures for tree-based AMR with arbitrary element shapes.
Stars: ✭ 37 (+32.14%)
Mutual labels:  hpc, parallel
ParMmg
Distributed parallelization of 3D volume mesh adaptation
Stars: ✭ 19 (-32.14%)
Mutual labels:  hpc, parallel
rTRNG
R package providing access and examples to TRNG C++ library
Stars: ✭ 17 (-39.29%)
Mutual labels:  hpc, parallel
pwm
Parallel Wavelet Tree and Wavelet Matrix Construction
Stars: ✭ 17 (-39.29%)
Mutual labels:  parallel
pytokio
[READ ONLY] Refer to gitlab repo for updated version - Total Knowledge of I/O Reference Implementation. Please see wiki for contribution guidelines.
Stars: ✭ 20 (-28.57%)
Mutual labels:  hpc
machine-learning-data-pipeline
Pipeline module for parallel real-time data processing for machine learning models development and production purposes.
Stars: ✭ 22 (-21.43%)
Mutual labels:  parallel
sst-core
SST Structural Simulation Toolkit Parallel Discrete Event Core and Services
Stars: ✭ 82 (+192.86%)
Mutual labels:  parallel
Kinetic.jl
Universal modeling and simulation of fluid dynamics upon machine learning
Stars: ✭ 82 (+192.86%)
Mutual labels:  hpc
pulsemaker
A Python widget library for designing pulses and pulse schedules for quantum computing hardware. Can be used in Jupyter notebooks, JupyterLab, and the IPython kernel.
Stars: ✭ 19 (-32.14%)
Mutual labels:  quantum-computing

PennyLane-Lightning Plugin

GitHub Workflow Status (branch) Codecov coverage CodeFactor Grade Read the Docs PyPI PyPI - Python Version

The PennyLane-Lightning plugin provides a fast state-vector simulator written in C++.

PennyLane is a cross-platform Python library for quantum machine learning, automatic differentiation, and optimization of hybrid quantum-classical computations.

Features

  • Combine PennyLane-Lightning's high performance simulator with PennyLane's automatic differentiation and optimization.

Installation

PennyLane-Lightning requires Python version 3.7 and above. It can be installed using pip:

$ pip install pennylane-lightning

To build PennyLane-Lightning from source you can run

$ pip install pybind11 pennylane-lightning --no-binary :all:

A C++ compiler such as g++, clang, or MSVC is required. On Debian-based systems, this can be installed via apt:

$ sudo apt install g++

The pybind11 library is also used for binding the C++ functionality to Python.

Alternatively, for development and testing, you can install by cloning the repository:

$ git clone https://github.com/PennyLaneAI/pennylane-lightning.git
$ cd pennylane-lightning
$ pip install -r requirements.txt
$ pip install -e .

Note that subsequent calls to pip install -e . will use cached binaries stored in the build folder. Run make clean if you would like to recompile.

You can also pass cmake options with build_ext:

$ python3 setup.py build_ext -i --define="ENABLE_OPENMP=OFF;ENABLE_NATIVE=ON"

and install the compilied library with

$ python3 setup.py develop

GPU support

For GPU support, PennyLane-Lightning-GPU can be installed by providing the optional [gpu] tag:

$ pip install pennylane-lightning[gpu]

For more information, please refer to the PennyLane Lightning GPU documentation.

Testing

To test that the plugin is working correctly you can test the Python code within the cloned repository:

$ make test-python

while the C++ code can be tested with

$ make test-cpp

CMake Support

One can also build the plugin using CMake:

$ cmake -S. -B build
$ cmake --build build

To test the C++ code:

$ mkdir build && cd build
$ cmake -DBUILD_TESTS=ON -DCMAKE_BUILD_TYPE=Debug ..
$ make

Other supported options are -DENABLE_WARNINGS=ON, -DENABLE_NATIVE=ON (for -march=native), -DENABLE_BLAS=ON, -DENABLE_OPENMP=ON, -DENABLE_KOKKOS=ON, and -DENABLE_CLANG_TIDY=ON.

Compile on Windows with MSVC

You can also compile Pennylane-Lightning on Windows using Microsoft Visual C++ compiler. You need cmake and appropriate Python environment (e.g. using Anaconda).

We recommend to use [x64 (or x86)] Native Tools Command Prompt for VS [version] for compiling the library. Be sure that cmake and python can be called within the prompt.

$ cmake --version
$ python --version

Then a common command will work.

$ pip install -r requirements.txt
$ pip install -e .

Note that OpenMP and BLAS are disabled in this setting.

Please refer to the plugin documentation as well as to the PennyLane documentation for further reference.

Docker Support

One can also build the Pennylane-Lightning image using Docker:

$ git clone https://github.com/PennyLaneAI/pennylane-lightning.git
$ cd pennylane-lightning
$ docker build -t lightning/base -f docker/Dockerfile .

Please refer to the PennyLane installation for detailed description about PennyLane Docker support.

Contributing

We welcome contributions - simply fork the repository of this plugin, and then make a pull request containing your contribution. All contributers to this plugin will be listed as authors on the releases.

We also encourage bug reports, suggestions for new features and enhancements, and even links to cool projects or applications built on PennyLane.

Authors

PennyLane-Lightning is the work of many contributors.

If you are doing research using PennyLane and PennyLane-Lightning, please cite our paper:

Ville Bergholm, Josh Izaac, Maria Schuld, Christian Gogolin, M. Sohaib Alam, Shahnawaz Ahmed, Juan Miguel Arrazola, Carsten Blank, Alain Delgado, Soran Jahangiri, Keri McKiernan, Johannes Jakob Meyer, Zeyue Niu, Antal Száva, and Nathan Killoran. PennyLane: Automatic differentiation of hybrid quantum-classical computations. 2018. arXiv:1811.04968

Support

If you are having issues, please let us know by posting the issue on our Github issue tracker, or by asking a question in the forum.

License

The PennyLane lightning plugin is free and open source, released under the Apache License, Version 2.0.

Acknowledgements

PennyLane Lightning makes use of the following libraries and tools, which are under their own respective licenses:

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].