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