logo

Expression of type QcircuitEquiv

from the theory of proveit.physics.quantum.QPE

In [1]:
import proveit
# Automation is not needed when building an expression:
proveit.defaults.automation = False # This will speed things up.
proveit.defaults.inline_pngs = False # Makes files smaller.
%load_expr # Load the stored expression as 'stored_expr'
# import Expression classes needed to build the expression
from proveit import ExprRange, Variable, VertExprArray, t
from proveit.linear_algebra import ScalarMult, VecAdd
from proveit.numbers import Add, Exp, Interval, Mult, Neg, e, frac, i, one, pi, sqrt, two, zero
from proveit.physics.quantum import ket0, ket1, ket_plus
from proveit.physics.quantum.QPE import QPE1, _U, _ket_u, _phase, _psi_t_ket, _s
from proveit.physics.quantum.circuits import Gate, Input, MultiQubitElem, Output, Qcircuit, QcircuitEquiv
In [2]:
# build up the expression from sub-expressions
sub_expr1 = Variable("_a", latex_format = r"{_{-}a}")
sub_expr2 = Add(t, one)
sub_expr3 = Add(t, _s)
sub_expr4 = Interval(sub_expr2, sub_expr3)
sub_expr5 = MultiQubitElem(element = Gate(operation = QPE1(_U, t), part = sub_expr1), targets = Interval(one, sub_expr3))
sub_expr6 = ExprRange(sub_expr1, MultiQubitElem(element = Output(state = _ket_u, part = sub_expr1), targets = sub_expr4), one, _s)
sub_expr7 = [ExprRange(sub_expr1, Input(state = ket_plus), one, t), ExprRange(sub_expr1, MultiQubitElem(element = Input(state = _ket_u, part = sub_expr1), targets = sub_expr4), one, _s)]
sub_expr8 = [ExprRange(sub_expr1, sub_expr5, one, t), ExprRange(sub_expr1, sub_expr5, sub_expr2, sub_expr3)]
expr = QcircuitEquiv(Qcircuit(vert_expr_array = VertExprArray(sub_expr7, sub_expr8, [ExprRange(sub_expr1, Output(state = ScalarMult(frac(one, sqrt(two)), VecAdd(ket0, ScalarMult(Exp(e, Mult(two, pi, i, Exp(two, Neg(sub_expr1)), _phase)), ket1)))), Add(Neg(t), one), zero).with_decreasing_order(), sub_expr6])), Qcircuit(vert_expr_array = VertExprArray(sub_expr7, sub_expr8, [ExprRange(sub_expr1, MultiQubitElem(element = Output(state = _psi_t_ket, part = sub_expr1), targets = Interval(one, t)), one, t), sub_expr6])))
expr:
In [3]:
# check that the built expression is the same as the stored expression
assert expr == stored_expr
assert expr._style_id == stored_expr._style_id
print("Passed sanity check: expr matches stored_expr")
Passed sanity check: expr matches stored_expr
In [4]:
# Show the LaTeX representation of the expression for convenience if you need it.
print(stored_expr.latex())
\left(\begin{array}{c} \Qcircuit@C=1em @R=.7em{
\qin{\lvert + \rangle} & \multigate{4}{\textrm{QPE}_1\left(U, t\right)} & \qout{\frac{1}{\sqrt{2}} \cdot \left(\lvert 0 \rangle + \left(\mathsf{e}^{2 \cdot \pi \cdot \mathsf{i} \cdot 2^{t - 1} \cdot \varphi} \cdot \lvert 1 \rangle\right)\right)} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \qout{\frac{1}{\sqrt{2}} \cdot \left(\lvert 0 \rangle + \left(\mathsf{e}^{2 \cdot \pi \cdot \mathsf{i} \cdot 2^{t - 2} \cdot \varphi} \cdot \lvert 1 \rangle\right)\right)} \\
\qin{\begin{array}{c}:\\ \left(t - 3\right) \times \\:\end{array}} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \qout{\vdots} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \qout{\frac{1}{\sqrt{2}} \cdot \left(\lvert 0 \rangle + \left(\mathsf{e}^{2 \cdot \pi \cdot \mathsf{i} \cdot 2^{0} \cdot \varphi} \cdot \lvert 1 \rangle\right)\right)} \\
\qin{\lvert u \rangle} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \qout{\lvert u \rangle}
} \end{array}\right) \cong \left(\begin{array}{c} \Qcircuit@C=1em @R=.7em{
\qin{\lvert + \rangle} & \multigate{4}{\textrm{QPE}_1\left(U, t\right)} & \multiqout{3}{\lvert \psi_{t} \rangle} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \ghostqout{\lvert \psi_{t} \rangle} \\
\qin{\begin{array}{c}:\\ \left(t - 3\right) \times \\:\end{array}} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \ghostqout{\lvert \psi_{t} \rangle} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \ghostqout{\lvert \psi_{t} \rangle} \\
\qin{\lvert u \rangle} & \ghost{\textrm{QPE}_1\left(U, t\right)} & \qout{\lvert u \rangle}
} \end{array}\right)
In [5]:
stored_expr.style_options()
namedescriptiondefaultcurrent valuerelated methods
operation'infix' or 'function' style formattinginfixinfix
wrap_positionsposition(s) at which wrapping is to occur; '2 n - 1' is after the nth operand, '2 n' is after the nth operation.()()('with_wrapping_at', 'with_wrap_before_operator', 'with_wrap_after_operator', 'without_wrapping', 'wrap_positions')
justificationif any wrap positions are set, justify to the 'left', 'center', or 'right'centercenter('with_justification',)
directionDirection of the relation (normal or reversed)normalnormal('with_direction_reversed', 'is_reversed')
In [6]:
# display the expression information
stored_expr.expr_info()
 core typesub-expressionsexpression
0Operationoperator: 1
operands: 2
1Literal
2ExprTuple3, 4
3Operationoperator: 6
operands: 5
4Operationoperator: 6
operands: 7
5ExprTuple9, 10, 8
6Literal
7ExprTuple9, 10, 11
8ExprTuple12, 18
9ExprTuple13, 14
10ExprTuple15, 16
11ExprTuple17, 18
12ExprRangelambda_map: 19
start_index: 20
end_index: 91
13ExprRangelambda_map: 21
start_index: 101
end_index: 84
14ExprRangelambda_map: 22
start_index: 101
end_index: 85
15ExprRangelambda_map: 23
start_index: 101
end_index: 84
16ExprRangelambda_map: 23
start_index: 68
end_index: 69
17ExprRangelambda_map: 24
start_index: 101
end_index: 84
18ExprRangelambda_map: 25
start_index: 101
end_index: 85
19Lambdaparameter: 114
body: 26
20Operationoperator: 78
operands: 27
21Lambdaparameter: 114
body: 28
22Lambdaparameter: 114
body: 29
23Lambdaparameter: 114
body: 30
24Lambdaparameter: 114
body: 31
25Lambdaparameter: 114
body: 32
26Operationoperator: 58
operands: 33
27ExprTuple34, 101
28Operationoperator: 52
operands: 35
29Operationoperator: 39
operands: 36
30Operationoperator: 39
operands: 37
31Operationoperator: 39
operands: 38
32Operationoperator: 39
operands: 40
33NamedExprsstate: 41
34Operationoperator: 112
operand: 84
35NamedExprsstate: 42
36NamedExprselement: 43
targets: 49
37NamedExprselement: 44
targets: 45
38NamedExprselement: 46
targets: 47
39Literal
40NamedExprselement: 48
targets: 49
41Operationoperator: 88
operands: 50
42Operationoperator: 97
operand: 64
43Operationoperator: 52
operands: 59
44Operationoperator: 53
operands: 54
45Operationoperator: 60
operands: 55
46Operationoperator: 58
operands: 56
47Operationoperator: 60
operands: 57
48Operationoperator: 58
operands: 59
49Operationoperator: 60
operands: 61
50ExprTuple62, 63
51ExprTuple64
52Literal
53Literal
54NamedExprsoperation: 65
part: 114
55ExprTuple101, 69
56NamedExprsstate: 66
part: 114
57ExprTuple101, 84
58Literal
59NamedExprsstate: 67
part: 114
60Literal
61ExprTuple68, 69
62Operationoperator: 94
operands: 70
63Operationoperator: 71
operands: 72
64Literal
65Operationoperator: 73
operands: 74
66Operationoperator: 75
operand: 84
67Literal
68Operationoperator: 78
operands: 77
69Operationoperator: 78
operands: 79
70ExprTuple101, 80
71Literal
72ExprTuple81, 82
73Literal
74ExprTuple83, 84
75Literal
76ExprTuple84
77ExprTuple84, 101
78Literal
79ExprTuple84, 85
80Operationoperator: 108
operands: 86
81Operationoperator: 97
operand: 91
82Operationoperator: 88
operands: 89
83Literal
84Variable
85Literal
86ExprTuple110, 90
87ExprTuple91
88Literal
89ExprTuple92, 93
90Operationoperator: 94
operands: 95
91Literal
92Operationoperator: 108
operands: 96
93Operationoperator: 97
operand: 101
94Literal
95ExprTuple101, 110
96ExprTuple99, 100
97Literal
98ExprTuple101
99Literal
100Operationoperator: 102
operands: 103
101Literal
102Literal
103ExprTuple110, 104, 105, 106, 107
104Literal
105Literal
106Operationoperator: 108
operands: 109
107Literal
108Literal
109ExprTuple110, 111
110Literal
111Operationoperator: 112
operand: 114
112Literal
113ExprTuple114
114Variable