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