Apply
(bitand-values val1 val2) → resval
It is an error if the values are not integers. If they are integers, we perform the usual arithmetic conversions and then we call the operation on integer values.
Function:
(defun bitand-values (val1 val2) (declare (xargs :guard (and (valuep val1) (valuep val2)))) (let ((__function__ 'bitand-values)) (declare (ignorable __function__)) (if (and (value-integerp val1) (value-integerp val2)) (b* (((mv val1 val2) (uaconvert-values val1 val2))) (bitand-integer-values val1 val2)) (error (list :bitand-mistype :required :integer :integer :supplied (value-fix val1) (value-fix val2))))))
Theorem:
(defthm value-resultp-of-bitand-values (b* ((resval (bitand-values val1 val2))) (value-resultp resval)) :rule-classes :rewrite)
Theorem:
(defthm bitand-values-of-value-fix-val1 (equal (bitand-values (value-fix val1) val2) (bitand-values val1 val2)))
Theorem:
(defthm bitand-values-value-equiv-congruence-on-val1 (implies (value-equiv val1 val1-equiv) (equal (bitand-values val1 val2) (bitand-values val1-equiv val2))) :rule-classes :congruence)
Theorem:
(defthm bitand-values-of-value-fix-val2 (equal (bitand-values val1 (value-fix val2)) (bitand-values val1 val2)))
Theorem:
(defthm bitand-values-value-equiv-congruence-on-val2 (implies (value-equiv val2 val2-equiv) (equal (bitand-values val1 val2) (bitand-values val1 val2-equiv))) :rule-classes :congruence)