Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/previsionio/damavand
Damavand is a quantum circuit simulator. It can run on laptops or High Performance Computing architectures, such CPU distributed architectures or multi GPU distributed architectures.
https://github.com/previsionio/damavand
cuda distributed-computing hpc multi-gpu multithreading quantum-computing rust simulator
Last synced: about 2 months ago
JSON representation
Damavand is a quantum circuit simulator. It can run on laptops or High Performance Computing architectures, such CPU distributed architectures or multi GPU distributed architectures.
- Host: GitHub
- URL: https://github.com/previsionio/damavand
- Owner: previsionio
- License: mit
- Created: 2021-12-22T12:22:03.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-01-11T14:59:00.000Z (about 3 years ago)
- Last Synced: 2024-07-30T20:09:21.898Z (6 months ago)
- Topics: cuda, distributed-computing, hpc, multi-gpu, multithreading, quantum-computing, rust, simulator
- Language: Rust
- Homepage:
- Size: 12.9 MB
- Stars: 8
- Watchers: 1
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
![damavand-main](figures/damavand_main.png)
Damavand is a code that simulates quantum circuits.
In order to learn more about damavand, refer to the [documentation](https://previsionio.github.io/damavand/).## Development status
1. Core features:
* single node CPU multithreading ✔️
* single node GPU ✔️
* multiple nodes CPU multithreading ✔️
* single node multiple GPUs ✔️
* multiple nodes multiple GPUs ✔️
2. pypi ✔️
3. README.md ✔️
3. Documentation 🛠️ (under construction)## Installation
### From pypi
```bash
pip3 install damavand
```### From sources
```bash
git clone https://github.com/previsionio/damavand.git
cd damavand/
python3 setup.py install
```## Example
Damavand can be executed with different "apply methods". These refer to the algorithms used to update a quantum state by
applying a given quantum gate. The different apply methods are:1. `brute_force` brute matrix vector multiplication (requires a lot of memory).
2. `shuffle` smart implementation of matrix vector multiplication where the matrix is the result of a series of
kronecker products (requires less memory but is still a bit slow).
3. `multithreading` runs on a single node multi CPUs.
4. `gpu` runs on a single node single GPU.
5. `distributed_cpu` runs on a multiple nodes multiple CPUs.
6. `distributed_gpu` runs on a single node multiple GPUs or on multiple nodes multiple GPUs.The default `apply_method` is `multithreading`. this can be changes by providing it as an option to the Circuit
builder, as shown in the following example:```python
from damavand import Circuit# initialize MPI
from mpi4py import MPInum_qubits = 1
circuit = Circuit(num_qubits, apply_method="distributed_gpu")circuit.add_hadamard_gate(0)
circuit.forward()
circuit.measure()num_samples=10
samples = circuit.sample(num_samples)observables = circuit.extract_expectation_values(samples)
```## Slurm workload run:
Here is a simple slurm example that shows how to run a simulation on 2 nodes, with multithreading.
```bash
#!/bin/bash#SBATCH --job-name=two_nodes
#SBATCH --qos=qos_cpu-dev
#SBATCH --ntasks=2
#SBATCH --ntasks-per-node=1
#SBATCH --cpus-per-task=40
#SBATCH --output=two_nodes.listing
#SBATCH --time=5:00module purge
module load openmpi/3.1.4
module load cuda/10.2srun python3 two_nodes.py
```
Run `sbatch run.sh` to lounch the script## Pennylane Integration
Damavand is linked to pennylane [PennyLane](https://pennylane.ai/), a library with many tools to approach qubit based
and continuous-variable based quantum architectures.The plugin that allows this can be found [here](https://github.com/previsionio/pennylane-damavand).
With this plugin, one can use pennylane with the `damavand.qubit` backend.
```python
dev = qml.device("damavand.qubit", wires=10, apply_method="gpu")
```## Sun rising on mount damavand
![damavand-sunrise](figures/damavand_2016_sunrise.png)