logo

Expression of type Implies

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 Conditional, ExprRange, Lambda, Variable, VertExprArray, e, l
from proveit.logic import And, Equals, Forall, Implies, InSet, 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, _full_domain, _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
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 = QPE(_U, _t), part = sub_expr1), targets = Interval(one, sub_expr3))
sub_expr6 = greater(ModAbs(l, _two_pow_t), e)
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_expr4), one, _s)], [ExprRange(sub_expr1, sub_expr5, one, _t), ExprRange(sub_expr1, sub_expr5, sub_expr2, sub_expr3)], [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_expr4), one, _s)]))
sub_expr8 = Conditional(sub_expr7, And(InSet(l, _full_domain), sub_expr6))
sub_expr9 = Conditional(sub_expr7, And(InSet(l, Union(_neg_domain, _pos_domain)), sub_expr6))
expr = Implies(Forall(instance_param_or_params = [l], instance_expr = Equals(sub_expr9, sub_expr8)), Equals(Lambda(l, sub_expr9), Lambda(l, sub_expr8)).with_wrapping_at(2)).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[\forall_{l}~\left(\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} \textrm{ if } l \in \left(\{-2^{t - 1} + 1~\ldotp \ldotp~-\left(e + 1\right)\} \cup \{e + 1~\ldotp \ldotp~2^{t - 1}\}\right) ,  \left|l\right|_{\textup{mod}\thinspace 2^{t}} > e\right.. = \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} \textrm{ if } l \in \{-2^{t - 1} + 1~\ldotp \ldotp~2^{t - 1}\} ,  \left|l\right|_{\textup{mod}\thinspace 2^{t}} > e\right..\right)\right] \Rightarrow  \\ \left(\begin{array}{c} \begin{array}{l} \left[l \mapsto \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} \textrm{ if } l \in \left(\{-2^{t - 1} + 1~\ldotp \ldotp~-\left(e + 1\right)\} \cup \{e + 1~\ldotp \ldotp~2^{t - 1}\}\right) ,  \left|l\right|_{\textup{mod}\thinspace 2^{t}} > e\right..\right] =  \\ \left[l \mapsto \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} \textrm{ if } l \in \{-2^{t - 1} + 1~\ldotp \ldotp~2^{t - 1}\} ,  \left|l\right|_{\textup{mod}\thinspace 2^{t}} > e\right..\right] \end{array} \end{array}\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: 5
operand: 8
4Operationoperator: 13
operands: 7
5Literal
6ExprTuple8
7ExprTuple9, 10
8Lambdaparameter: 136
body: 11
9Lambdaparameter: 136
body: 15
10Lambdaparameter: 136
body: 16
11Operationoperator: 13
operands: 14
12ExprTuple136
13Literal
14ExprTuple15, 16
15Conditionalvalue: 18
condition: 17
16Conditionalvalue: 18
condition: 19
17Operationoperator: 23
operands: 20
18Operationoperator: 21
operands: 22
19Operationoperator: 23
operands: 24
20ExprTuple25, 31
21Literal
22ExprTuple26, 27, 28, 29
23Literal
24ExprTuple30, 31
25Operationoperator: 41
operands: 32
26ExprTuple33, 34
27ExprTuple35, 36
28ExprTuple37, 38
29ExprTuple39, 40
30Operationoperator: 41
operands: 42
31Operationoperator: 43
operands: 44
32ExprTuple136, 45
33ExprRangelambda_map: 46
start_index: 145
end_index: 141
34ExprRangelambda_map: 47
start_index: 145
end_index: 128
35ExprRangelambda_map: 48
start_index: 145
end_index: 141
36ExprRangelambda_map: 48
start_index: 114
end_index: 115
37ExprRangelambda_map: 49
start_index: 145
end_index: 141
38ExprRangelambda_map: 50
start_index: 145
end_index: 128
39ExprRangelambda_map: 51
start_index: 145
end_index: 141
40ExprRangelambda_map: 52
start_index: 145
end_index: 128
41Literal
42ExprTuple136, 53
43Literal
44ExprTuple130, 54
45Operationoperator: 55
operands: 56
46Lambdaparameter: 113
body: 57
47Lambdaparameter: 113
body: 58
48Lambdaparameter: 113
body: 59
49Lambdaparameter: 113
body: 60
50Lambdaparameter: 113
body: 61
51Lambdaparameter: 113
body: 62
52Lambdaparameter: 113
body: 64
53Operationoperator: 105
operands: 65
54Operationoperator: 66
operands: 67
55Literal
56ExprTuple68, 69
57Operationoperator: 97
operands: 70
58Operationoperator: 77
operands: 71
59Operationoperator: 77
operands: 72
60Operationoperator: 73
operands: 74
61Operationoperator: 98
operands: 75
62Operationoperator: 77
operands: 76
63ExprTuple113
64Operationoperator: 77
operands: 78
65ExprTuple93, 129
66Literal
67ExprTuple136, 79
68Operationoperator: 105
operands: 80
69Operationoperator: 105
operands: 81
70NamedExprsstate: 82
71NamedExprselement: 83
targets: 91
72NamedExprselement: 84
targets: 85
73Literal
74NamedExprsbasis: 86
75NamedExprsoperation: 87
76NamedExprselement: 88
targets: 89
77Literal
78NamedExprselement: 90
targets: 91
79Operationoperator: 133
operands: 92
80ExprTuple93, 94
81ExprTuple117, 129
82Operationoperator: 95
operand: 109
83Operationoperator: 97
operands: 104
84Operationoperator: 98
operands: 99
85Operationoperator: 105
operands: 100
86Literal
87Literal
88Operationoperator: 103
operands: 101
89Operationoperator: 105
operands: 102
90Operationoperator: 103
operands: 104
91Operationoperator: 105
operands: 106
92ExprTuple137, 141
93Operationoperator: 139
operands: 107
94Operationoperator: 143
operand: 117
95Literal
96ExprTuple109
97Literal
98Literal
99NamedExprsoperation: 110
part: 113
100ExprTuple145, 115
101NamedExprsstate: 111
part: 113
102ExprTuple145, 141
103Literal
104NamedExprsstate: 112
part: 113
105Literal
106ExprTuple114, 115
107ExprTuple116, 145
108ExprTuple117
109Literal
110Operationoperator: 118
operands: 119
111Operationoperator: 120
operands: 121
112Literal
113Variable
114Operationoperator: 139
operands: 122
115Operationoperator: 139
operands: 123
116Operationoperator: 143
operand: 129
117Operationoperator: 139
operands: 125
118Literal
119ExprTuple126, 141
120Literal
121ExprTuple127, 141
122ExprTuple141, 145
123ExprTuple141, 128
124ExprTuple129
125ExprTuple130, 145
126Literal
127Operationoperator: 131
operands: 132
128Literal
129Operationoperator: 133
operands: 134
130Variable
131Literal
132ExprTuple135, 136
133Literal
134ExprTuple137, 138
135Literal
136Variable
137Literal
138Operationoperator: 139
operands: 140
139Literal
140ExprTuple141, 142
141Literal
142Operationoperator: 143
operand: 145
143Literal
144ExprTuple145
145Literal