logo
In [1]:
import proveit
from proveit import A, B
from proveit.logic.sets.inclusion  import proper_subset_def
theory = proveit.Theory() # the theorem's theory
In [2]:
%proving fold_proper_subset
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
fold_proper_subset:
(see dependencies)
In [3]:
# pull in the proper subset definition
proper_subset_def
In [4]:
proper_subset_def_inst = proper_subset_def.instantiate()
proper_subset_def_inst:  ⊢  
In [5]:
proper_subset_def_inst_derive_left = proper_subset_def_inst.derive_left_via_equality(
        assumptions=[proper_subset_def_inst.rhs])
proper_subset_def_inst_derive_left:  ⊢  
In [6]:
proper_subset_def_inst_derive_left.generalize(
        [[A, B]], conditions=[*proper_subset_def_inst_derive_left.assumptions])
fold_proper_subset has been proven.  Now simply execute "%qed".
In [7]:
%qed
proveit.logic.sets.inclusion.fold_proper_subset has been proven.
Out[7]:
 step typerequirementsstatement
0generalization1  ⊢  
1instantiation2, 3, 4  ⊢  
  : , :
2theorem  ⊢  
 proveit.logic.equality.lhs_via_equality
3assumption  ⊢  
4instantiation5  ⊢  
  : , :
5axiom  ⊢  
 proveit.logic.sets.inclusion.proper_subset_def