Greater-than-or-equal-to comparison of unsigned integer values.
Function:
(defun uint-ge (left right) (declare (xargs :guard (and (uintp left) (uintp right)))) (declare (xargs :guard (= (uint->size left) (uint->size right)))) (b* ((x (uint->value left)) (y (uint->value right))) (bool (>= x y))))
Theorem:
(defthm boolp-of-uint-ge (b* ((result (uint-ge left right))) (boolp result)) :rule-classes :rewrite)
Theorem:
(defthm uint-ge-of-uint-fix-left (equal (uint-ge (uint-fix left) right) (uint-ge left right)))
Theorem:
(defthm uint-ge-uint-equiv-congruence-on-left (implies (uint-equiv left left-equiv) (equal (uint-ge left right) (uint-ge left-equiv right))) :rule-classes :congruence)
Theorem:
(defthm uint-ge-of-uint-fix-right (equal (uint-ge left (uint-fix right)) (uint-ge left right)))
Theorem:
(defthm uint-ge-uint-equiv-congruence-on-right (implies (uint-equiv right right-equiv) (equal (uint-ge left right) (uint-ge left right-equiv))) :rule-classes :congruence)