(sv::aig-truncate-ss a b) → tr
Function:
(defun sv::aig-truncate-ss (a b) (declare (xargs :guard (and (true-listp a) (true-listp b)))) (let ((__function__ 'sv::aig-truncate-ss)) (declare (ignorable __function__)) (sv::aig-ite-bss (sv::aig-=-ss b nil) nil (b* (((mv bsign babs bneg) (sv::aig-sign-abs-not-s b)) ((mv asign aabs &) (sv::aig-sign-abs-not-s a)) ((mv f &) (sv::aig-floor-ss-aux aabs babs bneg))) (sv::aig-ite-bss (acl2::aig-xor bsign asign) (sv::aig-unary-minus-s f) f)))))
Theorem:
(defthm sv::true-listp-of-aig-truncate-ss (b* ((tr (sv::aig-truncate-ss a b))) (true-listp tr)) :rule-classes :type-prescription)
Theorem:
(defthm sv::aig-truncate-ss-correct (b* ((tr (sv::aig-truncate-ss a b))) (and (equal (sv::aig-list->s tr env) (truncate (sv::aig-list->s a env) (sv::aig-list->s b env))))))