forked from microsoft/QuantumKatas
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ReferenceImplementation.qs
95 lines (76 loc) · 3.43 KB
/
ReferenceImplementation.qs
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT license.
//////////////////////////////////////////////////////////////////////
// This file contains reference solutions to all tasks.
// The tasks themselves can be found in Tasks.qs file.
// We recommend that you try to solve the tasks yourself first,
// but feel free to look up the solution if you get stuck.
//////////////////////////////////////////////////////////////////////
namespace Quantum.Kata.JointMeasurements {
open Microsoft.Quantum.Intrinsic;
open Microsoft.Quantum.Measurement;
// Task 1. Single-qubit measurement
operation SingleQubitMeasurement_Reference (qs : Qubit[]) : Int {
// Hint: use two single-qubit measurements
return M(qs[0]) == M(qs[1]) ? 0 | 1;
}
// Task 2. Parity measurement
operation ParityMeasurement_Reference (qs : Qubit[]) : Int {
return MeasureAllZ(qs) == Zero ? 0 | 1;
}
// Task 3. |0000⟩ + |1111⟩ or |0011⟩ + |1100⟩ ?
operation GHZOrGHZWithX_Reference (qs : Qubit[]) : Int {
// Considering only the two middle qubits of the array, their parity for the first state is 0,
// so the first state belongs to the +1 eigenspace of operator Z ⊗ Z on these qubits;
// their parity for the second state is 1, so the second state belongs to the -1 eigenspace.
return MeasureAllZ(qs[1 .. 2]) == Zero ? 0 | 1;
}
// Task 4. |0..0⟩ + |1..1⟩ or W state ?
operation GHZOrWState_Reference (qs : Qubit[]) : Int {
// Since the number of qubits in qs is even, the parity of both |0..0⟩ and |1..1⟩ basis states is 0,
// so both of them belong to the +1 eigenspace of operator Z ⊗ Z ⊗ ... ⊗ Z.
// All basis vectors in W state have parity 1 and belong to the -1 eigenspace of this operator.
return MeasureAllZ(qs) == Zero ? 0 | 1;
}
// Task 5*. Parity measurement in different basis
operation DifferentBasis_Reference (qs : Qubit[]) : Int {
// The first state is a superposition of the states |++⟩ and |--⟩,
// which belong to the +1 eigenspace of the operator X ⊗ X;
// the second one is a superposition of |+-⟩ and |-+⟩, which belong to the -1 eigenspace.
return Measure([PauliX, PauliX], qs) == Zero ? 0 | 1;
}
// Task 6*. Controlled X gate with |0⟩ target
operation ControlledX_Reference (qs : Qubit[]) : Unit {
H(qs[1]);
if (MeasureAllZ(qs) == One){
X(qs[1]);
}
}
// Task 7**. Controlled X gate with arbitrary target
operation ControlledX_General_Reference (qs : Qubit[]) : Unit {
body (...) {
// This implementation follows the description at https://arxiv.org/pdf/1201.5734.pdf.
// Note the parity notation used in the table of fixups in the paper
// differs from the notation used in Q#.
use a = Qubit();
let c = qs[0];
let t = qs[1];
H(a);
let p1 = MeasureAllZ([c, a]);
H(a);
H(t);
let p2 = MeasureAllZ([a, t]);
H(a);
H(t);
let m = M(a);
// apply fixups
if (p2 == One) {
Z(c);
}
if (p1 != m) {
X(t);
}
}
adjoint self;
}
}