Included Books
other
(in-package "ACL2")
include-book
(include-book "std/basic/defs" :dir :system)
encapsulate
(encapsulate (((xp *) => *)) (local (defun xp (x) x)))
encapsulate
(encapsulate (((elementp * *) => * :formals (x y) :guard (and (xp x) (integerp y)))) (local (defun elementp (x y) (cons x y))))
lboundpfunction
(defun-sk lboundp (x y) (declare (xargs :guard (and (xp x) (integerp y)))) (forall (y1) (impliez (and (integerp y1) (elementp x y1)) (<= (ifix y) y1))) :rewrite (implies (and (lboundp x y) (integerp y1) (elementp x y1)) (<= (ifix y) y1)))
booleanp-of-lboundptheorem
(defthm booleanp-of-lboundp (booleanp (lboundp x y)))
existspfunction
(defun-sk existsp (x) (declare (xargs :guard (xp x))) (exists (y) (and (integerp y) (elementp x y) (lboundp x y))) :skolem-name existsp-witness)
booleanp-of-existsptheorem
(defthm booleanp-of-existsp (booleanp (existsp x)))
maybe-integerp-of-ftheorem
(defthm maybe-integerp-of-f (maybe-integerp (f x)) :hints (("Goal" :in-theory (enable maybe-integerp existsp))))
integerp-of-f-equal-existsptheorem
(defthm integerp-of-f-equal-existsp (equal (integerp (f x)) (existsp x)) :hints (("Goal" :in-theory (enable existsp))))
integerp-of-f-when-existsptheorem
(defthm integerp-of-f-when-existsp (implies (existsp x) (integerp (f x))) :rule-classes :type-prescription)
f-iff-existsptheorem
(defthm f-iff-existsp (iff (f x) (existsp x)) :hints (("Goal" :in-theory (enable existsp))))
not-f-when-not-existsptheorem
(defthm not-f-when-not-existsp (implies (not (existsp x)) (not (f x))) :rule-classes :type-prescription)
elementp-of-f-when-existsptheorem
(defthm elementp-of-f-when-existsp (implies (existsp x) (elementp x (f x))) :hints (("Goal" :in-theory (enable existsp))))
lboundp-of-f-when-existsptheorem
(defthm lboundp-of-f-when-existsp (implies (existsp x) (lboundp x (f x))) :hints (("Goal" :in-theory (enable existsp))))
f-leq-when-existsp-lineartheorem
(defthm f-leq-when-existsp-linear (implies (and (existsp x) (elementp x y1) (integerp y1)) (<= (f x) y1)) :rule-classes :linear :hints (("Goal" :in-theory (disable f) :use (lboundp-of-f-when-existsp (:instance lboundp-necc (y (f x)))))))
f-leq-when-existsp-rewritetheorem
(defthm f-leq-when-existsp-rewrite (implies (and (existsp x) (elementp x y1) (integerp y1)) (<= (f x) y1)) :hints (("Goal" :by f-leq-when-existsp-linear)))
f-geq-when-existsp-lineartheorem
(defthm f-geq-when-existsp-linear (implies (and (existsp x) (lboundp x y1) (integerp y1)) (>= (f x) y1)) :rule-classes :linear :hints (("Goal" :in-theory (disable f) :use (:instance lboundp-necc (y1 (f x)) (y y1)))))
f-geq-when-existsp-rewritetheorem
(defthm f-geq-when-existsp-rewrite (implies (and (existsp x) (lboundp x y1) (integerp y1)) (>= (f x) y1)) :hints (("Goal" :by f-geq-when-existsp-linear)))
lbound-leq-membertheorem
(defthm lbound-leq-member (implies (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1)) (<= y1 y0)) :rule-classes nil :hints (("Goal" :use (:instance lboundp-necc (y y1) (y1 y0)))))
lbound-nonmember-lt-membertheorem
(defthm lbound-nonmember-lt-member (implies (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1) (not (elementp x y1))) (< y1 y0)) :rule-classes nil :hints (("Goal" :use lbound-leq-member)))
find-minfunction
(defun find-min (x y1 y0) (declare (xargs :measure (nfix (- y0 y1)) :hints (("Goal" :use lbound-nonmember-lt-member)))) (if (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1)) (if (elementp x y1) y1 (find-min x (1+ y1) y0)) 0))
find-min-lboundp-preservationtheorem
(defthm find-min-lboundp-preservation (implies (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1) (not (elementp x y1))) (lboundp x (1+ y1))) :hints (("Goal" :expand ((lboundp x (1+ y1))) :use (:instance lboundp-necc (y y1) (y1 (lboundp-witness x (1+ y1)))))))
elementp-of-find-mintheorem
(defthm elementp-of-find-min (implies (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1)) (elementp x (find-min x y1 y0))) :hints ('(:use (:instance lboundp-necc (y y1) (y1 0))) '(:use (:instance lboundp-necc (y 0) (y1 y0)))))
lboundp-of-find-mintheorem
(defthm lboundp-of-find-min (implies (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1)) (lboundp x (find-min x y1 y0))) :hints ('(:use (:instance lboundp-necc (y y1) (y1 0))) '(:use (:instance lboundp-necc (y 0) (y1 y0)))))
existsp-when-nonempty-and-boundedtheorem
(defthm existsp-when-nonempty-and-bounded (implies (and (integerp y0) (elementp x y0) (integerp y1) (lboundp x y1)) (existsp x)) :rule-classes nil :hints (("Goal" :use (:instance existsp-suff (y (find-min x y1 y0))))))
equal-when-member-and-lboundtheorem
(defthm equal-when-member-and-lbound (implies (and (integerp y) (elementp x y) (lboundp x y)) (equal (f x) y)) :rule-classes nil :hints (("Goal" :in-theory (disable f-leq-when-existsp-rewrite f-geq-when-existsp-rewrite) :use ((:instance existsp-when-nonempty-and-bounded (y0 y) (y1 y)) (:instance f-leq-when-existsp-rewrite (y1 y)) (:instance lboundp-necc (y1 (f x)))))))