-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclifford_rz.py
88 lines (64 loc) · 2.49 KB
/
clifford_rz.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import math
import os
import random
import sys
import time
from pyqrack import Pauli, QrackSimulator
def rand_1qb(sim, q):
sim.r(Pauli.PauliZ, random.uniform(0, 4 * math.pi), q)
def random_circuit(width, max_magic, circ):
t_count = 0
single_bit_gates = circ.h, circ.x, circ.y
single_bit_gates_with_phase = circ.h, circ.x, circ.y, circ.z, circ.s, circ.adjs
two_bit_gates = circ.mcx, circ.mcy, circ.mcz, circ.macx, circ.macy, circ.macz, circ.swap, circ.iswap, circ.adjiswap
for n in range(3 * width):
# Single bit gates
for j in range(width):
if (width * width * random.random()) < max_magic:
random.choice(single_bit_gates)(j)
rand_1qb(circ, j)
t_count += 1
else:
random.choice(single_bit_gates_with_phase)(j)
# Multi bit gates
bit_set = [i for i in range(width)]
while len(bit_set) > 1:
b1 = random.choice(bit_set)
bit_set.remove(b1)
b2 = random.choice(bit_set)
bit_set.remove(b2)
g = random.choice(two_bit_gates)
if g == circ.swap or g == circ.iswap or g == circ.adjiswap:
g(b1, b2)
else:
g([b1], b2)
return circ
def bench_qrack(n):
# This is a demonstration of near-Clifford capabilities, with Clifford+RZ gate set.
start = time.perf_counter()
sim = QrackSimulator(n, isStabilizerHybrid=True, isTensorNetwork=False, isSchmidtDecomposeMulti=False, isSchmidtDecompose=False, isOpenCL=False)
# Run a near-Clifford circuit
random_circuit(n, 3, sim)
result = sim.prob_perm(list(range(n)), [False]*n)
# fidelity = sim.get_unitary_fidelity()
return (time.perf_counter() - start, result)
def main():
print("Set environment variable QRACK_MAX_CPU_QB=-1 to use this script properly.")
bench_qrack(1)
max_qb = 24
samples = 1
if len(sys.argv) > 1:
max_qb = int(sys.argv[1])
if len(sys.argv) > 2:
samples = int(sys.argv[2])
for n in range(1, max_qb + 1):
width_results = []
# Run the benchmarks
for i in range(samples):
width_results.append(bench_qrack(n))
time_result = sum(r[0] for r in width_results) / samples
prob_result = sum(r[1] for r in width_results) / samples
print(n, ": ", time_result, " seconds, ", prob_result, " probability for |0...0> dimension")
return 0
if __name__ == '__main__':
sys.exit(main())