logo
In [1]:
import proveit
theory = proveit.Theory() # the theorem's theory
from proveit import defaults
from proveit.logic import Implies
from proveit.logic.sets.comprehension import comprehension_def
In [2]:
%proving fold
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
fold:
(see dependencies)
In [3]:
defaults.assumptions = fold.conditions
defaults.assumptions:
In [4]:
comprehension_def
In [5]:
comprehension_def_inst = comprehension_def.instantiate().instantiate()
comprehension_def_inst:  ⊢  
In [6]:
exists_eq_impl = Implies(comprehension_def_inst.rhs, comprehension_def_inst.rhs).prove()
exists_eq_impl:  ⊢  
In [7]:
exists_eq_impl.inner_expr().rhs.substitute(comprehension_def_inst.derive_reversed())
fold may now be readily provable (assuming required theorems are usable).  Simply execute "%qed".
In [8]:
%qed
proveit.logic.sets.comprehension.fold has been proven.
Out[8]:
 step typerequirementsstatement
0generalization1  ⊢  
1instantiation2, 3, 4  ⊢  
  : , : , :
2theorem  ⊢  
 proveit.logic.equality.sub_left_side_into
3instantiation5  ⊢  
  :
4instantiation6, 7  ⊢  
  :
5theorem  ⊢  
 proveit.logic.booleans.implication.self_implication
6axiom  ⊢  
 proveit.logic.sets.comprehension.comprehension_def
7assumption  ⊢