15#ifndef _GPU_LIB_TN_SIM_H_
16#define _GPU_LIB_TN_SIM_H_
28 explicit GpuLibTNSim(
const std::shared_ptr<GpuLibrary> &lib) : lib(lib) {
30 obj = lib->CreateTensorNet();
35 GpuLibTNSim(
const std::shared_ptr<GpuLibrary> &lib,
void *obj)
36 : lib(lib), obj(obj) {}
38 GpuLibTNSim() =
delete;
39 GpuLibTNSim(
const GpuLibTNSim &) =
delete;
40 GpuLibTNSim &operator=(
const GpuLibTNSim &) =
delete;
41 GpuLibTNSim(GpuLibTNSim &&) =
default;
42 GpuLibTNSim &operator=(GpuLibTNSim &&) =
default;
45 if (lib && obj) lib->DestroyTensorNet(obj);
48 bool Create(
unsigned int nrQubits) {
49 if (obj)
return lib->TNCreate(obj, nrQubits);
55 if (obj)
return lib->TNReset(obj);
60 bool IsValid()
const {
61 if (obj)
return lib->TNIsValid(obj);
66 bool IsCreated()
const {
67 if (obj)
return lib->TNIsCreated(obj);
72 bool SetDataType(
int useDoublePrecision) {
73 if (obj)
return lib->TNSetDataType(obj, useDoublePrecision);
78 bool IsDoublePrecision()
const {
79 if (obj)
return lib->TNIsDoublePrecision(obj);
84 bool SetCutoff(
double val) {
85 if (obj)
return lib->TNSetCutoff(obj, val);
90 double GetCutoff()
const {
91 if (obj)
return lib->TNGetCutoff(obj);
96 bool SetGesvdJ(
int val) {
97 if (obj)
return lib->TNSetGesvdJ(obj, val);
102 bool GetGesvdJ()
const {
103 if (obj)
return lib->TNGetGesvdJ(obj);
108 bool SetMaxExtent(
long int val) {
109 if (obj)
return lib->TNSetMaxExtent(obj, val);
114 long int GetMaxExtent()
const {
115 if (obj)
return lib->TNGetMaxExtent(obj);
120 int GetNrQubits()
const {
121 if (obj)
return lib->TNGetNrQubits(obj);
126 bool Amplitude(
long int numFixedValues,
long int *fixedValues,
double *real,
127 double *imaginary)
const {
129 return lib->TNAmplitude(obj, numFixedValues, fixedValues, real,
135 double Probability0(
unsigned int qubit)
const {
136 if (obj)
return lib->TNProbability0(obj, qubit);
141 bool Measure(
unsigned int qubit) {
142 if (obj)
return lib->TNMeasure(obj, qubit);
147 bool MeasureQubits(
long int numQubits,
unsigned int *qubits,
int *result) {
148 if (obj)
return lib->TNMeasureQubits(obj, numQubits, qubits, result);
153 std::unordered_map<std::vector<bool>, int64_t> *GetMapForSample()
const {
154 if (lib)
return lib->TNGetMapForSample();
159 bool FreeMapForSample(
160 std::unordered_map<std::vector<bool>, int64_t> *map)
const {
161 if (lib)
return lib->TNFreeMapForSample(map);
166 bool Sample(
long int numShots,
long int numQubits,
unsigned int *qubits,
168 if (obj)
return lib->TNSample(obj, numShots, numQubits, qubits, resultMap);
174 if (obj)
return lib->TNSaveState(obj);
180 if (obj)
return lib->TNRestoreState(obj);
185 bool CleanSavedState() {
186 if (obj)
return lib->TNCleanSavedState(obj);
191 std::unique_ptr<GpuLibTNSim> Clone()
const {
197 double ExpectationValue(
const std::string &pauliString)
const {
199 return lib->TNExpectationValue(obj, pauliString.c_str(),
200 pauliString.length());
205 bool ApplyX(
unsigned int siteA) {
206 if (obj)
return lib->TNApplyX(obj, siteA);
211 bool ApplyY(
unsigned int siteA) {
212 if (obj)
return lib->TNApplyY(obj, siteA);
217 bool ApplyZ(
unsigned int siteA) {
218 if (obj)
return lib->TNApplyZ(obj, siteA);
223 bool ApplyH(
unsigned int siteA) {
224 if (obj)
return lib->TNApplyH(obj, siteA);
229 bool ApplyS(
unsigned int siteA) {
230 if (obj)
return lib->TNApplyS(obj, siteA);
236 if (obj)
return lib->TNApplySDG(obj, siteA);
241 bool ApplyT(
unsigned int siteA) {
242 if (obj)
return lib->TNApplyT(obj, siteA);
248 if (obj)
return lib->TNApplyTDG(obj, siteA);
253 bool ApplySX(
unsigned int siteA) {
254 if (obj)
return lib->TNApplySX(obj, siteA);
260 if (obj)
return lib->TNApplySXDG(obj, siteA);
265 bool ApplyK(
unsigned int siteA) {
266 if (obj)
return lib->TNApplyK(obj, siteA);
271 bool ApplyP(
unsigned int siteA,
double theta) {
272 if (obj)
return lib->TNApplyP(obj, siteA, theta);
277 bool ApplyRx(
unsigned int siteA,
double theta) {
278 if (obj)
return lib->TNApplyRx(obj, siteA, theta);
283 bool ApplyRy(
unsigned int siteA,
double theta) {
284 if (obj)
return lib->TNApplyRy(obj, siteA, theta);
289 bool ApplyRz(
unsigned int siteA,
double theta) {
290 if (obj)
return lib->TNApplyRz(obj, siteA, theta);
295 bool ApplyU(
unsigned int siteA,
double theta,
double phi,
double lambda,
297 if (obj)
return lib->TNApplyU(obj, siteA, theta, phi, lambda, gamma);
302 bool ApplySwap(
unsigned int controlQubit,
unsigned int targetQubit) {
303 if (obj)
return lib->TNApplySwap(obj, controlQubit, targetQubit);
308 bool ApplyCX(
unsigned int controlQubit,
unsigned int targetQubit) {
309 if (obj)
return lib->TNApplyCX(obj, controlQubit, targetQubit);
314 bool ApplyCY(
unsigned int controlQubit,
unsigned int targetQubit) {
315 if (obj)
return lib->TNApplyCY(obj, controlQubit, targetQubit);
320 bool ApplyCZ(
unsigned int controlQubit,
unsigned int targetQubit) {
321 if (obj)
return lib->TNApplyCZ(obj, controlQubit, targetQubit);
326 bool ApplyCH(
unsigned int controlQubit,
unsigned int targetQubit) {
327 if (obj)
return lib->TNApplyCH(obj, controlQubit, targetQubit);
332 bool ApplyCSX(
unsigned int controlQubit,
unsigned int targetQubit) {
333 if (obj)
return lib->TNApplyCSX(obj, controlQubit, targetQubit);
338 bool ApplyCSXDG(
unsigned int controlQubit,
unsigned int targetQubit) {
339 if (obj)
return lib->TNApplyCSXDG(obj, controlQubit, targetQubit);
344 bool ApplyCP(
unsigned int controlQubit,
unsigned int targetQubit,
346 if (obj)
return lib->TNApplyCP(obj, controlQubit, targetQubit, theta);
351 bool ApplyCRx(
unsigned int controlQubit,
unsigned int targetQubit,
353 if (obj)
return lib->TNApplyCRx(obj, controlQubit, targetQubit, theta);
358 bool ApplyCRy(
unsigned int controlQubit,
unsigned int targetQubit,
360 if (obj)
return lib->TNApplyCRy(obj, controlQubit, targetQubit, theta);
365 bool ApplyCRz(
unsigned int controlQubit,
unsigned int targetQubit,
367 if (obj)
return lib->TNApplyCRz(obj, controlQubit, targetQubit, theta);
372 bool ApplyCU(
unsigned int controlQubit,
unsigned int targetQubit,
373 double theta,
double phi,
double lambda,
double gamma) {
375 return lib->TNApplyCU(obj, controlQubit, targetQubit, theta, phi, lambda,
381 bool ApplyCCX(
unsigned int controlQubit1,
unsigned int controlQubit2,
382 unsigned int targetQubit) {
384 return lib->TNApplyCCX(obj, controlQubit1, controlQubit2, targetQubit);
388 bool ApplyCSwap(
unsigned int controlQubit,
unsigned int qubit1,
389 unsigned int qubit2) {
390 if (obj)
return lib->TNApplyCSwap(obj, controlQubit, qubit1, qubit2);
395 std::shared_ptr<GpuLibrary> lib;
int ApplyK(void *sim, int qubit)
int RestoreState(void *sim)
int ApplyRx(void *sim, int qubit, double theta)
int ApplyX(void *sim, int qubit)
int ApplyU(void *sim, int qubit, double theta, double phi, double lambda, double gamma)
int ApplyCRy(void *sim, int controlQubit, int targetQubit, double theta)
int ApplyTDG(void *sim, int qubit)
int ApplyCSXDG(void *sim, int controlQubit, int targetQubit)
int ApplyS(void *sim, int qubit)
int ApplyCX(void *sim, int controlQubit, int targetQubit)
int ApplyCRz(void *sim, int controlQubit, int targetQubit, double theta)
int ApplyCP(void *sim, int controlQubit, int targetQubit, double theta)
int ApplySXDG(void *sim, int qubit)
int ApplySDG(void *sim, int qubit)
unsigned long long int Measure(void *sim, const unsigned long int *qubits, unsigned long int nrQubits)
int ApplyCSwap(void *sim, int controlQubit, int qubit1, int qubit2)
int ApplyCCX(void *sim, int controlQubit1, int controlQubit2, int targetQubit)
int ApplyY(void *sim, int qubit)
double * Amplitude(void *sim, unsigned long long int outcome)
int ApplyZ(void *sim, int qubit)
int ApplyH(void *sim, int qubit)
int ApplyCY(void *sim, int controlQubit, int targetQubit)
int ApplyCU(void *sim, int controlQubit, int targetQubit, double theta, double phi, double lambda, double gamma)
int ApplySwap(void *sim, int qubit1, int qubit2)
int ApplyRy(void *sim, int qubit, double theta)
int ApplyP(void *sim, int qubit, double theta)
int ApplyCH(void *sim, int controlQubit, int targetQubit)
int ApplySX(void *sim, int qubit)
int ApplyCZ(void *sim, int controlQubit, int targetQubit)
int ApplyRz(void *sim, int qubit, double theta)
int ApplyT(void *sim, int qubit)
int ApplyCRx(void *sim, int controlQubit, int targetQubit, double theta)
int ApplyCSX(void *sim, int controlQubit, int targetQubit)