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