Grover's Algorithm
%load_ext sympyprinting
from sympy import sqrt, symbols, Rational
from sympy import expand, Eq, Symbol, simplify, exp, sin
from sympy.physics.quantum import *
from sympy.physics.quantum.qubit import *
from sympy.physics.quantum.gate import *
from sympy.physics.quantum.grover import *
from sympy.physics.quantum.qft import QFT, IQFT, Fourier
from sympy.physics.quantum.circuitplot import circuit_plot
nqubits = 3
Define a black box function that returns True if it is passed the state we are searching for.
def black_box(qubits):
return True if qubits == IntQubit(1, qubits.nqubits) else False
Build a uniform superposition state to start the search.
psi = superposition_basis(nqubits); psi
Wrap that black box function in an oracle gate.
v = OracleGate(nqubits, black_box)
Perform two iterations of Grover's algorithm. Each iteration, the amplitude of the target state increases.
iter1 = qapply(grover_iteration(psi, v)); iter1
iter2 = qapply(grover_iteration(iter1, v)); iter2
A single shot measurement is performed to retrieve the target state.
measure_all_oneshot(iter2)
%notebook save grovers.ipynb
%notebook load qft.ipynb