logo

Expression of type SubsetEq

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, IndexedVar, Variable, VertExprArray, e, m
from proveit.logic import SetOfAll, SubsetEq
from proveit.numbers import Add, Interval, ModAbs, greater, one, subtract
from proveit.physics.quantum import NumKet, Z, ket_plus
from proveit.physics.quantum.QPE import QPE, _U, _b_floor, _ket_u, _m_domain, _phase_est_circuit, _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 = IndexedVar(m, one)
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))
expr = SubsetEq(SetOfAll(instance_param_or_params = [m], instance_element = _phase_est_circuit, domain = _m_domain, condition = greater(ModAbs(subtract(m, _b_floor), _two_pow_t), e)), SetOfAll(instance_param_or_params = [sub_expr2], instance_element = 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(sub_expr2, _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)])), domain = _m_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\{\left(\begin{array}{c} \Qcircuit@C=1em @R=.7em{
\qin{\lvert + \rangle} & \multigate{4}{\textrm{QPE}\left(U, t\right)} & \meter & \multiqout{3}{\lvert m \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert m \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 m \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert m \rangle_{t}} \\
\qin{\lvert u \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & { /^{s} } \qw & \qout{\lvert u \rangle}
} \end{array}\right)~|~\left|m - b_{\textit{f}}\right|_{\textup{mod}\thinspace 2^{t}} > e\right\}_{m \in \{0~\ldotp \ldotp~2^{t} - 1\}} \subseteq  \\ \left\{\begin{array}{c} \Qcircuit@C=1em @R=.7em{
\qin{\lvert + \rangle} & \multigate{4}{\textrm{QPE}\left(U, t\right)} & \meter & \multiqout{3}{\lvert m_{1} \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert m_{1} \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 m_{1} \rangle_{t}} \\
\qin{\lvert + \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & \meter & \ghostqout{\lvert m_{1} \rangle_{t}} \\
\qin{\lvert u \rangle} & \ghost{\textrm{QPE}\left(U, t\right)} & { /^{s} } \qw & \qout{\lvert u \rangle}
} \end{array}\right\}_{m_{1} \in \{0~\ldotp \ldotp~2^{t} - 1\}} \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: 6
operand: 8
4Operationoperator: 6
operand: 9
5ExprTuple8
6Literal
7ExprTuple9
8Lambdaparameter: 135
body: 11
9Lambdaparameter: 132
body: 13
10ExprTuple135
11Conditionalvalue: 14
condition: 15
12ExprTuple132
13Conditionalvalue: 16
condition: 17
14Operationoperator: 21
operands: 18
15Operationoperator: 19
operands: 20
16Operationoperator: 21
operands: 22
17Operationoperator: 32
operands: 23
18ExprTuple27, 28, 29, 24
19Literal
20ExprTuple25, 26
21Literal
22ExprTuple27, 28, 29, 30
23ExprTuple132, 45
24ExprTuple31, 43
25Operationoperator: 32
operands: 33
26Operationoperator: 34
operands: 35
27ExprTuple36, 37
28ExprTuple38, 39
29ExprTuple40, 41
30ExprTuple42, 43
31ExprRangelambda_map: 44
start_index: 137
end_index: 133
32Literal
33ExprTuple135, 45
34Literal
35ExprTuple46, 47
36ExprRangelambda_map: 48
start_index: 137
end_index: 133
37ExprRangelambda_map: 49
start_index: 137
end_index: 134
38ExprRangelambda_map: 50
start_index: 137
end_index: 133
39ExprRangelambda_map: 50
start_index: 119
end_index: 120
40ExprRangelambda_map: 51
start_index: 137
end_index: 133
41ExprRangelambda_map: 52
start_index: 137
end_index: 134
42ExprRangelambda_map: 53
start_index: 137
end_index: 133
43ExprRangelambda_map: 54
start_index: 137
end_index: 134
44Lambdaparameter: 118
body: 55
45Operationoperator: 107
operands: 56
46Variable
47Operationoperator: 57
operands: 58
48Lambdaparameter: 118
body: 59
49Lambdaparameter: 118
body: 60
50Lambdaparameter: 118
body: 61
51Lambdaparameter: 118
body: 62
52Lambdaparameter: 118
body: 63
53Lambdaparameter: 118
body: 64
54Lambdaparameter: 118
body: 66
55Operationoperator: 78
operands: 67
56ExprTuple68, 69
57Literal
58ExprTuple70, 94
59Operationoperator: 99
operands: 71
60Operationoperator: 78
operands: 72
61Operationoperator: 78
operands: 73
62Operationoperator: 74
operands: 75
63Operationoperator: 100
operands: 76
64Operationoperator: 78
operands: 77
65ExprTuple118
66Operationoperator: 78
operands: 79
67NamedExprselement: 80
targets: 90
68Literal
69Operationoperator: 129
operands: 81
70Operationoperator: 129
operands: 82
71NamedExprsstate: 83
72NamedExprselement: 84
targets: 92
73NamedExprselement: 85
targets: 86
74Literal
75NamedExprsbasis: 87
76NamedExprsoperation: 88
77NamedExprselement: 89
targets: 90
78Literal
79NamedExprselement: 91
targets: 92
80Operationoperator: 105
operands: 93
81ExprTuple94, 95
82ExprTuple135, 96
83Operationoperator: 97
operand: 114
84Operationoperator: 99
operands: 106
85Operationoperator: 100
operands: 101
86Operationoperator: 107
operands: 102
87Literal
88Literal
89Operationoperator: 105
operands: 103
90Operationoperator: 107
operands: 104
91Operationoperator: 105
operands: 106
92Operationoperator: 107
operands: 108
93NamedExprsstate: 109
part: 118
94Operationoperator: 110
operands: 111
95Operationoperator: 112
operand: 137
96Operationoperator: 112
operand: 123
97Literal
98ExprTuple114
99Literal
100Literal
101NamedExprsoperation: 115
part: 118
102ExprTuple137, 120
103NamedExprsstate: 116
part: 118
104ExprTuple137, 133
105Literal
106NamedExprsstate: 117
part: 118
107Literal
108ExprTuple119, 120
109Operationoperator: 126
operands: 121
110Literal
111ExprTuple122, 133
112Literal
113ExprTuple123
114Literal
115Operationoperator: 124
operands: 125
116Operationoperator: 126
operands: 127
117Literal
118Variable
119Operationoperator: 129
operands: 128
120Operationoperator: 129
operands: 130
121ExprTuple135, 133
122Literal
123Literal
124Literal
125ExprTuple131, 133
126Literal
127ExprTuple132, 133
128ExprTuple133, 137
129Literal
130ExprTuple133, 134
131Literal
132IndexedVarvariable: 135
index: 137
133Literal
134Literal
135Variable
136ExprTuple137
137Literal