#include "QuEST.h"#include "utilities.hpp"#include "catch.hpp"#include <random>#include <algorithm>#include <bitset>Go to the source code of this file.
| Data Structures | |
| class | SequenceGenerator< T > | 
| class | SubListGenerator | 
| Macros | |
| #define | DEMAND(cond) if (!(cond)) FAIL( ); | 
| #define | macro_copyComplexMatrix(dest, src) | 
| Copies ComplexMatrix structures into a QMatrix.  More... | |
| #define | macro_copyQMatrix(dest, src) | 
| Functions | |
| void | applyReferenceMatrix (QMatrix &state, int *ctrls, int numCtrls, int *targs, int numTargs, QMatrix op) | 
| Modifies the density matrix stateto be the result of left-multiplying the multi-target operator matrixop, with the specified control and target qubits (inctrlsandtargsrespectively).  More... | |
| void | applyReferenceMatrix (QVector &state, int *ctrls, int numCtrls, int *targs, int numTargs, QMatrix op) | 
| Modifies the state-vector stateto be the result of left-multiplying the multi-target operator matrixop, with the specified control and target qubits (inctrlsandtargsrespectively).  More... | |
| void | applyReferenceOp (QMatrix &state, int *ctrls, int numCtrls, int *targs, int numTargs, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the multi-target operator matrixop, with the specified control and target qubits (inctrlsandtargsrespectively).  More... | |
| void | applyReferenceOp (QMatrix &state, int *ctrls, int numCtrls, int targ1, int targ2, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the two-target operator matrixop, with the specified control qubits (inctrls).  More... | |
| void | applyReferenceOp (QMatrix &state, int *ctrls, int numCtrls, int target, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the single-target operator matrixop, with the specified control qubits (inctrls).  More... | |
| void | applyReferenceOp (QMatrix &state, int *targs, int numTargs, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the multi-target operator matrixop, with no control qubits.  More... | |
| void | applyReferenceOp (QMatrix &state, int ctrl, int *targs, int numTargs, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the multi-target operator matrixop, with a single control qubitctrl.  More... | |
| void | applyReferenceOp (QMatrix &state, int ctrl, int targ, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the single-control single-target operator matrixop.  More... | |
| void | applyReferenceOp (QMatrix &state, int ctrl, int targ1, int targ2, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the two-target operator matrixop, with a single control qubitctrl.  More... | |
| void | applyReferenceOp (QMatrix &state, int targ, QMatrix op) | 
| Modifies the density matrix stateto be the result of applying the single-target operator matrixop, with no control qubit.  More... | |
| void | applyReferenceOp (QVector &state, int *ctrls, int numCtrls, int *targs, int numTargs, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the multi-target operator matrixop, with the specified control and target qubits (inctrlsandtargsrespectively).  More... | |
| void | applyReferenceOp (QVector &state, int *ctrls, int numCtrls, int targ1, int targ2, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the two-target operator matrixop, with the specified control qubits (inctrls).  More... | |
| void | applyReferenceOp (QVector &state, int *ctrls, int numCtrls, int target, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the single-target operator matrixop, with the specified control qubits (inctrls).  More... | |
| void | applyReferenceOp (QVector &state, int *targs, int numTargs, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the multi-target operator matrixop, with no contorl qubits.  More... | |
| void | applyReferenceOp (QVector &state, int ctrl, int *targs, int numTargs, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the multi-target operator matrixop, with a single control qubit (ctrl) This updatesstateunder.  More... | |
| void | applyReferenceOp (QVector &state, int ctrl, int targ, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the single-target operator matrixop, with a single control qubit (ctrl).  More... | |
| void | applyReferenceOp (QVector &state, int ctrl, int targ1, int targ2, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the two-target operator matrixop, with a single control qubit (ctrl).  More... | |
| void | applyReferenceOp (QVector &state, int targ, QMatrix op) | 
| Modifies the state-vector stateto be the result of applying the single-target operator matrixop, with no contorl qubits.  More... | |
| bool | areEqual (QMatrix a, QMatrix b) | 
| Returns true if the absolute value of the difference between every amplitude in matrices aandbis less thanREAL_EPS.  More... | |
| bool | areEqual (Qureg qureg, QMatrix matr) | 
| Performs a hardware-agnostic comparison of density-matrix quregtomatr, checking whether the difference between the real and imaginary components of every amplitude is smaller than the QuEST_PREC-specific REAL_EPS (defined in QuEST_precision) precision.  More... | |
| bool | areEqual (Qureg qureg, QMatrix matr, qreal precision) | 
| Performs a hardware-agnostic comparison of density-matrix quregtomatr, checking whether the difference between the real and imaginary components of every amplitude is smaller thanprecision.  More... | |
| bool | areEqual (Qureg qureg, QVector vec) | 
| Performs a hardware-agnostic comparison of state-vector quregtovec, checking whether the difference between the real and imaginary components of every amplitude is smaller than the QuEST_PREC-specific REAL_EPS (defined in QuEST_precision) precision.  More... | |
| bool | areEqual (Qureg qureg, QVector vec, qreal precision) | 
| Performs a hardware-agnostic comparison of state-vector quregtovec, checking whether the difference between the real and imaginary components of every amplitude is smaller thanprecision.  More... | |
| bool | areEqual (Qureg qureg1, Qureg qureg2) | 
| Performs a hardware-agnostic comparison of the given quregs, checking whether the difference between the real and imaginary components of every amplitude is smaller than the QuEST_PREC-specific REAL_EPS (defined in QuEST_precision) precision.  More... | |
| bool | areEqual (Qureg qureg1, Qureg qureg2, qreal precision) | 
| Performs a hardware-agnostic comparison of the given quregs, checking whether the difference between the real and imaginary components of every amplitude is smaller than precision.  More... | |
| bool | areEqual (QVector a, QVector b) | 
| Returns true if the absolute value of the difference between every amplitude in vectors aandbis less thanREAL_EPS.  More... | |
| bool | areEqual (QVector vec, qreal *reals) | 
| Returns true if the absolute value of the difference between every element in vec(which must be strictly real) and those implied byreals, is less thanREAL_EPS.  More... | |
| bool | areEqual (QVector vec, qreal *reals, qreal *imags) | 
| Returns true if the absolute value of the difference between every element in vecand those implied byrealsandimags, is less thanREAL_EPS.  More... | |
| Catch::Generators::GeneratorWrapper< int * > | bitsets (int numBits) | 
| Returns a Catch2 generator of every numBits-lengthbit-set, in increasing lexographic order, where left-most (zero index) bit is treated as LEAST significant (opposite typical convention).  More... | |
| unsigned int | calcLog2 (long unsigned int res) | 
| Returns log2 of numbers which must be gauranteed to be 2^n.  More... | |
| void | deleteFilesWithPrefixSynch (char *prefix) | 
| Deletes all files with filename starting with prefix.  More... | |
| qcomp | expI (qreal phase) | 
| Returns the unit-norm complex number exp(i* phase).  More... | |
| QMatrix | getConjugateTranspose (QMatrix a) | 
| Returns the conjugate transpose of the complex square matrix a.  More... | |
| QVector | getDFT (QVector in) | 
| Returns the discrete fourier transform of vector in.  More... | |
| QVector | getDFT (QVector in, int *targs, int numTargs) | 
| Returns the discrete fourier transform of a sub-partition of the vector in.  More... | |
| QMatrix | getExponentialOfDiagonalMatrix (QMatrix a) | 
| Returns the matrix exponential of a diagonal, square, complex matrix.  More... | |
| QMatrix | getExponentialOfPauliMatrix (qreal angle, QMatrix a) | 
| Returns the matrix exponential of a kronecker product of pauli matrices (or of any involutory matrices), with exponent factor (-i angle/ 2).  More... | |
| QMatrix | getFullOperatorMatrix (int *ctrls, int numCtrls, int *targs, int numTargs, QMatrix op, int numQubits) | 
| Takes a 2^ numTargs-by-2^opand a returns a 2^numQubits-by-2^whereopis controlled on the givenctrlsqubits.  More... | |
| QMatrix | getIdentityMatrix (size_t dim) | 
| Returns a dim-by-dim identity matrix.  More... | |
| long long int | getIndexOfTargetValues (long long int ref, int *targs, int numTargs, int targVal) | 
| QMatrix | getKetBra (QVector ket, QVector bra) | 
| Returns the matrix | ket><with ith-jth elementket(i)conj(bra(j)), since |ket><sum_i a_i|i> sum_j b_j* <j| = sum_{ij} a_i b_j* |i><j|.  More... | |
| QMatrix | getKroneckerProduct (QMatrix a, QMatrix b) | 
| Returns the kronecker product of aandb, whereaandbare square but possibly differently-sized complex matrices.  More... | |
| QVector | getKroneckerProduct (QVector b, QVector a) | 
| Returns b (otimes) a.  More... | |
| QVector | getMatrixDiagonal (QMatrix matr) | 
| Returns the diagonal vector of the given matrix.  More... | |
| QMatrix | getMixedDensityMatrix (std::vector< qreal > probs, std::vector< QVector > states) | 
| Returns a mixed density matrix formed from mixing the given pure states, which are assumed normalised, but not necessarily orthogonal.  More... | |
| QVector | getNormalised (QVector vec) | 
| Returns an L2-normalised copy of vec, using Kahan summation for improved accuracy.  More... | |
| QMatrix | getPureDensityMatrix (QVector state) | 
| Returns a density matrix initialised into the given pure state.  More... | |
| qcomp | getRandomComplex () | 
| Returns a random complex number within the square closing (-1-i) and (1+i), from a distribution uniformly randomising the individual real and imaginary components in their domains.  More... | |
| QMatrix | getRandomDensityMatrix (int numQb) | 
| Returns a random numQb-by-matrix, from an undisclosed distribution, in a very mixed state.  More... | |
| int | getRandomInt (int min, int max) | 
| Returns a random integer between min(inclusive) andmax(exclusive), from the uniform distribution.  More... | |
| std::vector< QMatrix > | getRandomKrausMap (int numQb, int numOps) | 
| Returns a random Kraus map of # numOps2^numQb-by-2^, from an undisclosed distribution.  More... | |
| std::vector< QVector > | getRandomOrthonormalVectors (int numQb, int numStates) | 
| Returns a list of random orthonormal complex vectors, from an undisclosed distribution.  More... | |
| std::vector< qreal > | getRandomProbabilities (int numProbs) | 
| Returns a list of random real scalars, each in [0, 1], which sum to unity.  More... | |
| QMatrix | getRandomPureDensityMatrix (int numQb) | 
| Returns a random numQb-by-matrix, from an undisclosed distribution, which is pure (corresponds to a random state-vector)  More... | |
| QMatrix | getRandomQMatrix (int dim) | 
| Returns a dim-by-matrix, where the real and imaginary value of each element are independently random, under the standard normal distribution (mean 0, standard deviation 1).  More... | |
| QVector | getRandomQVector (int dim) | 
| Returns a dim-lengthvector with random complex amplitudes in the square joining {-1-i, 1+i}, of an undisclosed distribution.  More... | |
| qreal | getRandomReal (qreal min, qreal max) | 
| Returns a random real between min(inclusive) andmax(exclusive), from the uniform distribution.  More... | |
| QVector | getRandomStateVector (int numQb) | 
| Returns a random numQb-lengthL2-normalised state-vector from an undisclosed distribution.  More... | |
| QMatrix | getRandomUnitary (int numQb) | 
| Returns a uniformly random (under Haar) 2^ numQb-by-2^matrix.  More... | |
| QMatrix | getSwapMatrix (int qb1, int qb2, int numQb) | 
| Returns the 2^ numQb-by-2^matrix which swaps qubitsqb1andqb2; the SWAP gate of not-necessarily-adjacent qubits.  More... | |
| long long int | getTwosComplement (long long int decimal, int numBits) | 
| Returns the two's complement signed encoding of the unsigned number decimal, which must be a number between 0 and 2^numBits (exclusive).  More... | |
| long long int | getUnsigned (long long int twosComp, int numBits) | 
| Return the unsigned value of a number, made of #numBitsbits, which under two's complement, encodes the signed number twosComp.  More... | |
| long long int | getValueOfTargets (long long int ind, int *targs, int numTargs) | 
| Returns the integer value of the targeted sub-register for the given full state index ind.  More... | |
| QMatrix | getZeroMatrix (size_t dim) | 
| Returns a dim-by-dim square complex matrix, initialised to all zeroes.  More... | |
| QMatrix | operator* (const qcomp &a, const QMatrix &m) | 
| QVector | operator* (const qcomp &a, const QVector &v) | 
| QMatrix | operator* (const QMatrix &m, const qcomp &a) | 
| QVector | operator* (const QMatrix &m, const QVector &v) | 
| QMatrix | operator* (const QMatrix &m1, const QMatrix &m2) | 
| QVector | operator* (const QVector &v, const qcomp &a) | 
| qcomp | operator* (const QVector &v1, const QVector &v2) | 
| void | operator*= (QMatrix &m1, const QMatrix &m2) | 
| void | operator*= (QMatrix &m1, const qreal &a) | 
| void | operator*= (QVector &v1, const qcomp &a) | 
| QMatrix | operator+ (const QMatrix &m1, const QMatrix &m2) | 
| QVector | operator+ (const QVector &v1, const QVector &v2) | 
| void | operator+= (QMatrix &m1, const QMatrix &m2) | 
| void | operator+= (QVector &v1, const QVector &v2) | 
| QMatrix | operator- (const QMatrix &m1, const QMatrix &m2) | 
| QVector | operator- (const QVector &v1, const QVector &v2) | 
| void | operator-= (QMatrix &m1, const QMatrix &m2) | 
| void | operator-= (QVector &v1, const QVector &v2) | 
| QMatrix | operator/ (const QMatrix &m, const qcomp &a) | 
| QVector | operator/ (const QVector &v, const qcomp &a) | 
| void | operator/= (QMatrix &m1, const qreal &a) | 
| void | operator/= (QVector &v1, const qcomp &a) | 
| Catch::Generators::GeneratorWrapper< pauliOpType * > | pauliseqs (int numPaulis) | 
| Returns a Catch2 generator of every numPaulis-lengthset of Pauli-matrix types (or base-4 integers).  More... | |
| Catch::Generators::GeneratorWrapper< int * > | sequences (int base, int numDigits) | 
| Returns a Catch2 generator of every numDigits-lengthsequence in the givenbase, in increasing lexographic order, where left-most (zero index) bit is treated as LEAST significant (opposite typical convention).  More... | |
| long long int | setBit (long long int num, int bitInd, int bitVal) | 
| void | setDiagMatrixOverrides (QMatrix &matr, int *numQubitsPerReg, int numRegs, enum bitEncoding encoding, long long int *overrideInds, qreal *overridePhases, int numOverrides) | 
| Modifies the given diagonal matrix such that the diagonal elements which correspond to the coordinates in overrideInds are replaced with exp(i phase), as prescribed by overridePhases.  More... | |
| void | setRandomDiagPauliHamil (PauliHamil hamil) | 
| Populates hamilwith random coefficients and a random amount number of PAULI_I and PAULI_Z operators.  More... | |
| void | setRandomPauliSum (PauliHamil hamil) | 
| Populates hamilwith random coefficients and pauli codes.  More... | |
| void | setRandomPauliSum (qreal *coeffs, pauliOpType *codes, int numQubits, int numTerms) | 
| Populates the coeffsarray with random qreals in (-5, 5), and populatescodeswith random Pauli codes.  More... | |
| void | setSubMatrix (QMatrix &dest, QMatrix sub, size_t r, size_t c) | 
| Modifies destby overwriting its submatrix (from top-left corner (r,c) to bottom-right corner (r+dest.size(),c+dest.size()) with the complete elements of sub.  More... | |
| void | setUniqueFilename (char *outFn, char *prefix) | 
| Modifies outFn to be a filename of format prefix_NUM.txt where NUM is a new unique integer so far.  More... | |
| Catch::Generators::GeneratorWrapper< int * > | sublists (Catch::Generators::GeneratorWrapper< int > &&gen, int numSamps) | 
| Catch::Generators::GeneratorWrapper< int * > | sublists (Catch::Generators::GeneratorWrapper< int > &&gen, int numSamps, const int *exclude, int numExclude) | 
| Catch::Generators::GeneratorWrapper< int * > | sublists (Catch::Generators::GeneratorWrapper< int > &&gen, int numSamps, int excluded) | 
| Catch::Generators::GeneratorWrapper< int * > | sublists (int *list, int len, int sublen) | 
| Returns a Catch2 generator of every length- sublensublist of length-lenlist, in increasing lexographic order.  More... | |
| ComplexMatrix2 | toComplexMatrix2 (QMatrix qm) | 
| Returns a ComplexMatrix2copy of QMatixqm.  More... | |
| ComplexMatrix4 | toComplexMatrix4 (QMatrix qm) | 
| Returns a ComplexMatrix4copy of QMatixqm.  More... | |
| void | toComplexMatrixN (QMatrix qm, ComplexMatrixN cm) | 
| Initialises cmwith the values ofqm.  More... | |
| QMatrix | toDiagonalQMatrix (QVector vec) | 
| Returns a diagonal complex matrix formed by the given vector.  More... | |
| QMatrix | toQMatrix (Complex alpha, Complex beta) | 
| Returns the matrix (where a= alpha, b=beta) {{a, -conj(b)}, {b, conj(a)}} using theqcompcomplex type.  More... | |
| QMatrix | toQMatrix (ComplexMatrix2 src) | 
| Returns a copy of the given 2-by-2 matrix.  More... | |
| QMatrix | toQMatrix (ComplexMatrix4 src) | 
| Returns a copy of the given 4-by-4 matrix.  More... | |
| QMatrix | toQMatrix (ComplexMatrixN src) | 
| Returns a copy of the given 2^ N-by-2^.  More... | |
| QMatrix | toQMatrix (DiagonalOp op) | 
| Returns a 2^ N-by-2^diagonal matrix form of the DiagonalOp.  More... | |
| QMatrix | toQMatrix (PauliHamil hamil) | 
| Returns a 2^ N-by-2^matrix form of the PauliHamil.  More... | |
| QMatrix | toQMatrix (qreal *coeffs, pauliOpType *paulis, int numQubits, int numTerms) | 
| Returns a 2^ N-by-2^matrix form of the specified weighted sum of Pauli products.  More... | |
| QMatrix | toQMatrix (Qureg qureg) | 
| Returns an equal-size copy of the given density matrix qureg.  More... | |
| void | toQureg (Qureg qureg, QMatrix mat) | 
| Initialises the density matrix quregto have the same amplitudes asmat.  More... | |
| void | toQureg (Qureg qureg, QVector vec) | 
| Initialises the state-vector quregto have the same amplitudes asvec.  More... | |
| QVector | toQVector (DiagonalOp op) | 
| Returns a vector with the same of the full diagonal operator, populated with op'selements.  More... | |
| QVector | toQVector (Qureg qureg) | 
| Returns an equal-size copy of the given state-vector qureg.  More... | |
| void | updateIndices (int oldEl, int newEl, int *list1, int len1, int *list2, int len2) | 
| void | writeToFileSynch (char *fn, const string &contents) | 
| Writes contents to the file with filename fn, which is created and/or overwritten.  More... | |
| Variables | |
| static int | fn_unique_suffix_id = 0 | 
Detailed Description
Unoptimised, analytic implementations of matrix operations used by QuEST_unit_tests
Definition in file utilities.cpp.
Macro Definition Documentation
◆ DEMAND
| #define DEMAND | ( | cond | ) | if (!(cond)) FAIL( ); | 
Definition at line 24 of file utilities.cpp.
◆ macro_copyComplexMatrix
| #define macro_copyComplexMatrix | ( | dest, | |
| src | |||
| ) | 
Copies ComplexMatrix structures into a QMatrix.
Definition at line 1039 of file utilities.cpp.
◆ macro_copyQMatrix
| #define macro_copyQMatrix | ( | dest, | |
| src | |||
| ) | 
Definition at line 1013 of file utilities.cpp.
Function Documentation
◆ expI()
Returns the unit-norm complex number exp(i*phase). 
This function uses the Euler formula, and avoids problems with calling exp(complex) in a platform agnostic way
Definition at line 417 of file utilities.cpp.
References qcomp.
Referenced by getDFT(), setDiagMatrixOverrides(), and TEST_CASE().
◆ getIndexOfTargetValues()
| long long int getIndexOfTargetValues | ( | long long int | ref, | 
| int * | targs, | ||
| int | numTargs, | ||
| int | targVal | ||
| ) | 
◆ operator*() [1/7]
Definition at line 92 of file utilities.cpp.
◆ operator*() [2/7]
Definition at line 40 of file utilities.cpp.
◆ operator*() [3/7]
Definition at line 99 of file utilities.cpp.
◆ operator*() [4/7]
◆ operator*() [5/7]
Definition at line 109 of file utilities.cpp.
◆ operator*() [6/7]
Definition at line 46 of file utilities.cpp.
◆ operator*() [7/7]
◆ operator*=() [1/3]
Definition at line 131 of file utilities.cpp.
◆ operator*=() [2/3]
Definition at line 125 of file utilities.cpp.
◆ operator*=() [3/3]
Definition at line 70 of file utilities.cpp.
◆ operator+() [1/2]
◆ operator+() [2/2]
◆ operator+=() [1/2]
Definition at line 119 of file utilities.cpp.
◆ operator+=() [2/2]
Definition at line 64 of file utilities.cpp.
◆ operator-() [1/2]
◆ operator-() [2/2]
◆ operator-=() [1/2]
Definition at line 122 of file utilities.cpp.
◆ operator-=() [2/2]
Definition at line 67 of file utilities.cpp.
◆ operator/() [1/2]
Definition at line 102 of file utilities.cpp.
◆ operator/() [2/2]
◆ operator/=() [1/2]
Definition at line 128 of file utilities.cpp.
◆ operator/=() [2/2]
Definition at line 73 of file utilities.cpp.
◆ setBit()
| long long int setBit | ( | long long int | num, | 
| int | bitInd, | ||
| int | bitVal | ||
| ) | 
Definition at line 681 of file utilities.cpp.
References DEMAND.
Referenced by getIndexOfTargetValues().
◆ sublists() [1/3]
| Catch::Generators::GeneratorWrapper<int*> sublists | ( | Catch::Generators::GeneratorWrapper< int > && | gen, | 
| int | numSamps | ||
| ) | 
Definition at line 1510 of file utilities.cpp.
◆ sublists() [2/3]
| Catch::Generators::GeneratorWrapper<int*> sublists | ( | Catch::Generators::GeneratorWrapper< int > && | gen, | 
| int | numSamps, | ||
| const int * | exclude, | ||
| int | numExclude | ||
| ) | 
Definition at line 1495 of file utilities.cpp.
◆ sublists() [3/3]
| Catch::Generators::GeneratorWrapper<int*> sublists | ( | Catch::Generators::GeneratorWrapper< int > && | gen, | 
| int | numSamps, | ||
| int | excluded | ||
| ) | 
Definition at line 1502 of file utilities.cpp.
◆ updateIndices()
| void updateIndices | ( | int | oldEl, | 
| int | newEl, | ||
| int * | list1, | ||
| int | len1, | ||
| int * | list2, | ||
| int | len2 | ||
| ) | 
Variable Documentation
◆ fn_unique_suffix_id
| 
 | static | 
Definition at line 1356 of file utilities.cpp.
Referenced by setUniqueFilename().