forked from Udinanon/Anaqonda
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnode_charlie.py
60 lines (49 loc) · 2.51 KB
/
node_charlie.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
from cqc.pythonLib import CQCConnection, qubit
import random
import json
N_QUBIT = 10
with open("n_qubit.config") as config_file:
N_QUBIT = int(next(config_file).split()[0])
while True:
with CQCConnection("Charlie") as Charlie:
master_not_chosen = True
received_from = []
first_node_qubits = []
second_node_qubits = []
# Waiting for the first node :)
print("~Charlie# Waiting for the first node :)")
first_node_attempt = Charlie.recvClassical(msg_size=65536)
attempt = json.loads(first_node_attempt.decode("utf-8"))
received_from.append(attempt["name"])
Charlie.sendClassical(received_from[-1], json.dumps(master_not_chosen).encode("utf-8"))
for _ in range(N_QUBIT):
first_node_qubits.append(Charlie.recvQubit())
master_not_chosen = False # I'm the master!
# Waiting for the second node :(
print("~Charlie# Waiting for the second node :(")
second_node_attempt = Charlie.recvClassical(msg_size=65536)
attempt = json.loads(second_node_attempt.decode("utf-8"))
received_from.append(attempt["name"])
Charlie.sendClassical(received_from[-1], json.dumps(master_not_chosen).encode("utf-8"))
for _ in range(N_QUBIT):
second_node_qubits.append(Charlie.recvQubit())
# Ok, I have all the qubits, now let's elaborate them
# The master (always the first node) do a cNOT (qubit by qubit) onto the second node (target)
for i in range(N_QUBIT):
first_node_qubits[i].cnot(second_node_qubits[i])
# And now let's apply the Hadamard Gate to the qubits of the master
for i in range(N_QUBIT):
first_node_qubits[i].H()
# Finally create and send the matrix of measurements
measurements_matrix = []
for i in range(N_QUBIT):
first = first_node_qubits[i].measure()
second = second_node_qubits[i].measure()
measurements_matrix.append([first, second])
print("~Charlie# Sending matrix")
measurements_message = json.dumps(measurements_matrix).encode("utf-8")
Charlie.sendClassical(received_from[0], measurements_message)
Charlie.sendClassical(received_from[1], measurements_message)
# Release all qubits so I can be ready for another key distribution
print("~Charlie# Done :)")
Charlie.release_all_qubits()