logo
In [1]:
import proveit
from proveit import defaults
theory = proveit.Theory() # the theorem's theory
In [2]:
%proving num_ket_eq
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
num_ket_eq:
(see dependencies)
num_ket_eq may now be readily provable (assuming required theorems are usable).  Simply execute "%qed".
In [3]:
defaults.assumptions = num_ket_eq.all_conditions()
defaults.assumptions:
In [4]:
j_eq_k = defaults.assumptions[0]
j_eq_k:
In [5]:
j_ket = num_ket_eq.instance_expr.instance_expr.lhs
j_ket:
In [6]:
j_eq_k.substitution(j_ket)
In [7]:
%qed
proveit.physics.quantum.algebra.num_ket_eq has been proven.
Out[7]:
 step typerequirementsstatement
0generalization1  ⊢  
1instantiation2, 3  ⊢  
  : , : , :
2axiom  ⊢  
 proveit.logic.equality.substitution
3assumption  ⊢