Logically simple definition that is similar to nat-to-hex-chars.
(basic-nat-to-hex-chars n) → chars
This almost computes
Function:
(defun basic-nat-to-hex-chars (n) (declare (xargs :guard (natp n))) (let ((acl2::__function__ 'basic-nat-to-hex-chars)) (declare (ignorable acl2::__function__)) (if (zp n) nil (cons (hex-digit-to-char (logand n 15)) (basic-nat-to-hex-chars (ash n -4))))))
Theorem:
(defthm hex-digit-char-list*p-of-basic-nat-to-hex-chars (b* ((chars (basic-nat-to-hex-chars n))) (hex-digit-char-list*p chars)) :rule-classes :rewrite)
Theorem:
(defthm basic-nat-to-hex-chars-when-zp (implies (zp n) (equal (basic-nat-to-hex-chars n) nil)))
Theorem:
(defthm true-listp-of-basic-nat-to-hex-chars (true-listp (basic-nat-to-hex-chars n)) :rule-classes :type-prescription)
Theorem:
(defthm character-listp-of-basic-nat-to-hex-chars (character-listp (basic-nat-to-hex-chars n)))
Theorem:
(defthm basic-nat-to-hex-chars-under-iff (iff (basic-nat-to-hex-chars n) (not (zp n))))
Theorem:
(defthm consp-of-basic-nat-to-hex-chars (equal (consp (basic-nat-to-hex-chars n)) (if (basic-nat-to-hex-chars n) t nil)))
Theorem:
(defthm basic-nat-to-hex-chars-one-to-one (equal (equal (basic-nat-to-hex-chars n) (basic-nat-to-hex-chars m)) (equal (nfix n) (nfix m))))