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, ExprTuple, Lambda, U, i, j, n
from proveit.core_expr_types import v_i, v_j
from proveit.linear_algebra import Adj
from proveit.logic import And, Equals, InSet
from proveit.numbers import Interval, KroneckerDelta, one
from proveit.physics.quantum import Bra, Ket, Qmult
# build up the expression from sub-expressions
sub_expr1 = Interval(one, n)
expr = ExprTuple(Lambda([i, j], Conditional(Equals(Qmult(Bra(v_i), Adj(U), U, Ket(v_j)), KroneckerDelta(i, j)), And(InSet(i, sub_expr1), InSet(j, sub_expr1)))))
# 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")
# Show the LaTeX representation of the expression for convenience if you need it.
print(stored_expr.latex())
stored_expr.style_options()
# display the expression information
stored_expr.expr_info()