Spaces:
Runtime error
Runtime error
# Credit to: https://github.com/qulacs/cirq-qulacs/blob/master/benchmark/benchmark_state_vector_qulacs.py | |
import re | |
import subprocess | |
def parse_qasm_to_package_gen(N, input_filename, output_filename): | |
with open(output_filename, 'w') as f: | |
f.write('#include <stdio.h>\n') | |
f.write('#include <math.h>\n') | |
f.write('#include <time.h>\n') | |
f.write('#include <stdlib.h>\n') | |
f.write('#include \"qpp.h\"\n') | |
f.write('using namespace qpp;\n') | |
f.write('#define BILLION 1E9\n') | |
f.write('\n') | |
f.write('cmat u2g(double p, double l){\n') | |
f.write('\tcmat u2{cmat::Zero(2, 2)};\n') | |
f.write('\tu2 << std::exp(-1_i * (p + l) / 2.0)/std::sqrt(2),\n') | |
f.write('\t-std::exp(-1_i * (p - l) / 2.0)/std::sqrt(2),\n') | |
f.write('\tstd::exp(1_i * (p - l) / 2.0)/std::sqrt(2),\n') | |
f.write('\tstd::exp(1_i * (p + l) / 2.0)/std::sqrt(2);\n') | |
f.write('\treturn u2;\n') | |
f.write('}\n') | |
f.write('cmat u3g(double t, double p, double l){\n') | |
f.write('\tcmat u3{cmat::Zero(2, 2)};\n') | |
f.write('\tu3 << std::exp(-1_i * (p + l) / 2.0) * std::cos(t / 2.0),\n') | |
f.write('\t-std::exp(-1_i * (p - l) / 2.0) * std::sin(t / 2.0),\n') | |
f.write('\tstd::exp(1_i * (p - l) / 2.0) * std::sin(t / 2.0),\n') | |
f.write('\tstd::exp(1_i * (p + l) / 2.0) * std::cos(t / 2.0);\n') | |
f.write('\treturn u3;\n') | |
f.write('}\n') | |
# f.write('int main(int argc, char* argv[]){\n') | |
f.write('int main(){\n') | |
f.write('\tusing namespace qpp;\n') | |
# f.write('\tQCircuit qc{{}};\n'.format(N)) | |
f.write('\tQCircuit qc{' + str(N) + '};\n') | |
f.write('\tstruct timespec requestStart, requestEnd;\n') | |
f.write('\tclock_gettime(CLOCK_REALTIME, &requestStart);\n') | |
lc = 0 | |
with open(input_filename, "r") as ifile: | |
lines = ifile.readlines() | |
k = 0 | |
for line in lines: | |
s = re.search(r"Generated|QASM|include|qreg|Qubits|cirq|x|y|z|h|rx|ry|rz|cx|u2|u3|\bsx\b|\bsxdg\b|s", line) | |
if s is None: | |
continue | |
elif s.group() in ['Generated', 'QASM', 'include', 'qreg', 'Qubits', 'cirq']: | |
lc = lc + 1 | |
f.write('// {}\n'.format(s.group())) | |
continue | |
elif s.group() == 'x' or s.group() == 'y' or s.group() == 'z' or s.group() == 'sx' or s.group() == 'sxdg' or s.group() == 'h' or s.group() == 's': | |
lc = lc + 1 | |
m_i = re.findall(r'\[\d\d*\]', line) | |
t_qbit = int(m_i[0].strip('[]')) | |
f.write('\tqc.gate(gt.{}, {});\n'.format(s.group().upper(), t_qbit)) | |
continue | |
elif s.group() == 'rx' or s.group() == 'ry' or s.group() == 'rz': | |
lc = lc + 1 | |
m_r = re.findall(r'\((.*?)\)', line) | |
# print(m_r) | |
if 'pi' in m_r[0] and 'e' in m_r[0]: | |
sp_str = m_r[0].split('e-') | |
m_r[0] = [re.findall(r'[-]?\d*\.\d\d*', sp_str[0])[0] + 'E-' + sp_str[1]] | |
elif 'pi' in m_r[0]: | |
m_r[0] = re.findall(r'[-]?\d*\.\d\d*', m_r[0]) | |
# print(m_r) | |
m_i = re.findall(r'\[\d\d*\]', line) | |
t_qbit = int(m_i[0].strip('[]')) | |
f.write('\tcmat U_{} = gt.{}(M_PI*{});\n'.format(k, s.group().upper(), float(m_r[0][0]))) | |
f.write('\tqc.gate(U_{}, {}, \"{}\");\n'.format(k, t_qbit, s.group())) | |
k = k + 1 | |
continue | |
elif s.group() == 'cx': | |
lc = lc + 1 | |
match = re.findall(r'\[\d\d*\]', line) | |
c_qbit = int(match[0].strip('[]')) | |
t_qbit = int(match[1].strip('[]')) | |
f.write('\tqc.gate(gt.CNOT, {}, {});\n'.format(c_qbit, t_qbit)) | |
continue | |
elif s.group() == 'u2': | |
lc = lc + 1 | |
m_r = re.findall(r'\((.*?,.*?)\)', line) | |
m_r = m_r[0].split(',') | |
for i, m in enumerate(m_r): | |
if 'pi' in m and 'e' in m: | |
sp_str = m_r[i].split('e-') | |
m_r[i] = [re.findall(r'[-]?\d*\.\d\d*', sp_str[0])[0] + 'E-' + sp_str[1]] | |
elif 'pi' in m: | |
m_r[i] = re.findall(r'[-]?\d*\.\d\d*', m) | |
else: | |
m_r[i] = '0' | |
m_i = re.findall(r'\[\d\d*\]', line) | |
t_qbit = int(m_i[0].strip('[]')) | |
f.write('\tcmat u2_' + str(k) + '{cmat::Zero(2, 2)};\n') | |
f.write('\tu2_{} << u2g(M_PI*{}, M_PI*{});\n'.format(k, float(m_r[0][0]), float(m_r[1][0]))) | |
f.write('\tqc.gate(u2_{}, {}, \"u2\");\n'.format(k, t_qbit)) | |
k = k + 1 | |
continue | |
elif s.group() == 'u3': | |
lc = lc + 1 | |
m_r = re.findall(r'\((.*?,.*?,.*?)\)', line) | |
m_r = m_r[0].split(',') | |
for i, m in enumerate(m_r): | |
if 'pi' in m and 'e' in m: | |
sp_str = m_r[i].split('e-') | |
m_r[i] = [re.findall(r'[-]?\d*\.\d\d*', sp_str[0])[0] + 'E-' + sp_str[1]] | |
elif 'pi' in m: | |
m_r[i] = re.findall(r'[-]?\d*\.\d\d*', m) | |
else: | |
m_r[i] = '0' | |
m_i = re.findall(r'\[\d\d*\]', line) | |
t_qbit = int(m_i[0].strip('[]')) | |
f.write('\tcmat u3_' + str(k) + '{cmat::Zero(2, 2)};\n') | |
f.write('\tu3_{} << u3g(M_PI*{}, M_PI*{}, M_PI*{});\n'.format(k, float(m_r[0][0]), float(m_r[1][0]), float(m_r[2][0]))) | |
f.write('\tqc.gate(u3_{}, {}, \"u3\");\n'.format(k, t_qbit)) | |
k = k + 1 | |
continue | |
f.write('\tQEngine engine{qc};\n') | |
f.write('\tengine.execute();\n') | |
f.write('\tclock_gettime(CLOCK_REALTIME, &requestEnd);\n') | |
f.write('\tdouble accum = (requestEnd.tv_sec - requestStart.tv_sec) + (requestEnd.tv_nsec - requestStart.tv_nsec)/BILLION;\n') | |
f.write('\tprintf( "%lf, ", accum );\n') | |
f.write('\treturn 0;\n') | |
f.write('}') | |
# result = subprocess.run(["grep", ".", input_filename, "|", "wc", "-l"], text=True)#stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) | |
_cmd = "grep . " + input_filename + "| wc -l" | |
lc_res = subprocess.check_output(_cmd, shell=True) | |
print(int(lc_res) == lc) | |
# print(lc) | |
task = 'qft' | |
sim_pack = 'qpp' | |
com_cap = 'mt' | |
prec = 'dp' | |
for N in range(6, 40, 2): | |
input_file_path = '/data/user/gangap_a/{}_singular/qasm_files/'.format(task) | |
input_file = input_file_path + 'qasm_N_{}.qasm'.format(N) | |
# save_file_path = '/data/user/gangap_a/{}_singular/{}/data_{}_{}'.format(task, sim_pack, com_cap, prec) | |
output_file_path = '/data/user/gangap_a/{}_singular/{}/run_files_{}_{}/'.format(task, sim_pack, com_cap, prec) | |
output_file = output_file_path + '{}_n{}.cpp'.format(task, N) | |
parse_qasm_to_package_gen(N, input_file, output_file) | |
r""" | |
for N in range(12, 42, 2): | |
input_file_path = '/data/user/gangap_a/rqc/data_files/' | |
input_file = input_file_path + 'circuit_n{}_m14_s0_e0_pEFGH.qasm'.format(N) | |
output_file_path = '/data/user/gangap_a/rqc/quest/QuEST/rqc/quest_sp_run_files/' | |
output_file = output_file_path + 'quest_rqc_n{}.c'.format(N) | |
parse_qasm_to_package_gen(N, 'float', input_file, output_file) | |
for N in range(41, 51): | |
input_file_path = '/data/user/gangap_a/rqc/data_files/' | |
input_file = input_file_path + 'circuit_n{}_m14_s0_e0_pEFGH.qasm'.format(N) | |
output_file_path = '/data/user/gangap_a/rqc/quest/QuEST/rqc/quest_sp_run_files/' | |
output_file = output_file_path + 'quest_rqc_n{}.c'.format(N) | |
parse_qasm_to_package_gen(N, 'float', input_file, output_file) | |
""" | |