logo
In [1]:
import proveit
from proveit import defaults
from proveit import x, y
from proveit.logic.equality  import equals_symmetry
theory = proveit.Theory() # the theorem's theory
In [2]:
%proving equals_reversal
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
equals_reversal:
(see dependencies)
equals_reversal may now be readily provable (assuming required theorems are usable).  Simply execute "%qed".
In [3]:
defaults.assumptions = equals_reversal.all_conditions()
defaults.assumptions:
In [4]:
equals_symmetry
In [5]:
eq_sym = equals_symmetry.instantiate({x:x, y:y})
eq_sym:  ⊢  
In [6]:
eq_sym.derive_left_via_equality()
In [7]:
%qed
proveit.logic.equality.equals_reversal has been proven.
Out[7]:
 step typerequirementsstatement
0generalization1  ⊢  
1instantiation2, 3, 4  ⊢  
  : , :
2theorem  ⊢  
 proveit.logic.equality.lhs_via_equality
3assumption  ⊢  
4instantiation5  ⊢  
  : , :
5axiom  ⊢  
 proveit.logic.equality.equals_symmetry