(aabf-logapp-nss-aux n a b) → a-app-b
Function:
(defun aabf-logapp-nss-aux (n a b) (declare (xargs :guard (and (natp n) (true-listp a) (true-listp b)))) (declare (xargs :guard (and))) (let ((__function__ 'aabf-logapp-nss-aux)) (declare (ignorable __function__)) (b* (((when (zp n)) (llist-fix b)) ((mv first rest &) (aabf-first/rest/end a))) (aabf-scons first (aabf-logapp-nss-aux (1- n) rest b)))))
Theorem:
(defthm trivial-theorem-about-aabf-logapp-nss-aux (b* nil (b* ((?ignore (aabf-logapp-nss-aux n a b))) t)) :rule-classes nil)
Theorem:
(defthm true-listp-of-aabf-logapp-nss-aux.a-app-b (b* ((?a-app-b (aabf-logapp-nss-aux n a b))) (true-listp a-app-b)) :rule-classes :type-prescription)
Theorem:
(defthm aabf-p-of-aabf-logapp-nss-aux (b* ((a-app-b (aabf-logapp-nss-aux n a b))) (implies (and (aabflist-p a man) (aabflist-p b man)) (and (aabflist-p a-app-b man)))))
Theorem:
(defthm aabf-eval-of-aabf-logapp-nss-aux (b* ((a-app-b (aabf-logapp-nss-aux n a b))) (implies (and (aabflist-p a man) (aabflist-p b man)) (and (equal (bools->int (aabflist-eval a-app-b env man)) (logapp (nfix n) (bools->int (aabflist-eval a env man)) (bools->int (aabflist-eval b env man))))))))
Theorem:
(defthm aabf-pred-of-aabf-logapp-nss-aux (b* ((a-app-b (aabf-logapp-nss-aux n a b))) (implies (and (aabflist-p a man) (aabflist-p b man) (aabflist-pred a man) (aabflist-pred b man)) (and (aabflist-pred a-app-b man)))))