(decompose-expression-aux i n expr) → exprs
Function:
(defun decompose-expression-aux (i n expr) (declare (xargs :guard (and (natp i) (natp n) (expressionp expr)))) (let ((__function__ 'decompose-expression-aux)) (declare (ignorable __function__)) (b* ((i (nfix i)) (n (nfix n))) (if (>= i n) nil (cons (make-expression-component :multi expr :index i) (decompose-expression-aux (1+ i) n expr))))))
Theorem:
(defthm expression-listp-of-decompose-expression-aux (b* ((exprs (decompose-expression-aux i n expr))) (expression-listp exprs)) :rule-classes :rewrite)
Theorem:
(defthm len-of-decompose-expression-aux (b* ((?exprs (decompose-expression-aux i n expr))) (equal (len exprs) (nfix (- (nfix n) (nfix i))))))
Theorem:
(defthm decompose-expression-aux-of-nfix-i (equal (decompose-expression-aux (nfix i) n expr) (decompose-expression-aux i n expr)))
Theorem:
(defthm decompose-expression-aux-nat-equiv-congruence-on-i (implies (nat-equiv i i-equiv) (equal (decompose-expression-aux i n expr) (decompose-expression-aux i-equiv n expr))) :rule-classes :congruence)
Theorem:
(defthm decompose-expression-aux-of-nfix-n (equal (decompose-expression-aux i (nfix n) expr) (decompose-expression-aux i n expr)))
Theorem:
(defthm decompose-expression-aux-nat-equiv-congruence-on-n (implies (nat-equiv n n-equiv) (equal (decompose-expression-aux i n expr) (decompose-expression-aux i n-equiv expr))) :rule-classes :congruence)
Theorem:
(defthm decompose-expression-aux-of-expression-fix-expr (equal (decompose-expression-aux i n (expression-fix expr)) (decompose-expression-aux i n expr)))
Theorem:
(defthm decompose-expression-aux-expression-equiv-congruence-on-expr (implies (expression-equiv expr expr-equiv) (equal (decompose-expression-aux i n expr) (decompose-expression-aux i n expr-equiv))) :rule-classes :congruence)