logo

Expression of type Equals

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, e, l
from proveit.logic import Equals, Union
from proveit.numbers import Add, Interval, ModAbs, greater, one
from proveit.physics.quantum import NumKet, Z, ket_plus
from proveit.physics.quantum.QPE import ModAdd, QPE, _U, _b_floor, _ket_u, _neg_domain, _pos_domain, _s, _s_wire, _t, _two_pow_t
from proveit.physics.quantum.circuits import Gate, Input, Measure, MultiQubitElem, Output, Qcircuit
from proveit.statistics import ProbOfAll
In [2]:
# build up the expression from sub-expressions
sub_expr1 = Variable("_a", latex_format = r"{_{-}a}")
sub_expr2 = [l]
sub_expr3 = Add(_t, one)
sub_expr4 = Add(_t, _s)
sub_expr5 = Interval(sub_expr3, sub_expr4)
sub_expr6 = MultiQubitElem(element = Gate(operation = QPE(_U, _t), part = sub_expr1), targets = Interval(one, sub_expr4))
sub_expr7 = Qcircuit(vert_expr_array = VertExprArray([ExprRange(sub_expr1, Input(state = ket_plus), one, _t), ExprRange(sub_expr1, MultiQubitElem(element = Input(state = _ket_u, part = sub_expr1), targets = sub_expr5), one, _s)], [ExprRange(sub_expr1, sub_expr6, one, _t), ExprRange(sub_expr1, sub_expr6, sub_expr3, sub_expr4)], [ExprRange(sub_expr1, Measure(basis = Z), one, _t), _s_wire], [ExprRange(sub_expr1, MultiQubitElem(element = Output(state = NumKet(ModAdd(_b_floor, l), _t), part = sub_expr1), targets = Interval(one, _t)), one, _t), ExprRange(sub_expr1, MultiQubitElem(element = Output(state = _ket_u, part = sub_expr1), targets = sub_expr5), one, _s)]))
expr = Equals(ProbOfAll(instance_param_or_params = sub_expr2, instance_element = sub_expr7, domain = Union(_neg_domain, _pos_domain), condition = greater(ModAbs(l, _two_pow_t), e)), Add(Variable("_b", latex_format = r"{_{-}b}"), ProbOfAll(instance_param_or_params = sub_expr2, instance_element = sub_expr7, domain = _pos_domain))).with_wrapping_at(2)
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())
\begin{array}{c} \begin{array}{l} \left[\textrm{Prob}_{l \in \{-2^{t - 1} + 1~\ldotp \ldotp~-\left(e + 1\right)\} \cup \{e + 1~\ldotp \ldotp~2^{t - 1}\}~|~\left|l\right|_{\textup{mod}\thinspace 2^{t}} > e}~\left(\begin{array}{c} \Qcircuit@C=1em @R=.7em{
\qin{\lvert + \rangle} & \multigate{4}{\textrm{QPE}\left(U, t\right)} & \meter & \multiqout{3}{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\begin{array}{c}:\\ \left(t - 3\right) \times \\:\end{array}} & \ghost{\textrm{QPE}\left(U, t\right)} & \measure{\begin{array}{c}:\\ \left(t - 3\right) \times \\:\end{array}} \qw & \ghostqout{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\lvert u \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & { /^{s} } \qw & \qout{\lvert u \rangle}
} \end{array}\right)\right] =  \\ \left({_{-}b} + \left[\textrm{Prob}_{l \in \{e + 1~\ldotp \ldotp~2^{t - 1}\}}~\left(\begin{array}{c} \Qcircuit@C=1em @R=.7em{
\qin{\lvert + \rangle} & \multigate{4}{\textrm{QPE}\left(U, t\right)} & \meter & \multiqout{3}{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\begin{array}{c}:\\ \left(t - 3\right) \times \\:\end{array}} & \ghost{\textrm{QPE}\left(U, t\right)} & \measure{\begin{array}{c}:\\ \left(t - 3\right) \times \\:\end{array}} \qw & \ghostqout{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert b_{\textit{f}} \oplus l \rangle_{t}} \\
\qin{\lvert u \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & { /^{s} } \qw & \qout{\lvert u \rangle}
} \end{array}\right)\right]\right) \end{array} \end{array}
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.()(2)('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: 11
operand: 7
4Operationoperator: 132
operands: 6
5ExprTuple7
6ExprTuple8, 9
7Lambdaparameter: 135
body: 10
8Variable
9Operationoperator: 11
operand: 14
10Conditionalvalue: 21
condition: 13
11Literal
12ExprTuple14
13Operationoperator: 15
operands: 16
14Lambdaparameter: 135
body: 18
15Literal
16ExprTuple19, 20
17ExprTuple135
18Conditionalvalue: 21
condition: 22
19Operationoperator: 28
operands: 23
20Operationoperator: 24
operands: 25
21Operationoperator: 26
operands: 27
22Operationoperator: 28
operands: 29
23ExprTuple135, 30
24Literal
25ExprTuple116, 31
26Literal
27ExprTuple32, 33, 34, 35
28Literal
29ExprTuple135, 49
30Operationoperator: 36
operands: 37
31Operationoperator: 38
operands: 39
32ExprTuple40, 41
33ExprTuple42, 43
34ExprTuple44, 45
35ExprTuple46, 47
36Literal
37ExprTuple48, 49
38Literal
39ExprTuple135, 50
40ExprRangelambda_map: 51
start_index: 140
end_index: 136
41ExprRangelambda_map: 52
start_index: 140
end_index: 127
42ExprRangelambda_map: 53
start_index: 140
end_index: 136
43ExprRangelambda_map: 53
start_index: 113
end_index: 114
44ExprRangelambda_map: 54
start_index: 140
end_index: 136
45ExprRangelambda_map: 55
start_index: 140
end_index: 127
46ExprRangelambda_map: 56
start_index: 140
end_index: 136
47ExprRangelambda_map: 57
start_index: 140
end_index: 127
48Operationoperator: 104
operands: 58
49Operationoperator: 104
operands: 59
50Operationoperator: 123
operands: 60
51Lambdaparameter: 112
body: 61
52Lambdaparameter: 112
body: 62
53Lambdaparameter: 112
body: 63
54Lambdaparameter: 112
body: 64
55Lambdaparameter: 112
body: 65
56Lambdaparameter: 112
body: 66
57Lambdaparameter: 112
body: 68
58ExprTuple69, 70
59ExprTuple93, 115
60ExprTuple128, 136
61Operationoperator: 96
operands: 71
62Operationoperator: 78
operands: 72
63Operationoperator: 78
operands: 73
64Operationoperator: 74
operands: 75
65Operationoperator: 97
operands: 76
66Operationoperator: 78
operands: 77
67ExprTuple112
68Operationoperator: 78
operands: 79
69Operationoperator: 132
operands: 80
70Operationoperator: 138
operand: 93
71NamedExprsstate: 82
72NamedExprselement: 83
targets: 91
73NamedExprselement: 84
targets: 85
74Literal
75NamedExprsbasis: 86
76NamedExprsoperation: 87
77NamedExprselement: 88
targets: 89
78Literal
79NamedExprselement: 90
targets: 91
80ExprTuple92, 140
81ExprTuple93
82Operationoperator: 94
operand: 108
83Operationoperator: 96
operands: 103
84Operationoperator: 97
operands: 98
85Operationoperator: 104
operands: 99
86Literal
87Literal
88Operationoperator: 102
operands: 100
89Operationoperator: 104
operands: 101
90Operationoperator: 102
operands: 103
91Operationoperator: 104
operands: 105
92Operationoperator: 138
operand: 115
93Operationoperator: 132
operands: 107
94Literal
95ExprTuple108
96Literal
97Literal
98NamedExprsoperation: 109
part: 112
99ExprTuple140, 114
100NamedExprsstate: 110
part: 112
101ExprTuple140, 136
102Literal
103NamedExprsstate: 111
part: 112
104Literal
105ExprTuple113, 114
106ExprTuple115
107ExprTuple116, 140
108Literal
109Operationoperator: 117
operands: 118
110Operationoperator: 119
operands: 120
111Literal
112Variable
113Operationoperator: 132
operands: 121
114Operationoperator: 132
operands: 122
115Operationoperator: 123
operands: 124
116Variable
117Literal
118ExprTuple125, 136
119Literal
120ExprTuple126, 136
121ExprTuple136, 140
122ExprTuple136, 127
123Literal
124ExprTuple128, 129
125Literal
126Operationoperator: 130
operands: 131
127Literal
128Literal
129Operationoperator: 132
operands: 133
130Literal
131ExprTuple134, 135
132Literal
133ExprTuple136, 137
134Literal
135Variable
136Literal
137Operationoperator: 138
operand: 140
138Literal
139ExprTuple140
140Literal