Get the bit-length for a particular input simulation variable.
(stv-in->width x stv) → width
For instance, if you have an STV input line like:
("a_bus" _ _ _ a1 _ a2 _ _)
Then
If
Function:
(defun stv-in->width (x stv) (declare (xargs :guard (and (symbolp x) (processed-stv-p stv)))) (let ((__function__ 'stv-in->width)) (declare (ignorable __function__)) (b* (((processed-stv stv) stv) ((compiled-stv cstv) stv.compiled-stv) (look (hons-assoc-equal x cstv.in-usersyms)) ((unless look) (raise "Unknown input: ~x0~%" x) 0)) (len (cdr look)))))
Theorem:
(defthm natp-of-stv-in->width (b* ((width (stv-in->width x stv))) (natp width)) :rule-classes :type-prescription)