-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathteleportation.js
55 lines (42 loc) · 1.05 KB
/
teleportation.js
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
const QuantumCircuit = require("../../lib/quantum-circuit.js");
var input = `
OPENQASM 2.0;
include "qelib1.inc";
qreg q[3];
creg c0[1];
creg c1[1];
rx (pi/4) q[0]; // this message will be teleported from qubit 0 to qubit 2
h q[1];
cx q[1], q[2];
cx q[0], q[1];
h q[0];
measure q[1] -> c1[0];
if(c1==1) x q[2];
measure q[0] -> c0[0];
if(c0==1) z q[2];
`;
var circuit = new QuantumCircuit();
console.log("");
console.log("Importing QASM...");
circuit.importQASM(input);
console.log("");
console.log(circuit.exportQASM("Teleportation"));
console.log("");
console.log(circuit.exportPyquil("Teleportation"));
console.log("");
console.log("Teleporting...");
circuit.run();
console.log("");
console.log("Time: " + circuit.stats.duration + " ms");
console.log("");
console.log("Final amplitudes:");
circuit.print(true);
console.log("");
console.log("Angles:");
console.log(circuit.angles());
console.log("");
console.log("Probabilities:");
console.log(circuit.probabilities());
console.log("");
console.log("Measured:");
console.log(circuit.measureAll());