To learn more about how to use CUDA Quantum, please take a look at the CUDA Quantum Documentation. The page also contains installation instructions for released packages.
This document contains instructions for how to build CUDA Quantum from source. This is only needed if you would like to try out the latest (unreleased) version that is currently under development in this repository and/or if you would like to add your own modifications to this code base.
To build the CUDA Quantum source code locally, fork this repository and follow
the instructions for setting up your environment. Once you
have done that, you should be able to run the build
script to build and install CUDA Quantum in a local
folder. The path where CUDA Quantum will be installed can be configured by
setting the environment variable CUDAQ_INSTALL_PREFIX
. If you customize this
path or do not work in our dev container, you either need to invoke the
built/installed binaries with the full path or modify your path variables as
follows:
export PATH="${CUDAQ_INSTALL_PREFIX}/bin:${PATH}"
export PYTHONPATH="${CUDAQ_INSTALL_PREFIX}:${PYTHONPATH}"
Our dev container comes with a prebuilt version of LLVM which is used to build CUDA Quantum. If you are working outside our container, please see the instructions for building CUDA Quantum with a custom LLVM version.
Once you have built CUDA Quantum, you should be able to run the tests and
confirm that they pass by navigating to the build
folder and entering the
command ctest
. If all tests pass, you are all set to start
developing.
CUDA Quantum comes with a range of simulator backends for testing and debugging application code. In addition to simulators that run on CPUs, there are also multiple backends leveraging cuQuantum for GPU accelerated simulation. This repository does not require you to have a GPU; if no GPU is detected, the corresponding backends will simply be omitted from the build.
To use or develop GPU-based simulators, you will need to make sure you have a
suitable NVIDIA GPU with the latest driver installed. You can
confirm the GPU is properly detected running the command nvidia-smi
.
If you are working in our dev container, please add a --gpus=all
flag to the
list of runArgs
in the
.devcontainer/devcontainer.json file and
relaunch the container. It is unfortunately not possible to define a dev
container that enables GPU support depending on the system configuration (see
this issue).
If you are not working in our dev container, you may need to specify the correct
path to your cuQuantum installation by setting the environment variable
CUQUANTUM_INSTALL_PREFIX
.
CUDA Quantum is intended to be built using the LLVM commit that the submodule is
set to. If you need to update the LLVM commit, or if you are not using the
prebuilt version of that commit in our dev container, LLVM will need to be built
from source. To configure our build scripts, please set the LLVM submodule to
the desired commit, and set the following environment variable, replacing
<installation_path>
with the path where the freshly built LLVM tools and
libraries should be installed:
export LLVM_INSTALL_PREFIX=<installation_path>
The CUDA Quantum build script checks if
llvm-config
is available in the bin subfolder of that directory, and will
automatically invoke the LLVM build script if it is
not.
Please note that building LLVM may take a while and you should have about 64GB of memory available for the build. Please configure your Docker container settings accordingly. If you are working on Windows, the amount of resources that are available within a container is determined by the WSL settings. Please create or modify the WSL configuration file if necessary.