Last active
May 15, 2020 18:56
-
-
Save billchenxi/25f23a758bc9823f15ab44981596b001 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
namespace Q_Teleportation { | |
open Microsoft.Quantum.Canon; | |
open Microsoft.Quantum.Intrinsic; | |
operation Teleportation(sentMessage : Bool) : Bool { | |
mutable receivedMessage = false; | |
using (register = Qubit[3]) { | |
let message = register[0]; | |
if (sentMessage) { | |
X(message); // flip the message to "true" | |
} | |
let person_1 = register[1]; | |
let person_2 = register[2]; | |
// entanglement | |
H(person_1); | |
CNOT(person_1, person_2); | |
// teleportation: this order CNOT->H transfer the state of the message QuBit onto person_1. | |
CNOT(message, person_1); | |
H(message); | |
// Find the bell state was used | |
let messageState = M(message); | |
let person_1_state = M(person_1); | |
if (messageState == One) { | |
Z(person_2); | |
} | |
if (person_1_state == One) { | |
X(person_2); | |
} | |
if (M(person_2) == One) { | |
set receivedMessage = true; | |
} | |
ResetAll(register); | |
} | |
return receivedMessage; | |
} | |
operation QuantumSimulator(count : Int) : (Int, Int) { | |
mutable trues = 0; | |
mutable equal = 0; | |
mutable sentMessage = false; | |
for (indx in 1..count) { | |
set sentMessage = (Random([0.5, 0.5]) == 0); | |
mutable receivedMessage = Teleportation(sentMessage); | |
if (receivedMessage) { | |
set trues += 1; | |
} | |
if (receivedMessage == sentMessage) { | |
set equal += 1; | |
} | |
} | |
return (trues, equal); | |
} | |
@EntryPoint() | |
operation Driver_Code() : Unit { | |
let (trues, equal) = QuantumSimulator(1000); | |
let falses = 1000-trues; | |
Message($"Teleportation result: "); | |
Message($" One: {trues}"); | |
Message($" Zero: {falses}"); | |
Message($" Equal: {equal}"); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment