Qrack  9.13
General classical-emulating-quantum development framework
pinvoke_api.hpp
Go to the documentation of this file.
1 // Copyright (c) Microsoft Corporation. All rights reserved.
2 // Licensed under the MIT License.
3 //
4 // (Extensively modified and adapted by Daniel Strano in unitaryfund/qrack)
5 
6 #pragma once
7 
8 #include "config.h"
9 #include "stddef.h"
10 
11 #if defined(_WIN32) && !defined(__CYGWIN__)
12 #define MICROSOFT_QUANTUM_DECL __declspec(dllexport)
13 #define MICROSOFT_QUANTUM_DECL_IMPORT __declspec(dllimport)
14 #else
15 #define MICROSOFT_QUANTUM_DECL
16 #define MICROSOFT_QUANTUM_DECL_IMPORT
17 #endif
18 
19 // SAL only defined in windows.
20 #ifndef _In_
21 #define _In_
22 #define _In_reads_(n)
23 #endif
24 
25 typedef unsigned long long uintq;
26 typedef void (*IdCallback)(uintq);
27 typedef bool (*ProbAmpCallback)(size_t, double, double);
28 
29 #if !(FPPOW < 6 && !defined(ENABLE_COMPLEX_X2))
31 #endif
32 
33 extern "C" {
34 // non-quantum
36 MICROSOFT_QUANTUM_DECL uintq init_count_type(_In_ uintq q, _In_ bool tn, _In_ bool md, _In_ bool sd, _In_ bool sh,
37  _In_ bool bdt, _In_ bool pg, _In_ bool nw, _In_ bool hy, _In_ bool oc, _In_ bool dm);
47 
48 // pseudo-quantum
49 #if FPPOW < 6
50 MICROSOFT_QUANTUM_DECL void ProbAll(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, float* p);
51 #else
52 MICROSOFT_QUANTUM_DECL void ProbAll(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, double* p);
53 #endif
57  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) bool* c);
59  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) bool* c, _In_ bool r);
62  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_ bool r);
64  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_ uintq m, uintq* c);
66  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_ uintq m, uintq* c, _In_ bool r);
70  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_ uintq m, uintq* c);
72  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_ uintq m, uintq* c, _In_ bool r);
73 #if FPPOW < 6
76  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, float* c, _In_ bool r);
78  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) float* b);
80  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) float* b);
82  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) float* b, _In_reads_(2 * n) float* e);
84  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) float* b, _In_reads_(2 * n) float* e);
87  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, float* c, _In_ bool r);
89  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) float* b);
91  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) float* b);
93  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) float* b, _In_reads_(2 * n) float* e);
95  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) float* b, _In_reads_(2 * n) float* e);
96 #else
99  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, double* c, _In_ bool r);
101  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) double* b);
103  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) double* b);
105  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) double* b, _In_reads_(2 * n) double* e);
107  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) double* b, _In_reads_(2 * n) double* e);
110  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, double* c, _In_ bool r);
112  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) double* b);
114  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) double* b);
116  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(3 * n) double* b, _In_reads_(2 * n) double* e);
118  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(8 * n) double* b, _In_reads_(2 * n) double* e);
119 #endif
121  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* b);
123  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* b);
124 
127 
128 #if FPPOW < 6
129 MICROSOFT_QUANTUM_DECL void InKet(_In_ uintq sid, _In_ float* ket);
130 MICROSOFT_QUANTUM_DECL void OutKet(_In_ uintq sid, _In_ float* ket);
131 MICROSOFT_QUANTUM_DECL void OutProbs(_In_ uintq sid, _In_ float* ket);
132 #else
133 MICROSOFT_QUANTUM_DECL void InKet(_In_ uintq sid, _In_ double* ket);
134 MICROSOFT_QUANTUM_DECL void OutKet(_In_ uintq sid, _In_ double* ket);
135 MICROSOFT_QUANTUM_DECL void OutProbs(_In_ uintq sid, _In_ double* ket);
136 #endif
137 
138 MICROSOFT_QUANTUM_DECL size_t random_choice(_In_ uintq sid, _In_ size_t n, _In_reads_(n) double* p);
139 
140 MICROSOFT_QUANTUM_DECL void PhaseParity(_In_ uintq sid, _In_ double lambda, _In_ uintq n, _In_reads_(n) uintq* q);
143  _In_ uintq sid, _In_ uintq n, _In_reads_(n) int* b, _In_reads_(n) uintq* q);
144 
146 
147 // allocate and release
151 
152 // single-qubit gates
165 MICROSOFT_QUANTUM_DECL void U(_In_ uintq sid, _In_ uintq q, _In_ double theta, _In_ double phi, _In_ double lambda);
166 MICROSOFT_QUANTUM_DECL void Mtrx(_In_ uintq sid, _In_reads_(8) double* m, _In_ uintq q);
167 
168 // multi-controlled single-qubit gates
169 
178 MICROSOFT_QUANTUM_DECL void MCU(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq q, _In_ double theta,
179  _In_ double phi, _In_ double lambda);
181  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_reads_(8) double* m, _In_ uintq q);
182 
191 MICROSOFT_QUANTUM_DECL void MACU(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq q, _In_ double theta,
192  _In_ double phi, _In_ double lambda);
194  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_reads_(8) double* m, _In_ uintq q);
195 
197  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_reads_(8) double* m, _In_ uintq q, _In_ uintq p);
198 
200  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq q, double* m);
201 
202 // coalesced single qubit gates
203 
207 
208 // rotations
209 MICROSOFT_QUANTUM_DECL void R(_In_ uintq sid, _In_ uintq b, _In_ double phi, _In_ uintq q);
210 
211 // multi-controlled rotations
213  _In_ uintq sid, _In_ uintq b, _In_ double phi, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq q);
214 
215 // Exponential of Pauli operators
217  _In_ uintq sid, _In_ uintq n, _In_reads_(n) int* b, _In_ double phi, _In_reads_(n) uintq* q);
218 MICROSOFT_QUANTUM_DECL void MCExp(_In_ uintq sid, _In_ uintq n, _In_reads_(n) int* b, _In_ double phi, _In_ uintq nc,
219  _In_reads_(nc) uintq* cs, _In_reads_(n) uintq* q);
220 
221 // measurements
227  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, _In_ uintq s, _In_reads_(s) uintq* m);
228 
232 MICROSOFT_QUANTUM_DECL void FSim(_In_ uintq sid, _In_ double theta, _In_ double phi, _In_ uintq qi1, _In_ uintq qi2);
235  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq qi1, _In_ uintq qi2);
236 
237 // Schmidt decomposition
241 
243 MICROSOFT_QUANTUM_DECL void OR(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo);
248 MICROSOFT_QUANTUM_DECL void CLAND(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo);
249 MICROSOFT_QUANTUM_DECL void CLOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo);
250 MICROSOFT_QUANTUM_DECL void CLXOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo);
251 MICROSOFT_QUANTUM_DECL void CLNAND(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo);
252 MICROSOFT_QUANTUM_DECL void CLNOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo);
253 MICROSOFT_QUANTUM_DECL void CLXNOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo);
254 
257 
258 #if ENABLE_ALU
260  _In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq* a, _In_ uintq n, _In_reads_(n) uintq* q);
262  _In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq* a, _In_ uintq n, _In_reads_(n) uintq* q);
264  _In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq* a, uintq s, _In_ uintq n, _In_reads_(n) uintq* q);
266  _In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq* a, uintq s, _In_ uintq n, _In_reads_(n) uintq* q);
267 
269  _In_reads_(nc) uintq* c, _In_ uintq nq, _In_reads_(nq) uintq* q);
271  _In_reads_(nc) uintq* c, _In_ uintq nq, _In_reads_(nq) uintq* q);
272 
274  _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
276  _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
278  _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
280  _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
282  _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
283 
285  _In_reads_(nc) uintq* c, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
287  _In_reads_(nc) uintq* c, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
289  _In_reads_(nc) uintq* c, _In_reads_(na) uintq* m, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
291  _In_reads_(nc) uintq* c, _In_reads_(na) uintq* m, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
293  _In_reads_(nc) uintq* c, _In_reads_(na) uintq* m, _In_ uintq n, _In_reads_(n) uintq* q, _In_reads_(n) uintq* o);
294 
296  _In_ uintq sid, _In_ uintq ni, _In_reads_(ni) uintq* qi, _In_ uintq nv, _In_reads_(nv) uintq* qv, unsigned char* t);
298  _In_reads_(nv) uintq* qv, unsigned char* t);
300  _In_reads_(nv) uintq* qv, unsigned char* t);
301 MICROSOFT_QUANTUM_DECL void Hash(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* q, unsigned char* t);
302 #endif
303 
310 MICROSOFT_QUANTUM_DECL void SetSdrp(_In_ uintq sid, _In_ double sdrp);
311 MICROSOFT_QUANTUM_DECL void SetNcrp(_In_ uintq sid, _In_ double ncrp);
316 
317 #if !(FPPOW < 6 && !defined(ENABLE_COMPLEX_X2))
318 MICROSOFT_QUANTUM_DECL void TimeEvolve(_In_ uintq sid, _In_ double t, _In_ uintq n,
319  _In_reads_(n) _QrackTimeEvolveOpHeader* teos, uintq mn, _In_reads_(mn) double* mtrx);
320 #endif
321 
323  _In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq q, _In_ uintq f, _In_ double a, _In_ double tol);
326 
327 #if FPPOW < 6
328 MICROSOFT_QUANTUM_DECL void set_qneuron_angles(_In_ uintq nid, _In_ float* angles);
329 MICROSOFT_QUANTUM_DECL void get_qneuron_angles(_In_ uintq nid, _In_ float* angles);
330 #else
331 MICROSOFT_QUANTUM_DECL void set_qneuron_angles(_In_ uintq nid, _In_ double* angles);
332 MICROSOFT_QUANTUM_DECL void get_qneuron_angles(_In_ uintq nid, _In_ double* angles);
333 #endif
334 
335 MICROSOFT_QUANTUM_DECL void set_qneuron_alpha(_In_ uintq nid, _In_ double alpha);
337 
340 
341 MICROSOFT_QUANTUM_DECL double qneuron_predict(_In_ uintq nid, _In_ bool e, _In_ bool r);
343 
345 
346 MICROSOFT_QUANTUM_DECL void qneuron_learn(_In_ uintq nid, _In_ double eta, _In_ bool e, _In_ bool r);
347 MICROSOFT_QUANTUM_DECL void qneuron_learn_permutation(_In_ uintq nid, _In_ double eta, _In_ bool e, _In_ bool r);
348 
349 MICROSOFT_QUANTUM_DECL uintq init_qcircuit(_In_ bool collapse, _In_ bool clifford);
358  _In_ uintq cid, _In_reads_(8) double* m, _In_ uintq n, _In_reads_(n) uintq* c, _In_ uintq q, _In_ uintq p);
364 }
MICROSOFT_QUANTUM_DECL void POWN(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_reads_(na) uintq *m, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3186
MICROSOFT_QUANTUM_DECL bool TrySeparate2Qb(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:3362
MICROSOFT_QUANTUM_DECL void Exp(_In_ uintq sid, _In_ uintq n, _In_reads_(n) int *b, _In_ double phi, _In_reads_(n) uintq *q)
(External API) Exponentiation of Pauli operators
Definition: pinvoke_api.cpp:2012
#define _In_reads_(n)
Definition: pinvoke_api.hpp:22
MICROSOFT_QUANTUM_DECL void Dispose(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:2325
MICROSOFT_QUANTUM_DECL double FactorizedExpectation(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ uintq m, uintq *c)
(External API) Get the permutation expectation value, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2731
MICROSOFT_QUANTUM_DECL void Normalize(_In_ uintq sid)
Definition: pinvoke_api.cpp:3502
MICROSOFT_QUANTUM_DECL void set_qneuron_alpha(_In_ uintq nid, _In_ double alpha)
Definition: pinvoke_api.cpp:3673
MICROSOFT_QUANTUM_DECL void MCMUL(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3202
MICROSOFT_QUANTUM_DECL void MZ(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
(External API) Multiple "Z" Gate
Definition: pinvoke_api.cpp:1967
MICROSOFT_QUANTUM_DECL void Dump(_In_ uintq sid, _In_ ProbAmpCallback callback)
(External API) "Dump" state vector from the selected simulator ID into the callback
Definition: pinvoke_api.cpp:1078
MICROSOFT_QUANTUM_DECL void SBC(_In_ uintq sid, uintq s, _In_ uintq ni, _In_reads_(ni) uintq *qi, _In_ uintq nv, _In_reads_(nv) uintq *qv, unsigned char *t)
Definition: pinvoke_api.cpp:3322
MICROSOFT_QUANTUM_DECL void AdjSY(_In_ uintq sid, _In_ uintq q)
(External API) Inverse square root of Y gate
Definition: pinvoke_api.cpp:1532
MICROSOFT_QUANTUM_DECL void qcircuit_swap(_In_ uintq cid, _In_ uintq q1, _In_ uintq q2)
Definition: pinvoke_api.cpp:3844
#define MICROSOFT_QUANTUM_DECL
Definition: pinvoke_api.hpp:15
MICROSOFT_QUANTUM_DECL void XNOR(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo)
Definition: pinvoke_api.cpp:2416
MICROSOFT_QUANTUM_DECL void MCDIV(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3220
MICROSOFT_QUANTUM_DECL void set_concurrency(_In_ uintq sid, _In_ uintq p)
(External API) Set concurrency level per QEngine shard
Definition: pinvoke_api.cpp:997
MICROSOFT_QUANTUM_DECL void CLAND(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo)
Definition: pinvoke_api.cpp:2428
MICROSOFT_QUANTUM_DECL double Variance(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
(External API) Get the permutation variance, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2659
MICROSOFT_QUANTUM_DECL double MatrixVarianceEigenVal(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(8 *n) float *b, _In_reads_(2 *n) float *e)
(External API) Get the single-qubit (2x2) operator variance for the array of qubits and bases.
Definition: pinvoke_api.cpp:2962
MICROSOFT_QUANTUM_DECL void ResetUnitaryFidelity(_In_ uintq sid)
Definition: pinvoke_api.cpp:3433
MICROSOFT_QUANTUM_DECL void set_qneuron_angles(_In_ uintq nid, _In_ float *angles)
Definition: pinvoke_api.cpp:3639
MICROSOFT_QUANTUM_DECL uintq init_count_pager(_In_ uintq q, _In_ bool dm)
(External API) Initialize a simulator ID with "q" qubits and implicit default layer options.
Definition: pinvoke_api.cpp:791
MICROSOFT_QUANTUM_DECL void Hash(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, unsigned char *t)
Definition: pinvoke_api.cpp:3335
MICROSOFT_QUANTUM_DECL bool TrySeparate1Qb(_In_ uintq sid, _In_ uintq qi1)
Definition: pinvoke_api.cpp:3349
MICROSOFT_QUANTUM_DECL double FactorizedVarianceFp(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, float *c)
(External API) Get the permutation variance, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2787
MICROSOFT_QUANTUM_DECL void SetNoiseParameter(_In_ uintq sid, _In_ double np)
Definition: pinvoke_api.cpp:3491
MICROSOFT_QUANTUM_DECL void MCS(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled "S" Gate
Definition: pinvoke_api.cpp:1661
MICROSOFT_QUANTUM_DECL void MX(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
(External API) Multiple "X" Gate
Definition: pinvoke_api.cpp:1939
MICROSOFT_QUANTUM_DECL void MCDIVN(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_reads_(na) uintq *m, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3257
MICROSOFT_QUANTUM_DECL uintq init_count(_In_ uintq q, _In_ bool dm)
(External API) Initialize a simulator ID with "q" qubits and implicit default layer options.
Definition: pinvoke_api.cpp:737
MICROSOFT_QUANTUM_DECL void OutProbs(_In_ uintq sid, _In_ float *ket)
(External API) Get basis dimension probabilities for the selected simulator ID.
Definition: pinvoke_api.cpp:1160
MICROSOFT_QUANTUM_DECL void DIVN(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_reads_(na) uintq *m, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3171
MICROSOFT_QUANTUM_DECL double MatrixExpectationEigenVal(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(8 *n) float *b, _In_reads_(2 *n) float *e)
(External API) Get the single-qubit (2x2) operator expectation value for the array of qubits and base...
Definition: pinvoke_api.cpp:2953
MICROSOFT_QUANTUM_DECL void T(_In_ uintq sid, _In_ uintq q)
(External API) "T" Gate
Definition: pinvoke_api.cpp:1487
MICROSOFT_QUANTUM_DECL void ACSWAP(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:2236
MICROSOFT_QUANTUM_DECL double UnitaryVariance(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(3 *n) float *b)
(External API) Get the single-qubit (3-parameter) operator variance for the array of qubits and bases...
Definition: pinvoke_api.cpp:2833
MICROSOFT_QUANTUM_DECL void MULN(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_reads_(na) uintq *m, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3156
MICROSOFT_QUANTUM_DECL void qcircuit_append_mc(_In_ uintq cid, _In_reads_(8) double *m, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q, _In_ uintq p)
Definition: pinvoke_api.cpp:3857
MICROSOFT_QUANTUM_DECL void MCAdjS(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled Inverse "S" Gate
Definition: pinvoke_api.cpp:1689
MICROSOFT_QUANTUM_DECL uintq get_qcircuit_qubit_count(_In_ uintq cid)
Definition: pinvoke_api.cpp:3839
MICROSOFT_QUANTUM_DECL double MatrixExpectation(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(8 *n) float *b)
(External API) Get the single-qubit (2x2) operator expectation value for the array of qubits and base...
Definition: pinvoke_api.cpp:2863
MICROSOFT_QUANTUM_DECL void MUL(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3128
MICROSOFT_QUANTUM_DECL uintq Decompose(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:2289
MICROSOFT_QUANTUM_DECL void MeasureShots(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ uintq s, _In_reads_(s) uintq *m)
Definition: pinvoke_api.cpp:2159
MICROSOFT_QUANTUM_DECL void QFT(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c)
Definition: pinvoke_api.cpp:3002
MICROSOFT_QUANTUM_DECL double qneuron_learn_cycle(_In_ uintq nid, _In_ bool e)
Definition: pinvoke_api.cpp:3721
MICROSOFT_QUANTUM_DECL bool TrySeparateTol(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ double tol)
Definition: pinvoke_api.cpp:3375
MICROSOFT_QUANTUM_DECL void R(_In_ uintq sid, _In_ uintq b, _In_ double phi, _In_ uintq q)
(External API) Rotation around Pauli axes
Definition: pinvoke_api.cpp:1981
MICROSOFT_QUANTUM_DECL double qneuron_unpredict(_In_ uintq nid, _In_ bool e)
Definition: pinvoke_api.cpp:3709
MICROSOFT_QUANTUM_DECL uintq get_qneuron_activation_fn(_In_ uintq nid)
Definition: pinvoke_api.cpp:3691
MICROSOFT_QUANTUM_DECL double PauliVariance(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *b)
(External API) Get the Pauli operator variance for the array of qubits and bases.
Definition: pinvoke_api.cpp:2996
MICROSOFT_QUANTUM_DECL void qneuron_learn(_In_ uintq nid, _In_ double eta, _In_ bool e, _In_ bool r)
Definition: pinvoke_api.cpp:3733
MICROSOFT_QUANTUM_DECL void destroy_qneuron(_In_ uintq nid)
Definition: pinvoke_api.cpp:3629
MICROSOFT_QUANTUM_DECL double UnitaryVarianceEigenVal(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(3 *n) float *b, _In_reads_(2 *n) float *e)
(External API) Get the single-qubit (3-parameter) operator variance for the array of qubits and bases...
Definition: pinvoke_api.cpp:2916
MICROSOFT_QUANTUM_DECL double PermutationExpectationRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ bool r)
MICROSOFT_QUANTUM_DECL void NOR(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo)
Definition: pinvoke_api.cpp:2404
MICROSOFT_QUANTUM_DECL void SetTInjection(_In_ uintq sid, _In_ bool iti)
Definition: pinvoke_api.cpp:3480
MICROSOFT_QUANTUM_DECL void DumpIds(_In_ uintq sid, _In_ IdCallback callback)
(External API) "Dump" all IDs from the selected simulator ID into the callback
Definition: pinvoke_api.cpp:1060
MICROSOFT_QUANTUM_DECL void OR(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo)
Definition: pinvoke_api.cpp:2368
MICROSOFT_QUANTUM_DECL void MACZ(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled "Z" Gate
Definition: pinvoke_api.cpp:1778
MICROSOFT_QUANTUM_DECL void Y(_In_ uintq sid, _In_ uintq q)
(External API) "Y" Gate
Definition: pinvoke_api.cpp:1398
MICROSOFT_QUANTUM_DECL void set_qneuron_activation_fn(_In_ uintq nid, _In_ uintq f)
Definition: pinvoke_api.cpp:3685
MICROSOFT_QUANTUM_DECL double PermutationProbRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) bool *c, _In_ bool r)
(External API) Get the permutation expectation value, based upon the order of input qubits,...
Definition: pinvoke_api.cpp:2611
MICROSOFT_QUANTUM_DECL void Compose(_In_ uintq sid1, _In_ uintq sid2, uintq *q)
Definition: pinvoke_api.cpp:2247
MICROSOFT_QUANTUM_DECL void MCX(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled "X" Gate
Definition: pinvoke_api.cpp:1602
MICROSOFT_QUANTUM_DECL double Prob(_In_ uintq sid, _In_ uintq q)
(External API) Get the probability that a qubit is in the |1> state.
Definition: pinvoke_api.cpp:2567
MICROSOFT_QUANTUM_DECL void AdjSX(_In_ uintq sid, _In_ uintq q)
(External API) Inverse square root of X gate
Definition: pinvoke_api.cpp:1517
MICROSOFT_QUANTUM_DECL void SX(_In_ uintq sid, _In_ uintq q)
(External API) Square root of X gate
Definition: pinvoke_api.cpp:1457
MICROSOFT_QUANTUM_DECL uintq qcircuit_past_light_cone(_In_ uintq cid, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:3821
MICROSOFT_QUANTUM_DECL void SetNcrp(_In_ uintq sid, _In_ double ncrp)
Definition: pinvoke_api.cpp:3457
MICROSOFT_QUANTUM_DECL void qcircuit_out_to_string(_In_ uintq cid, _In_ char *f)
Definition: pinvoke_api.cpp:3915
MICROSOFT_QUANTUM_DECL uintq Measure(_In_ uintq sid, _In_ uintq n, _In_reads_(n) int *b, _In_reads_(n) uintq *q)
(External API) Measure bits in specified Pauli bases
Definition: pinvoke_api.cpp:2138
MICROSOFT_QUANTUM_DECL void MACH(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled "H" Gate
Definition: pinvoke_api.cpp:1792
MICROSOFT_QUANTUM_DECL uintq init_clone(_In_ uintq sid)
(External API) Initialize a simulator ID that clones simulator ID "sid"
Definition: pinvoke_api.cpp:862
MICROSOFT_QUANTUM_DECL bool release(_In_ uintq sid, _In_ uintq q)
(External API) Release 1 qubit with the given qubit ID, under the simulator ID
Definition: pinvoke_api.cpp:1333
MICROSOFT_QUANTUM_DECL void qstabilizer_in_from_file(_In_ uintq sid, _In_ char *f)
Definition: pinvoke_api.cpp:1032
MICROSOFT_QUANTUM_DECL uintq M(_In_ uintq sid, _In_ uintq q)
(External API) Measure bit in |0>/|1> basis
Definition: pinvoke_api.cpp:2090
MICROSOFT_QUANTUM_DECL void MCH(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled "H" Gate
Definition: pinvoke_api.cpp:1644
MICROSOFT_QUANTUM_DECL double qneuron_predict(_In_ uintq nid, _In_ bool e, _In_ bool r)
Definition: pinvoke_api.cpp:3697
MICROSOFT_QUANTUM_DECL void IQFT(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c)
Definition: pinvoke_api.cpp:3017
MICROSOFT_QUANTUM_DECL void MCMULN(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_reads_(na) uintq *m, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3238
MICROSOFT_QUANTUM_DECL void S(_In_ uintq sid, _In_ uintq q)
(External API) "S" Gate
Definition: pinvoke_api.cpp:1442
MICROSOFT_QUANTUM_DECL uintq clone_qneuron(_In_ uintq nid)
Definition: pinvoke_api.cpp:3590
MICROSOFT_QUANTUM_DECL void qneuron_learn_permutation(_In_ uintq nid, _In_ double eta, _In_ bool e, _In_ bool r)
Definition: pinvoke_api.cpp:3744
MICROSOFT_QUANTUM_DECL void MACY(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled "Y" Gate
Definition: pinvoke_api.cpp:1764
MICROSOFT_QUANTUM_DECL double FactorizedVarianceRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ uintq m, uintq *c, _In_ bool r)
(External API) Get the permutation variance, based upon the order of input qubits,...
Definition: pinvoke_api.cpp:2760
MICROSOFT_QUANTUM_DECL void Mtrx(_In_ uintq sid, _In_reads_(8) double *m, _In_ uintq q)
(External API) 2x2 complex matrix unitary gate
Definition: pinvoke_api.cpp:1577
MICROSOFT_QUANTUM_DECL void SetSdrp(_In_ uintq sid, _In_ double sdrp)
Definition: pinvoke_api.cpp:3445
MICROSOFT_QUANTUM_DECL double VarianceRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ bool r)
MICROSOFT_QUANTUM_DECL uintq init_qcircuit_clone(_In_ uintq cid)
Definition: pinvoke_api.cpp:3817
MICROSOFT_QUANTUM_DECL void MACAdjS(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled Inverse "S" Gate
Definition: pinvoke_api.cpp:1837
MICROSOFT_QUANTUM_DECL void PhaseRootN(_In_ uintq sid, _In_ uintq p, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:1220
MICROSOFT_QUANTUM_DECL void Multiplex1Mtrx(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q, double *m)
Definition: pinvoke_api.cpp:1913
MICROSOFT_QUANTUM_DECL void ADC(_In_ uintq sid, uintq s, _In_ uintq ni, _In_reads_(ni) uintq *qi, _In_ uintq nv, _In_reads_(nv) uintq *qv, unsigned char *t)
Definition: pinvoke_api.cpp:3309
MICROSOFT_QUANTUM_DECL size_t qcircuit_out_to_string_length(_In_ uintq cid)
Definition: pinvoke_api.cpp:3903
MICROSOFT_QUANTUM_DECL void ADDS(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, uintq s, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:3062
MICROSOFT_QUANTUM_DECL void NAND(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo)
Definition: pinvoke_api.cpp:2392
MICROSOFT_QUANTUM_DECL size_t random_choice(_In_ uintq sid, _In_ size_t n, _In_reads_(n) double *p)
MICROSOFT_QUANTUM_DECL void qcircuit_in_from_file(_In_ uintq cid, _In_ char *f)
Definition: pinvoke_api.cpp:3893
MICROSOFT_QUANTUM_DECL void MACX(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled "X" Gate
Definition: pinvoke_api.cpp:1750
MICROSOFT_QUANTUM_DECL void U(_In_ uintq sid, _In_ uintq q, _In_ double theta, _In_ double phi, _In_ double lambda)
(External API) 3-parameter unitary gate
Definition: pinvoke_api.cpp:1562
MICROSOFT_QUANTUM_DECL void MCU(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q, _In_ double theta, _In_ double phi, _In_ double lambda)
(External API) Controlled 3-parameter unitary gate
Definition: pinvoke_api.cpp:1717
MICROSOFT_QUANTUM_DECL void ISWAP(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:2189
MICROSOFT_QUANTUM_DECL uintq MAll(_In_ uintq sid)
(External API) Measure all bits separately in |0>/|1> basis, and return the result in low-to-high ord...
Definition: pinvoke_api.cpp:2123
MICROSOFT_QUANTUM_DECL uintq init()
Definition: pinvoke_api.hpp:40
MICROSOFT_QUANTUM_DECL void MCADD(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_ uintq nq, _In_reads_(nq) uintq *q)
Definition: pinvoke_api.cpp:3091
MICROSOFT_QUANTUM_DECL void CLNAND(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo)
Definition: pinvoke_api.cpp:2464
MICROSOFT_QUANTUM_DECL uintq num_qubits(_In_ uintq sid)
Definition: pinvoke_api.cpp:1367
MICROSOFT_QUANTUM_DECL void MACS(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled "S" Gate
Definition: pinvoke_api.cpp:1809
MICROSOFT_QUANTUM_DECL void MACAdjT(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled Inverse "T" Gate
Definition: pinvoke_api.cpp:1851
MICROSOFT_QUANTUM_DECL void MACT(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) "Anti-"Controlled "T" Gate
Definition: pinvoke_api.cpp:1823
MICROSOFT_QUANTUM_DECL void MCMtrx(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_reads_(8) double *m, _In_ uintq q)
(External API) Controlled 2x2 complex matrix unitary gate
Definition: pinvoke_api.cpp:1732
MICROSOFT_QUANTUM_DECL void MACU(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q, _In_ double theta, _In_ double phi, _In_ double lambda)
(External API) Controlled 3-parameter unitary gate
Definition: pinvoke_api.cpp:1865
MICROSOFT_QUANTUM_DECL void MCZ(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled "Z" Gate
Definition: pinvoke_api.cpp:1630
MICROSOFT_QUANTUM_DECL uintq init_count_type(_In_ uintq q, _In_ bool tn, _In_ bool md, _In_ bool sd, _In_ bool sh, _In_ bool bdt, _In_ bool pg, _In_ bool nw, _In_ bool hy, _In_ bool oc, _In_ bool dm)
(External API) Initialize a simulator ID with "q" qubits and explicit layer options on/off
Definition: pinvoke_api.cpp:640
bool(* ProbAmpCallback)(size_t, double, double)
Definition: pinvoke_api.hpp:27
MICROSOFT_QUANTUM_DECL double UnitaryExpectation(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(3 *n) float *b)
(External API) Get the single-qubit (3-parameter) operator expectation value for the array of qubits ...
Definition: pinvoke_api.cpp:2824
MICROSOFT_QUANTUM_DECL void ResetAll(_In_ uintq sid)
(External API) Set the simulator to a computational basis permutation.
Definition: pinvoke_api.cpp:1278
MICROSOFT_QUANTUM_DECL void LDA(_In_ uintq sid, _In_ uintq ni, _In_reads_(ni) uintq *qi, _In_ uintq nv, _In_reads_(nv) uintq *qv, unsigned char *t)
Definition: pinvoke_api.cpp:3296
MICROSOFT_QUANTUM_DECL void ADD(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:3034
MICROSOFT_QUANTUM_DECL void InKet(_In_ uintq sid, _In_ float *ket)
(External API) Set state vector for the selected simulator ID.
Definition: pinvoke_api.cpp:1103
MICROSOFT_QUANTUM_DECL double FactorizedVarianceFpRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, float *c, _In_ bool r)
(External API) Get the permutation variance, based upon the order of input qubits,...
Definition: pinvoke_api.cpp:2796
#define _In_
Definition: pinvoke_api.hpp:21
MICROSOFT_QUANTUM_DECL void SetReactiveSeparate(_In_ uintq sid, _In_ bool irs)
Definition: pinvoke_api.cpp:3469
void(* IdCallback)(uintq)
Definition: pinvoke_api.hpp:26
MICROSOFT_QUANTUM_DECL void OutKet(_In_ uintq sid, _In_ float *ket)
(External API) Get state vector for the selected simulator ID.
Definition: pinvoke_api.cpp:1130
MICROSOFT_QUANTUM_DECL void get_qneuron_angles(_In_ uintq nid, _In_ float *angles)
Definition: pinvoke_api.cpp:3656
MICROSOFT_QUANTUM_DECL void seed(_In_ uintq sid, _In_ uintq s)
(External API) Set RNG seed for simulator ID
Definition: pinvoke_api.cpp:982
MICROSOFT_QUANTUM_DECL void MCT(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled "T" Gate
Definition: pinvoke_api.cpp:1675
MICROSOFT_QUANTUM_DECL double get_qneuron_alpha(_In_ uintq nid)
Definition: pinvoke_api.cpp:3679
MICROSOFT_QUANTUM_DECL void UCMtrx(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_reads_(8) double *m, _In_ uintq q, _In_ uintq p)
(External API) Controlled 2x2 complex matrix unitary gate with arbitrary control permutation
Definition: pinvoke_api.cpp:1898
MICROSOFT_QUANTUM_DECL void SUBS(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, uintq s, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:3076
MICROSOFT_QUANTUM_DECL void AND(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo)
Definition: pinvoke_api.cpp:2356
MICROSOFT_QUANTUM_DECL double GetUnitaryFidelity(_In_ uintq sid)
Definition: pinvoke_api.cpp:3420
MICROSOFT_QUANTUM_DECL void MCSUB(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_ uintq nq, _In_reads_(nq) uintq *q)
Definition: pinvoke_api.cpp:3109
MICROSOFT_QUANTUM_DECL double FactorizedExpectationRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ uintq m, uintq *c, _In_ bool r)
(External API) Get the permutation expectation value, based upon the order of input qubits,...
Definition: pinvoke_api.cpp:2741
MICROSOFT_QUANTUM_DECL void AdjISWAP(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:2201
MICROSOFT_QUANTUM_DECL double PauliExpectation(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *b)
(External API) Get the Pauli operator expectation value for the array of qubits and bases.
Definition: pinvoke_api.cpp:2987
MICROSOFT_QUANTUM_DECL void qcircuit_out_to_file(_In_ uintq cid, _In_ char *f)
Definition: pinvoke_api.cpp:3884
MICROSOFT_QUANTUM_DECL double PermutationProb(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) bool *c)
(External API) Get the permutation expectation value, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2601
MICROSOFT_QUANTUM_DECL void qcircuit_run(_In_ uintq cid, _In_ uintq sid)
Definition: pinvoke_api.cpp:3878
MICROSOFT_QUANTUM_DECL double UnitaryExpectationEigenVal(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(3 *n) float *b, _In_reads_(2 *n) float *e)
(External API) Get the single-qubit (3-parameter) operator expectation value for the array of qubits ...
Definition: pinvoke_api.cpp:2907
MICROSOFT_QUANTUM_DECL int get_error(_In_ uintq sid)
(External API) Poll after each operation to check whether error occurred.
Definition: pinvoke_api.cpp:622
MICROSOFT_QUANTUM_DECL uintq init_qneuron(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q, _In_ uintq f, _In_ double a, _In_ double tol)
Definition: pinvoke_api.cpp:3539
MICROSOFT_QUANTUM_DECL void SUB(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:3048
MICROSOFT_QUANTUM_DECL void CSWAP(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:2225
MICROSOFT_QUANTUM_DECL void AdjS(_In_ uintq sid, _In_ uintq q)
(External API) Inverse "S" Gate
Definition: pinvoke_api.cpp:1502
MICROSOFT_QUANTUM_DECL void XOR(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2, _In_ uintq qo)
Definition: pinvoke_api.cpp:2380
MICROSOFT_QUANTUM_DECL void qcircuit_append_1qb(_In_ uintq cid, _In_reads_(8) double *m, _In_ uintq q)
Definition: pinvoke_api.cpp:3849
unsigned long long uintq
Definition: pinvoke_api.hpp:25
MICROSOFT_QUANTUM_DECL void DIV(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3142
MICROSOFT_QUANTUM_DECL double FactorizedExpectationFpRdm(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, float *c, _In_ bool r)
(External API) Get the permutation expectation value, based upon the order of input qubits,...
Definition: pinvoke_api.cpp:2778
MICROSOFT_QUANTUM_DECL void X(_In_ uintq sid, _In_ uintq q)
(External API) "X" Gate
Definition: pinvoke_api.cpp:1383
MICROSOFT_QUANTUM_DECL void MACMtrx(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_reads_(8) double *m, _In_ uintq q)
(External API) Controlled 2x2 complex matrix unitary gate
Definition: pinvoke_api.cpp:1880
MICROSOFT_QUANTUM_DECL double JointEnsembleProbability(_In_ uintq sid, _In_ uintq n, _In_reads_(n) int *b, _In_reads_(n) uintq *q)
(External API) Find the joint probability for all specified qubits under the respective Pauli basis t...
Definition: pinvoke_api.cpp:1254
MICROSOFT_QUANTUM_DECL void CLOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo)
Definition: pinvoke_api.cpp:2440
MICROSOFT_QUANTUM_DECL void AdjT(_In_ uintq sid, _In_ uintq q)
(External API) Inverse "T" Gate
Definition: pinvoke_api.cpp:1547
MICROSOFT_QUANTUM_DECL void SWAP(_In_ uintq sid, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:2177
MICROSOFT_QUANTUM_DECL void PhaseParity(_In_ uintq sid, _In_ double lambda, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:1215
MICROSOFT_QUANTUM_DECL void MCY(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled "Y" Gate
Definition: pinvoke_api.cpp:1616
MICROSOFT_QUANTUM_DECL void destroy(_In_ uintq sid)
(External API) Destroy a simulator (ID will not be reused)
Definition: pinvoke_api.cpp:968
MICROSOFT_QUANTUM_DECL double MatrixVariance(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(8 *n) float *b)
(External API) Get the single-qubit (2x2) operator variance for the array of qubits and bases.
Definition: pinvoke_api.cpp:2872
MICROSOFT_QUANTUM_DECL void MCPOWN(_In_ uintq sid, _In_ uintq na, _In_reads_(na) uintq *a, _In_ uintq nc, _In_reads_(nc) uintq *c, _In_reads_(na) uintq *m, _In_ uintq n, _In_reads_(n) uintq *q, _In_reads_(n) uintq *o)
Definition: pinvoke_api.cpp:3276
MICROSOFT_QUANTUM_DECL void ProbAll(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, float *p)
(External API) Get the probabilities of all permutations of the requested subset of qubits.
Definition: pinvoke_api.cpp:2517
MICROSOFT_QUANTUM_DECL void MCR(_In_ uintq sid, _In_ uintq b, _In_ double phi, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled rotation around Pauli axes
Definition: pinvoke_api.cpp:1996
MICROSOFT_QUANTUM_DECL void MCAdjT(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *c, _In_ uintq q)
(External API) Controlled Inverse "T" Gate
Definition: pinvoke_api.cpp:1703
MICROSOFT_QUANTUM_DECL void Separate(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
Definition: pinvoke_api.cpp:3393
MICROSOFT_QUANTUM_DECL double PermutationExpectation(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
(External API) Get the permutation expectation value, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2642
MICROSOFT_QUANTUM_DECL void CLNOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo)
Definition: pinvoke_api.cpp:2476
MICROSOFT_QUANTUM_DECL void CLXNOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo)
Definition: pinvoke_api.cpp:2488
MICROSOFT_QUANTUM_DECL void H(_In_ uintq sid, _In_ uintq q)
(External API) Walsh-Hadamard transform applied for simulator ID and qubit ID
Definition: pinvoke_api.cpp:1427
MICROSOFT_QUANTUM_DECL void allocateQubit(_In_ uintq sid, _In_ uintq qid)
(External API) Allocate 1 new qubit with the given qubit ID, under the simulator ID
Definition: pinvoke_api.cpp:1293
MICROSOFT_QUANTUM_DECL uintq qcircuit_inverse(_In_ uintq cid)
Definition: pinvoke_api.cpp:3819
MICROSOFT_QUANTUM_DECL uintq init_qcircuit(_In_ bool collapse, _In_ bool clifford)
Definition: pinvoke_api.cpp:3755
MICROSOFT_QUANTUM_DECL void FSim(_In_ uintq sid, _In_ double theta, _In_ double phi, _In_ uintq qi1, _In_ uintq qi2)
Definition: pinvoke_api.cpp:2213
MICROSOFT_QUANTUM_DECL void qstabilizer_out_to_file(_In_ uintq sid, _In_ char *f)
Definition: pinvoke_api.cpp:1009
MICROSOFT_QUANTUM_DECL void MCExp(_In_ uintq sid, _In_ uintq n, _In_reads_(n) int *b, _In_ double phi, _In_ uintq nc, _In_reads_(nc) uintq *cs, _In_reads_(n) uintq *q)
(External API) Controlled exponentiation of Pauli operators
Definition: pinvoke_api.cpp:2050
MICROSOFT_QUANTUM_DECL void destroy_qcircuit(_In_ uintq cid)
Definition: pinvoke_api.cpp:3830
MICROSOFT_QUANTUM_DECL uintq ForceM(_In_ uintq sid, _In_ uintq q, _In_ bool r)
(External API) PSEUDO-QUANTUM: Post-select bit in |0>/|1> basis
Definition: pinvoke_api.cpp:2106
MICROSOFT_QUANTUM_DECL double ProbRdm(_In_ uintq sid, _In_ uintq q)
(External API) Get the probability that a qubit is in the |1> state, treating all ancillary qubits as...
Definition: pinvoke_api.cpp:2573
MICROSOFT_QUANTUM_DECL void Z(_In_ uintq sid, _In_ uintq q)
(External API) "Z" Gate
Definition: pinvoke_api.cpp:1412
MICROSOFT_QUANTUM_DECL void SY(_In_ uintq sid, _In_ uintq q)
(External API) Square root of Y gate
Definition: pinvoke_api.cpp:1472
MICROSOFT_QUANTUM_DECL double FactorizedVariance(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, _In_ uintq m, uintq *c)
(External API) Get the permutation variance, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2750
MICROSOFT_QUANTUM_DECL void MY(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q)
(External API) Multiple "Y" Gate
Definition: pinvoke_api.cpp:1953
MICROSOFT_QUANTUM_DECL double FactorizedExpectationFp(_In_ uintq sid, _In_ uintq n, _In_reads_(n) uintq *q, float *c)
(External API) Get the permutation expectation value, based upon the order of input qubits.
Definition: pinvoke_api.cpp:2769
MICROSOFT_QUANTUM_DECL void CLXOR(_In_ uintq sid, _In_ bool ci, _In_ uintq qi, _In_ uintq qo)
Definition: pinvoke_api.cpp:2452
Definition: hamiltonian.hpp:16