Recognize choice second-order functions.
(choice-sofunp sofun wrld) → yes/no
Function:
(defun choice-sofunp (sofun wrld) (declare (xargs :guard (plist-worldp wrld))) (let ((__function__ 'choice-sofunp)) (declare (ignorable __function__)) (and (sofunp sofun wrld) (eq (sofun-kind sofun wrld) 'choice))))
Theorem:
(defthm booleanp-of-choice-sofunp (b* ((yes/no (choice-sofunp sofun wrld))) (booleanp yes/no)) :rule-classes :rewrite)