-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathrun_benchmarks.py
111 lines (96 loc) · 4.22 KB
/
run_benchmarks.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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import math
import time
from pathlib import Path
import numpy as np
from Cycles import GraphCreator, MemoryZone
from scheduling import create_initial_sequence, create_starting_config, run_simulation
def run_simulation_for_architecture(arch, seeds, pz, max_timesteps, compilation=True):
"""
Runs simulations for the given architecture and seeds, logs the results.
Args:
arch (list): Architecture parameters.
seeds (list): List of seed values.
pz (str): Position of Processing zone.
max_timesteps (int): Maximum timesteps.
compilation (bool): Compilation flag (Gate Selection Step).
Returns:
tuple: (timestep_arr, cpu_time_arr, number_of_registers, n_of_traps, seq_length)
"""
timestep_arr = []
cpu_time_arr = []
start_time = time.time()
for seed in seeds:
m, n, v, h = arch
graph = GraphCreator(m, n, v, h, pz).get_graph()
n_of_traps = len([trap for trap in graph.edges() if graph.get_edge_data(trap[0], trap[1])["edge_type"] == "trap"])
num_ion_chains = math.ceil(n_of_traps / 2)
try:
ion_chains, number_of_registers = create_starting_config(num_ion_chains, graph, seed=seed)
except:
continue
print(f"ion chains: {ion_chains}, number of registers: {number_of_registers}")
filename = f"QASM_files/full_register_access/full_register_access_{num_ion_chains}.qasm"
#filename = f"QASM_files/QFT_no_swaps/qft_no_swaps_nativegates_quantinuum_tket_{num_ion_chains}.qasm"
print(f"arch: {arch}, seed: {seed}, registers: {number_of_registers}\n")
time_2qubit_gate = 1
time_1qubit_gate = 1
max_chains_in_parking = 3
memorygrid = MemoryZone(
m, n, v, h, ion_chains, max_timesteps, max_chains_in_parking, pz,
time_2qubit_gate=time_2qubit_gate, time_1qubit_gate=time_1qubit_gate
)
memorygrid.update_distance_map()
seq, flat_seq, dag_dep, next_node_initial = create_initial_sequence(
memorygrid.distance_map, filename, compilation=compilation
)
seq_length = len(seq)
print(f"seq: {seq}")
timestep = run_simulation(
memorygrid, max_timesteps, seq, flat_seq, dag_dep, next_node_initial, max_length=10
)
timestep_arr.append(timestep)
cpu_time = time.time() - start_time
cpu_time_arr.append(cpu_time)
return timestep_arr, cpu_time_arr, number_of_registers, n_of_traps, seq_length
def log_results(arch, timestep_arr, cpu_time_arr, number_of_registers, n_of_traps, seq_length, compilation=True):
"""
Logs the results of the simulation to a file.
Args:
arch (list): Architecture parameters.
timestep_arr (list): List of timesteps.
cpu_time_arr (list): List of CPU times.
number_of_registers (int): Number of registers.
n_of_traps (int): Number of traps.
seq_length (int): Sequence length.
compilation (bool): Compilation flag (Gate Selection Step).
"""
timestep_mean = np.mean(timestep_arr)
timestep_var = np.var(timestep_arr)
cpu_time_mean = np.mean(cpu_time_arr)
print(cpu_time_mean)
print(f"timestep mean: {timestep_mean}, timestep var: {timestep_var}, cpu time mean: {cpu_time_mean}")
# file_path = Path("results.txt")
# try:
# with file_path.open("a") as file:
# line = (
# f"& {arch[0]} {arch[1]} {arch[2]} {arch[3]} & {number_of_registers}/{n_of_traps} & {seq_length} "
# f"& {timestep_mean} & {cpu_time_mean} s & Gate Selection={compilation} \\\\"
# )
# file.write(f"array ts: {timestep_arr}\n" + line + "\n\n")
# except:
# pass
def main():
archs = [
[3, 3, 2, 2],
]
seeds = [0]#, 1, 2, 3, 4]
pz = 'outer'
max_timesteps = 10000000
compilation = False
for arch in archs:
timestep_arr, cpu_time_arr, number_of_registers, n_of_traps, seq_length = run_simulation_for_architecture(
arch, seeds, pz, max_timesteps, compilation=compilation
)
log_results(arch, timestep_arr, cpu_time_arr, number_of_registers, n_of_traps, seq_length, compilation=compilation)
if __name__ == "__main__":
main()