logo
In [1]:
import proveit
from proveit import A, B
from proveit.logic import Boolean, InSet
from proveit.logic.sets.equivalence  import set_equiv_def
theory = proveit.Theory() # the theorem's theory
In [2]:
%proving set_equiv_is_bool
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
set_equiv_is_bool:
(see dependencies)
In [3]:
set_equiv_def
In [4]:
set_equiv_def_inst = set_equiv_def.instantiate()
set_equiv_def_inst:  ⊢  
In [5]:
set_equiv_in_bool_as_defined = set_equiv_def_inst.rhs.deduce_in_bool()
set_equiv_in_bool_as_defined:  ⊢  
In [6]:
set_equiv_def_inst.sub_left_side_into(set_equiv_in_bool_as_defined)
set_equiv_is_bool may now be readily provable (assuming required theorems are usable).  Simply execute "%qed".
In [7]:
%qed
proveit.logic.sets.equivalence.set_equiv_is_bool has been proven.
Out[7]: