Check if an ACL2 integer is
a valid index (i.e. in range)
for an array of type
(sint-array-integer-index-okp array index) → yes/no
Function:
(defun sint-array-integer-index-okp (array index) (declare (xargs :guard (and (sint-arrayp array) (integerp index)))) (let ((__function__ 'sint-array-integer-index-okp)) (declare (ignorable __function__)) (integer-range-p 0 (sint-array-length array) (ifix index))))
Theorem:
(defthm booleanp-of-sint-array-integer-index-okp (b* ((yes/no (sint-array-integer-index-okp array index))) (booleanp yes/no)) :rule-classes :rewrite)
Theorem:
(defthm sint-array-integer-index-okp-of-sint-array-fix-array (equal (sint-array-integer-index-okp (sint-array-fix array) index) (sint-array-integer-index-okp array index)))
Theorem:
(defthm sint-array-integer-index-okp-sint-array-equiv-congruence-on-array (implies (sint-array-equiv array array-equiv) (equal (sint-array-integer-index-okp array index) (sint-array-integer-index-okp array-equiv index))) :rule-classes :congruence)
Theorem:
(defthm sint-array-integer-index-okp-of-ifix-index (equal (sint-array-integer-index-okp array (ifix index)) (sint-array-integer-index-okp array index)))
Theorem:
(defthm sint-array-integer-index-okp-int-equiv-congruence-on-index (implies (acl2::int-equiv index index-equiv) (equal (sint-array-integer-index-okp array index) (sint-array-integer-index-okp array index-equiv))) :rule-classes :congruence)