Read an element from an array of type
(slong-array-integer-read array index) → element
Function:
(defun slong-array-integer-read (array index) (declare (xargs :guard (and (slong-arrayp array) (integerp index)))) (declare (xargs :guard (slong-array-integer-index-okp array index))) (let ((__function__ 'slong-array-integer-read)) (declare (ignorable __function__)) (slong-fix (nth index (slong-array->elements array)))))
Theorem:
(defthm slongp-of-slong-array-integer-read (b* ((element (slong-array-integer-read array index))) (slongp element)) :rule-classes :rewrite)
Theorem:
(defthm slong-array-integer-read-of-slong-array-fix-array (equal (slong-array-integer-read (slong-array-fix array) index) (slong-array-integer-read array index)))
Theorem:
(defthm slong-array-integer-read-slong-array-equiv-congruence-on-array (implies (slong-array-equiv array array-equiv) (equal (slong-array-integer-read array index) (slong-array-integer-read array-equiv index))) :rule-classes :congruence)
Theorem:
(defthm slong-array-integer-read-of-ifix-index (equal (slong-array-integer-read array (ifix index)) (slong-array-integer-read array index)))
Theorem:
(defthm slong-array-integer-read-int-equiv-congruence-on-index (implies (acl2::int-equiv index index-equiv) (equal (slong-array-integer-read array index) (slong-array-integer-read array index-equiv))) :rule-classes :congruence)
Theorem:
(defthm slong-array-integer-read-alt-def (implies (and (slong-arrayp array) (integerp index) (slong-array-integer-index-okp array index)) (equal (slong-array-integer-read array index) (value-array-read index array))))