- Note
- QuEST
v4
has been released which re-designed QuEST from the ground up. Read about the exciting new features here.
The Quantum Exact Simulation Toolkit (QuEST) is a high-performance simulator of quantum statevectors and density matrices. It hybridises multithreading, GPU acceleration and distribution to run lightning fast on laptops, desktops and supercomputers, parallelising over multiple cores, CPUs and GPUs. Behind the scenes, QuEST leverages OpenMP, MPI, CUDA, HIP, Thrust, cuQuantum and GPUDirect for cutting-edge performance on modern multi-GPU clusters, and compatibility with older NVIDIA and AMD GPUs. These deployments can be combined in any combination, or automatically decided at runtime, yet are abstracted behind a single, seamless interface, accessible by both C
and C++
and all the major compilers (detailed here).
QuEST development is led by the QTechTheory group at the University of Oxford, with active contributions from the EPCC team at the University of Edinburgh, and support from the below organisations. In particular, QuEST v4
was made possible through the support of the UK National Quantum Computing centre (NQCC200921) and the UKRI SEEQA project.
To learn more:
🎉 Introduction
QuEST has a simple interface which is agnostic to whether it's running on CPUs, GPUs or a networked supercomputer.
qreal calcExpecPauliStr(Qureg qureg, PauliStr str)
qreal calcProbOfQubitOutcome(Qureg qureg, int qubit, int outcome)
void initRandomPureState(Qureg qureg)
void applyHadamard(Qureg qureg, int target)
void applyFullQuantumFourierTransform(Qureg qureg)
void applyControlledRotateX(Qureg qureg, int control, int target, qreal angle)
PauliStr getPauliStr(const char *paulis, int *indices, int numPaulis)
Qureg createQureg(int numQubits)
void reportQureg(Qureg qureg)
Yet, it is flexible
void mixDepolarising(Qureg qureg, int qubit, qreal prob)
void mixKrausMap(Qureg qureg, int *targets, int numTargets, KrausMap map)
CompMatr1 getInlineCompMatr1({{ matrix }})
void multiplyCompMatr1(Qureg qureg, int target, CompMatr1 matrix)
void multiplyDiagMatrPower(Qureg qureg, int *targets, int numTargets, DiagMatr matrix, qcomp exponent)
int applyQubitMeasurement(Qureg qureg, int target)
void applyControlledPauliGadget(Qureg qureg, int control, PauliStr str, qreal angle)
void applyMultiQubitProjector(Qureg qureg, int *qubits, int *outcomes, int numQubits)
void applyMultiStateControlledSwap(Qureg qureg, int *controls, int *states, int numControls, int qubit1, int qubit2)
and extremely powerful
0.123 XXIXX
1.23i XYZXZ
-1-6i IIZII
)");
qreal calcExpecFullStateDiagMatr(Qureg qureg, FullStateDiagMatr matr)
qreal calcExpecPauliStrSum(Qureg qureg, PauliStrSum sum)
Qureg calcPartialTrace(Qureg qureg, int *traceOutQubits, int numTraceQubits)
CompMatr createCompMatr(int numQubits)
void setFullStateDiagMatrFromMultiVarFunc(FullStateDiagMatr out, qcomp(*func)(qindex *), int *numQubitsPerVar, int numVars, int areSigned)
void setCompMatr(CompMatr matr, qcomp **vals)
void applyCompMatr(Qureg qureg, int *targets, int numTargets, CompMatr matr)
void applyFullStateDiagMatrPower(Qureg qureg, FullStateDiagMatr matrix, qcomp exponent)
void applyTrotterizedPauliStrSumGadget(Qureg qureg, PauliStrSum sum, qreal angle, int order, int reps)
PauliStrSum createInlinePauliStrSum(const char *str)
✅ Features
QuEST supports:
- ☑️ density matrices for precise simulation of noisy quantum computers
- ☑️ general unitaries with any number of control, control-states, and target qubits
- ☑️ general decoherence channels of any dimension
- ☑️ general observables in the Pauli or diagonal-Z bases
- ☑️ many many operators, including Pauli gadgets, trotterised time evolutions, and projectors
- ☑️ many tools to analyse quantum states, such as calculations of probability, fidelity, expectation value, distances and partial traces
- ☑️ variable precision through
qreal
and qcomp
numerical types which can use single, double or quad precision
- ☑️ direct access to amplitudes for rapid custom modification of the quantum state
- ☑️ native compilation on MacOS, Linux and Windows, through Clang, GNU, Intel, and MSVC compilers
- ☑️ hybridisation of multithreading, GPU-acceleration, distribution and GPU-distribution
- ☑️ optimisation using NVLink'd GPUs, cuQuantum, and CUDA-aware MPI
- ☑️ automatic deployment of a
Qureg
to the optimal hardware at runtime
- ☑️ hardware probing to determine how many qubits can be simulated at runtime
- ☑️ bespoke algorithms to optimally simulate a wide variety of esoteric operations
📖 Documentation
- Important
- QuEST v4's documentation is still under construction!
Visit the docs for guides and tutorials, or the API which is divided into:
🚀 Getting started
To rocket right in, download QuEST with git at the terminal
git clone https://github.com/quest-kit/QuEST.git
cd QuEST
We recommend working in a build
directory:
Compile the minimum example using cmake:
then run it with
See the docs for enabling acceleration and running the unit tests.
❤ Acknowledgements
In addition to QuEST's authors, we sincerely thank the following external contributors to QuEST.
📰 Related projects