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