logo
In [1]:
import proveit
from proveit import A
from proveit.logic import Not
from proveit.logic.booleans.negation import closure
theory = proveit.Theory() # the theorem's theory
In [2]:
%proving double_neg_closure
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
double_neg_closure:
(see dependencies)
double_neg_closure may now be readily provable (assuming required theorems are usable).  Simply execute "%qed".
In [3]:
closure
In [4]:
closure.instantiate({A:Not(A)}, assumptions=double_neg_closure.conditions)
In [5]:
%qed
proveit.logic.booleans.negation.double_neg_closure has been proven.
Out[5]:
 step typerequirementsstatement
0generalization1  ⊢  
1instantiation3, 2  ⊢  
  :
2instantiation3, 4  ⊢  
  :
3conjecture  ⊢  
 proveit.logic.booleans.negation.closure
4assumption  ⊢