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