Access the fanin 0 literal from a gate node, whether an AND or an XOR.
Function:
(defun gate-node->fanin0 (node) (declare (xargs :guard (node-p node))) (declare (xargs :guard (equal (node->type node) (gate-type)))) (let ((__function__ 'gate-node->fanin0)) (declare (ignorable __function__)) (lit-fix (if (equal (node->regp node) 1) (xor-node->fanin0 node) (and-node->fanin0 node)))))
Theorem:
(defthm litp-of-gate-node->fanin0 (b* ((lit (gate-node->fanin0 node))) (litp lit)) :rule-classes :type-prescription)
Theorem:
(defthm gate-node->fanin0-of-and-node (equal (gate-node->fanin0 (and-node f0 f1)) (lit-fix f0)))
Theorem:
(defthm gate-node->fanin0-of-xor-node (equal (gate-node->fanin0 (xor-node f0 f1)) (lit-fix f0)))
Theorem:
(defthm gate-node->fanin0-of-node-fix-node (equal (gate-node->fanin0 (node-fix node)) (gate-node->fanin0 node)))
Theorem:
(defthm gate-node->fanin0-node-equiv-congruence-on-node (implies (node-equiv node node-equiv) (equal (gate-node->fanin0 node) (gate-node->fanin0 node-equiv))) :rule-classes :congruence)