Qibo circuit convertor

This commit is contained in:
tankya2
2023-02-10 16:31:17 +08:00
committed by Alessandro Candido
parent d1721ae37a
commit 6838faba33
2 changed files with 173 additions and 2 deletions

View File

@@ -1,5 +1,11 @@
import argparse
from qibotn import qasm_quimb
from timeit import default_timer as timer
from qibotn import quimb as qiboquimb
from QiboCircuitConvertor import QiboCircuitToEinsum
from cuquantum import contract
import cupy as cp
from qibo.models import *
def parser():
@@ -12,7 +18,65 @@ def parser():
def main(args: argparse.Namespace):
print("Testing for %d nqubits" % (args.nqubits))
qasm_quimb.eval_QI_qft(args.nqubits, args.qasm_circ, args.init_state)
qiboquimb.eval(args.nqubits, args.qasm_circ, args.init_state)
def parser_cuquantum():
parser = argparse.ArgumentParser()
parser.add_argument(
"--nqubits", default=10, type=int, help="Number of quibits in the circuits."
)
parser.add_argument(
"--circuit",
default="qft",
type=str,
help="Type of circuit to use. See README for the list of "
"available circuits.",
)
parser.add_argument(
"--precision",
default="complex128",
type=str,
help="Numerical precision of the simulation. "
"Choose between 'complex128' and 'complex64'.",
)
return parser.parse_args()
def main_cuquantum(args: argparse.Namespace):
print("Testing for %d nqubits" % (args.nqubits))
nqubits = args.nqubits
circuit_name = args.circuit
datatype = args.precision
# Create qibo quibit
if circuit_name in ("qft", "QFT"):
circuit = QFT(nqubits)
else:
raise NotImplementedError(f"Cannot find circuit {circuit_name}.")
myconvertor = QiboCircuitToEinsum(circuit, dtype=datatype)
expression, operands = myconvertor.state_vector()
start = timer()
result_qibo = circuit()
end = timer()
circuit_eval_time = end - start
print("Simulation time: Qibo =", circuit_eval_time, "s")
start = timer()
sv_cutn = contract(expression, *operands)
end = timer()
circuit_eval_time = end - start
print("Simulation time: cuQuantum cuTensorNet =", circuit_eval_time, "s")
# print(f"is sv in agreement?", cp.allclose(sv_cutn.flatten(), result_qibo.state(numpy=True)))
assert cp.allclose(sv_cutn.flatten(), result_qibo.state(numpy=True))
if __name__ == "__main__":