Retrieve, from a set of certificates, the subset of certificates with author in a given set and with a given round.
(certificates-with-authors+round authors round certs) → certs-with-authors-and-round
Function:
(defun certificates-with-authors+round (authors round certs) (declare (xargs :guard (and (address-setp authors) (posp round) (certificate-setp certs)))) (let ((__function__ 'certificates-with-authors+round)) (declare (ignorable __function__)) (b* (((when (emptyp certs)) nil) ((certificate cert) (head certs))) (if (and (in cert.author (address-set-fix authors)) (equal cert.round (pos-fix round))) (insert (certificate-fix cert) (certificates-with-authors+round authors round (tail certs))) (certificates-with-authors+round authors round (tail certs))))))
Theorem:
(defthm certificate-setp-of-certificates-with-authors+round (b* ((certs-with-authors-and-round (certificates-with-authors+round authors round certs))) (certificate-setp certs-with-authors-and-round)) :rule-classes :rewrite)
Theorem:
(defthm certificates-with-authors+round-of-address-set-fix-authors (equal (certificates-with-authors+round (address-set-fix authors) round certs) (certificates-with-authors+round authors round certs)))
Theorem:
(defthm certificates-with-authors+round-address-set-equiv-congruence-on-authors (implies (address-set-equiv authors authors-equiv) (equal (certificates-with-authors+round authors round certs) (certificates-with-authors+round authors-equiv round certs))) :rule-classes :congruence)
Theorem:
(defthm certificates-with-authors+round-of-pos-fix-round (equal (certificates-with-authors+round authors (pos-fix round) certs) (certificates-with-authors+round authors round certs)))
Theorem:
(defthm certificates-with-authors+round-pos-equiv-congruence-on-round (implies (acl2::pos-equiv round round-equiv) (equal (certificates-with-authors+round authors round certs) (certificates-with-authors+round authors round-equiv certs))) :rule-classes :congruence)
Theorem:
(defthm certificates-with-authors+round-subset (implies (certificate-setp certs) (b* ((?certs-with-authors-and-round (certificates-with-authors+round authors round certs))) (subset certs-with-authors-and-round certs))))
Theorem:
(defthm in-of-certificates-with-authors+round (implies (certificate-setp certs) (equal (in cert (certificates-with-authors+round authors round certs)) (and (in cert certs) (equal (certificate->round cert) (pos-fix round)) (in (certificate->author cert) (address-set-fix authors))))))
Theorem:
(defthm certificates-with-authors+round-when-emptyp (implies (emptyp authors) (equal (certificates-with-authors+round authors round certs) nil)))
Theorem:
(defthm certificates-with-authors+round-to-authors-of-round (implies (certificate-setp certs) (equal (certificates-with-authors+round authors round certs) (certificates-with-authors authors (certificates-with-round round certs)))))
Theorem:
(defthm certificates-with-authors+round-to-round-of-authors (implies (certificate-setp certs) (equal (certificates-with-authors+round authors round certs) (certificates-with-round round (certificates-with-authors authors certs)))))
Theorem:
(defthm certificate-set->round-set-of-certificates-with-authors+round (equal (certificate-set->round-set (certificates-with-authors+round authors round certs)) (if (emptyp (certificates-with-authors+round authors round certs)) nil (insert (pos-fix round) nil))))
Theorem:
(defthm certificate-set->round-set-of-certificates-with-authors+round-not-empty (b* ((rounds (certificate-set->round-set (certificates-with-authors+round authors round certs)))) (implies (not (emptyp rounds)) (equal rounds (insert (pos-fix round) nil)))))