logo
In [1]:
import proveit
from proveit import defaults
from proveit.numbers.numerals import DecimalSequence
theory = proveit.Theory() # the theorem's theory
In [2]:
%proving deci_sequence_reduction
With these allowed/disallowed theorem/theory presumptions (e.g., to avoid circular dependencies), we begin our proof of
deci_sequence_reduction:
(see dependencies)
In [3]:
defaults.assumptions = deci_sequence_reduction.all_conditions()
defaults.assumptions:
In [4]:
equality = defaults.assumptions[-1]
equality:
In [5]:
lhs = deci_sequence_reduction.instance_expr.instance_expr.lhs
lhs:
In [6]:
rhs = deci_sequence_reduction.instance_expr.instance_expr.rhs
rhs:
In [7]:
equality.substitution(lhs.inner_expr().operands[1])
deci_sequence_reduction may now be readily provable (assuming required theorems are usable).  Simply execute "%qed".
In [8]:
%qed
proveit.numbers.numerals.decimals.deci_sequence_reduction has been proven.
Out[8]:
 step typerequirementsstatement
0generalization1  ⊢  
1instantiation2, 3  ⊢  
  : , : , :
2axiom  ⊢  
 proveit.logic.equality.substitution
3assumption  ⊢