Construct a reduced BED for
(mk-op-true-x op right) → bed
Function:
(defun mk-op-true-x (op right) (declare (xargs :guard (bed-op-p op))) (let ((__function__ 'mk-op-true-x)) (declare (ignorable __function__)) (b* ((op (bed-op-fix$ op)) ((when (eql op (bed-op-true))) t) ((when (eql op (bed-op-ior))) t) ((when (eql op (bed-op-orc2))) t) ((when (eql op (bed-op-arg1))) t) ((when (eql op (bed-op-orc1))) right) ((when (eql op (bed-op-arg2))) right) ((when (eql op (bed-op-eqv))) right) ((when (eql op (bed-op-and))) right) ((when (eql op (bed-op-nand))) (mk-not right)) ((when (eql op (bed-op-xor))) (mk-not right)) ((when (eql op (bed-op-not2))) (mk-not right)) ((when (eql op (bed-op-andc2))) (mk-not right)) ((when (eql op (bed-op-not1))) nil) ((when (eql op (bed-op-andc1))) nil) ((when (eql op (bed-op-nor))) nil) ((when (eql op (bed-op-false))) nil)) (mk-op-raw op t right))))
Theorem:
(defthm bed-eval-of-mk-op-true-x (equal (bed-eval (mk-op-true-x op right) env) (bed-eval (mk-op-raw op t right) env)))