own simulator krisi2

This commit is contained in:
Daniel Tsvetkov 2020-03-27 18:59:07 +01:00
parent b5a512f5ac
commit 124edad8e3
2 changed files with 64 additions and 12 deletions

View File

@ -55,9 +55,11 @@ def perform_exp(case):
if __name__ == "__main__": if __name__ == "__main__":
correct = 0 correct = 0
results = defaultdict(int)
for i in range(100): for i in range(100):
case = random.choice([CASE_IDENTICAL, CASE_ORTHOGONAL]) case = random.choice([CASE_IDENTICAL, CASE_ORTHOGONAL])
result = perform_exp(case=case) result = perform_exp(case=case)
results[result] += 1
if result == '11': if result == '11':
guess = CASE_ORTHOGONAL guess = CASE_ORTHOGONAL
else: else:
@ -65,3 +67,4 @@ if __name__ == "__main__":
if guess == case: if guess == case:
correct += 1 correct += 1
print("Correct: {}".format(correct)) print("Correct: {}".format(correct))
# print("Results: {}".format(results))

73
lib.py
View File

@ -172,18 +172,9 @@ class State(Vector):
def _is_normalized(self): def _is_normalized(self):
return np.isclose(np.sum(np.abs(self.m ** 2)), 1.0) return np.isclose(np.sum(np.abs(self.m ** 2)), 1.0)
@staticmethod
def _normalize_angles(theta, phi):
# theta is between [0 and pi]
theta = theta.real % np.pi if theta.real != np.pi else theta.real
# phi is between (0 and 2*pi]
phi = phi.real % (2 * np.pi)
return theta, phi
@classmethod @classmethod
def from_bloch_angles(cls, theta, phi): def from_bloch_angles(cls, theta, phi):
"""Creates a state from angles in Bloch sphere""" """Creates a state from angles in Bloch sphere"""
theta, phi = cls._normalize_angles(theta, phi)
m0 = np.cos(theta / 2) m0 = np.cos(theta / 2)
m1 = np.sin(theta / 2) * np.power(np.e, (1j * phi)) m1 = np.sin(theta / 2) * np.power(np.e, (1j * phi))
m = m0 * _0 + m1 * _1 m = m0 * _0 + m1 * _1
@ -845,7 +836,7 @@ class MeasurementOperator(HermitianOperator):
# <ψ| # <ψ|
state_ct = state.conjugate_transpose() state_ct = state.conjugate_transpose()
# This is: <ψ| . M†_m M_m . |ψ> # This is: <ψ| . M†_m M_m . |ψ>
return state_ct.m.dot(self.m.dot(state.m)).item() return state_ct.m.dot(self.m.dot(state.m)).item().real
m0 = MeasurementOperator.create_from_basis(_0) m0 = MeasurementOperator.create_from_basis(_0)
@ -1304,7 +1295,63 @@ def test_light():
experiment(3, random_lights, [ver_filter, diag_filter, hor_filter]) experiment(3, random_lights, [ver_filter, diag_filter, hor_filter])
def test_krisi_measurement(): def test_krisi_measurement_2():
from qiskit import (
QuantumCircuit,
execute,
Aer)
simulator = Aer.get_backend('qasm_simulator')
CASE_IDENTICAL = "identical"
CASE_ORTHOGONAL = "orthogonal"
def perform_exp(case):
# produce angles with uniform distribution on the sphere
t = round(np.random.uniform(0, 1), 10)
theta0 = np.arccos(1 - 2 * t)
phi0 = round(np.random.uniform(0, 2 * np.pi), 10)
# rotate the 0th qubit in (theta, phi)
q0 = State.from_bloch_angles(theta0, phi0)
# rotate the 1st qubit depending on the case we are exploring...
if case == CASE_IDENTICAL:
# ... for identical we are rotating the 1st qubit the same angles as
# the 0th
theta1, phi1 = theta0, phi0
else:
# for orthogonal we rotate the 1st qubit in 90 degrees
# orthogonal to the first
theta1, phi1 = theta0 + np.pi, phi0
q1 = State.from_bloch_angles(theta1, phi1)
# Measure in the Bell's basis
st = State(q0 * q1)
meas = st.measure(basis=[b_phi_p, b_phi_m, b_psi_p, b_psi_m])
return meas
correct = 0
cases = defaultdict(int)
results = defaultdict(int)
for i in range(1000):
case = random.choice([CASE_IDENTICAL, CASE_ORTHOGONAL])
cases[case] += 1
result = perform_exp(case=case)
results[result] += 1
if result == '11':
guess = CASE_ORTHOGONAL
assert guess == case
else:
guess = CASE_IDENTICAL
if guess == case:
correct += 1
print("Correct: {}".format(correct))
# print("Results: {}".format(results))
# print("Cases: {}".format(cases))
def test_krisi_measurement_3():
beta = 2.6 beta = 2.6
b_0 = State(1 / np.sqrt(2) * (s("|100>") - s("|010>"))) b_0 = State(1 / np.sqrt(2) * (s("|100>") - s("|010>")))
b_1 = State(1 / np.sqrt(2) * (s("|011>") - s("|101>"))) b_1 = State(1 / np.sqrt(2) * (s("|011>") - s("|101>")))
@ -1325,4 +1372,6 @@ if __name__ == "__main__":
test() test()
test_quantum_processor() test_quantum_processor()
test_light() test_light()
test_krisi_measurement() test_krisi_measurement_2()
# TODO:
test_krisi_measurement_3()